| /* |
| * Copyright (c) 1993-1994 The Hewlett-Packard Development Company |
| * All rights reserved. |
| * |
| * Redistribution and use in source and binary forms, with or without |
| * modification, are permitted provided that the following conditions are |
| * met: redistributions of source code must retain the above copyright |
| * notice, this list of conditions and the following disclaimer; |
| * redistributions in binary form must reproduce the above copyright |
| * notice, this list of conditions and the following disclaimer in the |
| * documentation and/or other materials provided with the distribution; |
| * neither the name of the copyright holders nor the names of its |
| * contributors may be used to endorse or promote products derived from |
| * this software without specific prior written permission. |
| * |
| * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
| * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
| * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
| * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
| * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
| * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
| * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
| * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
| * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| */ |
| |
| #ifndef HUDSON_MACROS_LOADED |
| #define HUDSON_MACROS_LOADED 1 |
| |
| #define STALL \ |
| mfpr r31, pt0 |
| |
| #define NOP \ |
| bis $31, $31, $31 |
| |
| /* |
| ** Align code on an 8K byte page boundary. |
| */ |
| |
| #define ALIGN_PAGE \ |
| .align 13 |
| |
| /* |
| ** Align code on a 32 byte block boundary. |
| */ |
| |
| #define ALIGN_BLOCK \ |
| .align 5 |
| |
| /* |
| ** Align code on a quadword boundary. |
| */ |
| |
| #define ALIGN_BRANCH \ |
| .align 3 |
| |
| /* |
| ** Hardware vectors go in .text 0 sub-segment. |
| */ |
| |
| #define HDW_VECTOR(offset) \ |
| . = offset |
| |
| /* |
| ** Privileged CALL_PAL functions are in .text 1 sub-segment. |
| */ |
| |
| #define CALL_PAL_PRIV(vector) \ |
| . = (PAL_CALL_PAL_PRIV_ENTRY+(vector<<6)) |
| |
| /* |
| ** Unprivileged CALL_PAL functions are in .text 1 sub-segment, |
| ** the privileged bit is removed from these vectors. |
| */ |
| |
| #define CALL_PAL_UNPRIV(vector) \ |
| . = (PAL_CALL_PAL_UNPRIV_ENTRY+((vector&0x3F)<<6)) |
| |
| /* |
| ** Implements a load "immediate" longword function |
| */ |
| #define LDLI(reg,val) \ |
| ldah reg, ((val+0x8000) >> 16)(zero); \ |
| lda reg, (val&0xffff)(reg) |
| |
| #endif |