1 | /* |
---|
2 | * Copyright (c) 2007 Dietmar Hahn <dietmar.hahn@fujitsu-siemens.com> |
---|
3 | * |
---|
4 | ****************************************************************************** |
---|
5 | * |
---|
6 | * Redistribution and use in source and binary forms, with or without |
---|
7 | * modification, are permitted provided that the following conditions |
---|
8 | * are met: |
---|
9 | * 1. Redistributions of source code must retain the above copyright |
---|
10 | * notice, this list of conditions and the following disclaimer. |
---|
11 | * 2. Redistributions in binary form must reproduce the above copyright |
---|
12 | * notice, this list of conditions and the following disclaimer in the |
---|
13 | * documentation and/or other materials provided with the distribution. |
---|
14 | * |
---|
15 | * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND |
---|
16 | * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
---|
17 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
---|
18 | * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE |
---|
19 | * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL |
---|
20 | * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS |
---|
21 | * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) |
---|
22 | * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT |
---|
23 | * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY |
---|
24 | * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF |
---|
25 | * SUCH DAMAGE. |
---|
26 | * |
---|
27 | */ |
---|
28 | #include "types.h" |
---|
29 | #include "sched.h" |
---|
30 | #include "xen/xen.h" |
---|
31 | #include "xen/arch-ia64.h" |
---|
32 | |
---|
33 | #define DEFINE(sym, val) \ |
---|
34 | asm volatile("\n->" sym " %0 /* " #val " */": : "i" (val)) |
---|
35 | #define DEFINE_STR2(sym, pfx, val) \ |
---|
36 | asm volatile("\n->" sym " " pfx "%0" : : "i"(val)); |
---|
37 | |
---|
38 | #define SZ(st,e) sizeof(((st *)0)->e) |
---|
39 | #define OFF(st,e,d,o) \ |
---|
40 | DEFINE(#d, offsetof(st, e) + o); \ |
---|
41 | DEFINE(#d "_sz", SZ(st,e )); \ |
---|
42 | DEFINE_STR2(#d "_ld", "ld", SZ(st, e)); \ |
---|
43 | DEFINE_STR2(#d "_st", "st", SZ(st, e)); |
---|
44 | |
---|
45 | #define TFOFF(e,d) OFF(trap_frame_t, e, d, 0) |
---|
46 | #define SIZE(st,d) DEFINE(#d, sizeof(st)) |
---|
47 | |
---|
48 | #define SWOFF(e,d) OFF(struct thread, e, d, 0) |
---|
49 | |
---|
50 | /* shared_info_t from xen/xen.h */ |
---|
51 | #define SI_OFF(e, d) OFF(shared_info_t, e, d,0) |
---|
52 | /* mapped_regs_t from xen/arch-ia64.h */ |
---|
53 | #define MR_OFF(e, d) OFF(mapped_regs_t, e, d, XMAPPEDREGS_OFS) |
---|
54 | |
---|
55 | int |
---|
56 | main(int argc, char ** argv) |
---|
57 | { |
---|
58 | TFOFF(cfm, TF_CFM); |
---|
59 | TFOFF(pfs, TF_PFS); |
---|
60 | TFOFF(bsp, TF_BSP); |
---|
61 | TFOFF(rnat, TF_RNAT); |
---|
62 | TFOFF(csd, TF_CSD); |
---|
63 | TFOFF(ccv, TF_CCV); |
---|
64 | TFOFF(unat, TF_UNAT); |
---|
65 | TFOFF(fpsr, TF_FPSR); |
---|
66 | TFOFF(pr, TF_PR); |
---|
67 | |
---|
68 | TFOFF(sp, TF_SP); |
---|
69 | TFOFF(gp, TF_GP); |
---|
70 | TFOFF(tp, TF_TP); |
---|
71 | |
---|
72 | TFOFF(r2, TF_GREG2); |
---|
73 | TFOFF(r3, TF_GREG3); |
---|
74 | TFOFF(r16, TF_GREG16); |
---|
75 | TFOFF(r17, TF_GREG17); |
---|
76 | |
---|
77 | TFOFF(b0, TF_BREG0); |
---|
78 | TFOFF(b6, TF_BREG6); |
---|
79 | TFOFF(b7, TF_BREG7); |
---|
80 | |
---|
81 | TFOFF(f6, TF_FREG6); |
---|
82 | TFOFF(f7, TF_FREG7); |
---|
83 | |
---|
84 | TFOFF(rsc, TF_RSC); |
---|
85 | TFOFF(ndirty, TF_NDIRTY); |
---|
86 | TFOFF(ssd, TF_SSD); |
---|
87 | TFOFF(iip, TF_IIP); |
---|
88 | TFOFF(ipsr, TF_IPSR); |
---|
89 | TFOFF(ifs, TF_IFS); |
---|
90 | TFOFF(trap_num, TF_TRAP_NUM); |
---|
91 | |
---|
92 | TFOFF(ifa, TF_IFA); |
---|
93 | TFOFF(isr, TF_ISR); |
---|
94 | TFOFF(iim, TF_IIM); |
---|
95 | |
---|
96 | SIZE(trap_frame_t, TF_SIZE); |
---|
97 | |
---|
98 | SIZE(struct thread, SW_SIZE); |
---|
99 | SWOFF(regs.unat_b, SW_UNATB); |
---|
100 | SWOFF(regs.sp, SW_SP); |
---|
101 | SWOFF(regs.rp, SW_RP); |
---|
102 | SWOFF(regs.pr, SW_PR); |
---|
103 | SWOFF(regs.pfs, SW_PFS); |
---|
104 | SWOFF(regs.bsp, SW_BSP); |
---|
105 | SWOFF(regs.rnat, SW_RNAT); |
---|
106 | SWOFF(regs.lc, SW_LC); |
---|
107 | //SWOFF(regs.fpsr, SW_FPSR); |
---|
108 | //SWOFF(regs.psr, SW_PSR); |
---|
109 | //SWOFF(regs.gp, SW_GP); |
---|
110 | SWOFF(regs.unat_a, SW_UNATA); |
---|
111 | SWOFF(regs.r4, SW_R4); |
---|
112 | SWOFF(regs.r5, SW_R5); |
---|
113 | SWOFF(regs.r6, SW_R6); |
---|
114 | SWOFF(regs.r7, SW_R7); |
---|
115 | SWOFF(regs.b1, SW_B1); |
---|
116 | SWOFF(regs.b2, SW_B2); |
---|
117 | SWOFF(regs.b3, SW_B3); |
---|
118 | SWOFF(regs.b4, SW_B4); |
---|
119 | SWOFF(regs.b5, SW_B5); |
---|
120 | SWOFF(regs.f2, SW_F2); |
---|
121 | SWOFF(regs.f3, SW_F3); |
---|
122 | SWOFF(regs.f4, SW_F4); |
---|
123 | SWOFF(regs.f5, SW_F5); |
---|
124 | |
---|
125 | SI_OFF(arch.start_info_pfn, START_INFO_PFN); |
---|
126 | MR_OFF(interrupt_mask_addr, XSI_PSR_I_ADDR_OFS); |
---|
127 | MR_OFF(interrupt_collection_enabled, XSI_PSR_IC_OFS); |
---|
128 | MR_OFF(ipsr, XSI_IPSR_OFS); |
---|
129 | MR_OFF(iip, XSI_IIP_OFS); |
---|
130 | MR_OFF(ifs, XSI_IFS_OFS); |
---|
131 | MR_OFF(ifa, XSI_IFA_OFS); |
---|
132 | MR_OFF(iim, XSI_IIM_OFS); |
---|
133 | MR_OFF(iim, XSI_IIM_OFS); |
---|
134 | MR_OFF(iipa, XSI_IIPA_OFS); |
---|
135 | MR_OFF(isr, XSI_ISR_OFS); |
---|
136 | MR_OFF(banknum, XSI_BANKNUM_OFS); |
---|
137 | MR_OFF(bank1_regs[0], XSI_BANK1_R16_OFS); |
---|
138 | MR_OFF(precover_ifs, XSI_PRECOVER_IFS_OFS); |
---|
139 | |
---|
140 | return 0; |
---|
141 | } |
---|