/****************************************************************************** * arch/ia64/include/asm/native/inst.h * * Copyright (c) 2008 Isaku Yamahata <yamahata at valinux co jp> * VA Linux Systems Japan K.K. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * */ #define DO_SAVE_MIN IA64_NATIVE_DO_SAVE_MIN #define __paravirt_switch_to ia64_native_switch_to #define __paravirt_leave_syscall ia64_native_leave_syscall #define __paravirt_work_processed_syscall ia64_native_work_processed_syscall #define __paravirt_leave_kernel ia64_native_leave_kernel #define __paravirt_pending_syscall_end ia64_work_pending_syscall_end #define __paravirt_work_processed_syscall_target \ ia64_work_processed_syscall #define paravirt_fsyscall_table ia64_native_fsyscall_table #define paravirt_fsys_bubble_down ia64_native_fsys_bubble_down #ifdef CONFIG_PARAVIRT_GUEST_ASM_CLOBBER_CHECK # define PARAVIRT_POISON 0xdeadbeefbaadf00d # define CLOBBER(clob) \ ;; \ movl clob = PARAVIRT_POISON; \ ;; # define CLOBBER_PRED(pred_clob) \ ;; \ cmp.eq pred_clob, p0 = r0, r0 \ ;; #else # define CLOBBER(clob) /* nothing */ # define CLOBBER_PRED(pred_clob) /* nothing */ #endif #define MOV_FROM_IFA(reg) \ mov reg = cr.ifa #define MOV_FROM_ITIR(reg) \ mov reg = cr.itir #define MOV_FROM_ISR(reg) \ mov reg = cr.isr #define MOV_FROM_IHA(reg) \ mov reg = cr.iha #define MOV_FROM_IPSR(pred, reg) \ (pred) mov reg = cr.ipsr #define MOV_FROM_IIM(reg) \ mov reg = cr.iim #define MOV_FROM_IIP(reg) \ mov reg = cr.iip #define MOV_FROM_IVR(reg, clob) \ mov reg = cr.ivr \ CLOBBER(clob) #define MOV_FROM_PSR(pred, reg, clob) \ (pred) mov reg = psr \ CLOBBER(clob) #define MOV_FROM_ITC(pred, pred_clob, reg, clob) \ (pred) mov reg = ar.itc \ CLOBBER(clob) \ CLOBBER_PRED(pred_clob) #define MOV_TO_IFA(reg, clob) \ mov cr.ifa = reg \ CLOBBER(clob) #define MOV_TO_ITIR(pred, reg, clob) \ (pred) mov cr.itir = reg \ CLOBBER(clob) #define MOV_TO_IHA(pred, reg, clob) \ (pred) mov cr.iha = reg \ CLOBBER(clob) #define MOV_TO_IPSR(pred, reg, clob) \ (pred) mov cr.ipsr = reg \ CLOBBER(clob) #define MOV_TO_IFS(pred, reg, clob) \ (pred) mov cr.ifs = reg \ CLOBBER(clob) #define MOV_TO_IIP(reg, clob) \ mov cr.iip = reg \ CLOBBER(clob) #define MOV_TO_KR(kr, reg, clob0, clob1) \ mov IA64_KR(kr) = reg \ CLOBBER(clob0) \ CLOBBER(clob1) #define ITC_I(pred, reg, clob) \ (pred) itc.i reg \ CLOBBER(clob) #define ITC_D(pred, reg, clob) \ (pred) itc.d reg \ CLOBBER(clob) #define ITC_I_AND_D(pred_i, pred_d, reg, clob) \ (pred_i) itc.i reg; \ (pred_d) itc.d reg \ CLOBBER(clob) #define THASH(pred, reg0, reg1, clob) \ (pred) thash reg0 = reg1 \ CLOBBER(clob) #define SSM_PSR_IC_AND_DEFAULT_BITS_AND_SRLZ_I(clob0, clob1) \ ssm psr.ic | PSR_DEFAULT_BITS \ CLOBBER(clob0) \ CLOBBER(clob1) \ ;; \ srlz.i /* guarantee that interruption collectin is on */ \ ;; #define SSM_PSR_IC_AND_SRLZ_D(clob0, clob1) \ ssm psr.ic \ CLOBBER(clob0) \ CLOBBER(clob1) \ ;; \ srlz.d #define RSM_PSR_IC(clob) \ rsm psr.ic \ CLOBBER(clob) #define SSM_PSR_I(pred, pred_clob, clob) \ (pred) ssm psr.i \ CLOBBER(clob) \ CLOBBER_PRED(pred_clob) #define RSM_PSR_I(pred, clob0, clob1) \ (pred) rsm psr.i \ CLOBBER(clob0) \ CLOBBER(clob1) #define RSM_PSR_I_IC(clob0, clob1, clob2) \ rsm psr.i | psr.ic \ CLOBBER(clob0) \ CLOBBER(clob1) \ CLOBBER(clob2) #define RSM_PSR_DT \ rsm psr.dt #define RSM_PSR_BE_I(clob0, clob1) \ rsm psr.be | psr.i \ CLOBBER(clob0) \ CLOBBER(clob1) #define SSM_PSR_DT_AND_SRLZ_I \ ssm psr.dt \ ;; \ srlz.i #define BSW_0(clob0, clob1, clob2) \ bsw.0 \ CLOBBER(clob0) \ CLOBBER(clob1) \ CLOBBER(clob2) #define BSW_1(clob0, clob1) \ bsw.1 \ CLOBBER(clob0) \ CLOBBER(clob1) #define COVER \ cover #define RFI \ rfi