Blame view
arch/ia64/kernel/paravirtentry.S
3.13 KB
4df8d22bb [IA64] pvops: par... |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
/****************************************************************************** * linux/arch/ia64/xen/paravirtentry.S * * 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 * */ |
03f511dd0 ia64/pv_ops: impl... |
22 |
#include <linux/init.h> |
4df8d22bb [IA64] pvops: par... |
23 24 |
#include <asm/asmmacro.h> #include <asm/asm-offsets.h> |
03f511dd0 ia64/pv_ops: impl... |
25 26 |
#include <asm/paravirt_privop.h> #include <asm/paravirt_patch.h> |
4df8d22bb [IA64] pvops: par... |
27 28 29 |
#include "entry.h" #define DATA8(sym, init_value) \ |
54cb27a71 Rename .data.read... |
30 |
.pushsection .data..read_mostly ; \ |
4df8d22bb [IA64] pvops: par... |
31 32 33 34 35 |
.align 8 ; \ .global sym ; \ sym: ; \ data8 init_value ; \ .popsection |
03f511dd0 ia64/pv_ops: impl... |
36 37 38 39 40 41 42 43 |
#define BRANCH(targ, reg, breg, type) \ PARAVIRT_PATCH_SITE_BR(PARAVIRT_PATCH_TYPE_BR_ ## type) ; \ ;; \ movl reg=targ ; \ ;; \ ld8 reg=[reg] ; \ ;; \ mov breg=reg ; \ |
4df8d22bb [IA64] pvops: par... |
44 |
br.cond.sptk.many breg |
03f511dd0 ia64/pv_ops: impl... |
45 46 47 48 |
#define BRANCH_PROC(sym, reg, breg, type) \ DATA8(paravirt_ ## sym ## _targ, ia64_native_ ## sym) ; \ GLOBAL_ENTRY(paravirt_ ## sym) ; \ BRANCH(paravirt_ ## sym ## _targ, reg, breg, type) ; \ |
4df8d22bb [IA64] pvops: par... |
49 |
END(paravirt_ ## sym) |
03f511dd0 ia64/pv_ops: impl... |
50 51 52 53 54 |
#define BRANCH_PROC_UNWINFO(sym, reg, breg, type) \ DATA8(paravirt_ ## sym ## _targ, ia64_native_ ## sym) ; \ GLOBAL_ENTRY(paravirt_ ## sym) ; \ PT_REGS_UNWIND_INFO(0) ; \ BRANCH(paravirt_ ## sym ## _targ, reg, breg, type) ; \ |
4df8d22bb [IA64] pvops: par... |
55 |
END(paravirt_ ## sym) |
03f511dd0 ia64/pv_ops: impl... |
56 57 58 59 |
BRANCH_PROC(switch_to, r22, b7, SWITCH_TO) BRANCH_PROC_UNWINFO(leave_syscall, r22, b7, LEAVE_SYSCALL) BRANCH_PROC(work_processed_syscall, r2, b7, WORK_PROCESSED_SYSCALL) BRANCH_PROC_UNWINFO(leave_kernel, r22, b7, LEAVE_KERNEL) |
bf7ab02f6 ia64/pv_op/binary... |
60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 |
#ifdef CONFIG_MODULES #define __INIT_OR_MODULE .text #define __INITDATA_OR_MODULE .data #else #define __INIT_OR_MODULE __INIT #define __INITDATA_OR_MODULE __INITDATA #endif /* CONFIG_MODULES */ __INIT_OR_MODULE GLOBAL_ENTRY(paravirt_fc_i) fc.i r32 br.ret.sptk.many rp END(paravirt_fc_i) __FINIT __INIT_OR_MODULE .align 32 GLOBAL_ENTRY(paravirt_nop_b_inst_bundle) { nop.b 0 nop.b 0 nop.b 0 } END(paravirt_nop_b_inst_bundle) __FINIT /* NOTE: nop.[mfi] has same format */ __INIT_OR_MODULE GLOBAL_ENTRY(paravirt_nop_mfi_inst_bundle) { nop.m 0 nop.f 0 nop.i 0 } END(paravirt_nop_mfi_inst_bundle) __FINIT __INIT_OR_MODULE GLOBAL_ENTRY(paravirt_nop_bundle) paravirt_nop_bundle_start: { nop 0 nop 0 nop 0 } paravirt_nop_bundle_end: END(paravirt_nop_bundle) __FINIT __INITDATA_OR_MODULE .align 8 .global paravirt_nop_bundle_size paravirt_nop_bundle_size: data8 paravirt_nop_bundle_end - paravirt_nop_bundle_start |