ivt.S 52 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686
  1. /*
  2. * arch/ia64/kernel/ivt.S
  3. *
  4. * Copyright (C) 1998-2001, 2003, 2005 Hewlett-Packard Co
  5. * Stephane Eranian <eranian@hpl.hp.com>
  6. * David Mosberger <davidm@hpl.hp.com>
  7. * Copyright (C) 2000, 2002-2003 Intel Co
  8. * Asit Mallick <asit.k.mallick@intel.com>
  9. * Suresh Siddha <suresh.b.siddha@intel.com>
  10. * Kenneth Chen <kenneth.w.chen@intel.com>
  11. * Fenghua Yu <fenghua.yu@intel.com>
  12. *
  13. * 00/08/23 Asit Mallick <asit.k.mallick@intel.com> TLB handling for SMP
  14. * 00/12/20 David Mosberger-Tang <davidm@hpl.hp.com> DTLB/ITLB handler now uses virtual PT.
  15. *
  16. * Copyright (C) 2005 Hewlett-Packard Co
  17. * Dan Magenheimer <dan.magenheimer@hp.com>
  18. * Xen paravirtualization
  19. * Copyright (c) 2008 Isaku Yamahata <yamahata at valinux co jp>
  20. * VA Linux Systems Japan K.K.
  21. * pv_ops.
  22. * Yaozu (Eddie) Dong <eddie.dong@intel.com>
  23. */
  24. /*
  25. * This file defines the interruption vector table used by the CPU.
  26. * It does not include one entry per possible cause of interruption.
  27. *
  28. * The first 20 entries of the table contain 64 bundles each while the
  29. * remaining 48 entries contain only 16 bundles each.
  30. *
  31. * The 64 bundles are used to allow inlining the whole handler for critical
  32. * interruptions like TLB misses.
  33. *
  34. * For each entry, the comment is as follows:
  35. *
  36. * // 0x1c00 Entry 7 (size 64 bundles) Data Key Miss (12,51)
  37. * entry offset ----/ / / / /
  38. * entry number ---------/ / / /
  39. * size of the entry -------------/ / /
  40. * vector name -------------------------------------/ /
  41. * interruptions triggering this vector ----------------------/
  42. *
  43. * The table is 32KB in size and must be aligned on 32KB boundary.
  44. * (The CPU ignores the 15 lower bits of the address)
  45. *
  46. * Table is based upon EAS2.6 (Oct 1999)
  47. */
  48. #include <asm/asmmacro.h>
  49. #include <asm/break.h>
  50. #include <asm/kregs.h>
  51. #include <asm/asm-offsets.h>
  52. #include <asm/pgtable.h>
  53. #include <asm/processor.h>
  54. #include <asm/ptrace.h>
  55. #include <asm/thread_info.h>
  56. #include <asm/unistd.h>
  57. #include <asm/errno.h>
  58. #if 0
  59. # define PSR_DEFAULT_BITS psr.ac
  60. #else
  61. # define PSR_DEFAULT_BITS 0
  62. #endif
  63. #if 0
  64. /*
  65. * This lets you track the last eight faults that occurred on the CPU. Make sure ar.k2 isn't
  66. * needed for something else before enabling this...
  67. */
  68. # define DBG_FAULT(i) mov r16=ar.k2;; shl r16=r16,8;; add r16=(i),r16;;mov ar.k2=r16
  69. #else
  70. # define DBG_FAULT(i)
  71. #endif
  72. #include "minstate.h"
  73. #define FAULT(n) \
  74. mov r31=pr; \
  75. mov r19=n;; /* prepare to save predicates */ \
  76. br.sptk.many dispatch_to_fault_handler
  77. .section .text..ivt,"ax"
  78. .align 32768 // align on 32KB boundary
  79. .global ia64_ivt
  80. ia64_ivt:
  81. /////////////////////////////////////////////////////////////////////////////////////////
  82. // 0x0000 Entry 0 (size 64 bundles) VHPT Translation (8,20,47)
  83. ENTRY(vhpt_miss)
  84. DBG_FAULT(0)
  85. /*
  86. * The VHPT vector is invoked when the TLB entry for the virtual page table
  87. * is missing. This happens only as a result of a previous
  88. * (the "original") TLB miss, which may either be caused by an instruction
  89. * fetch or a data access (or non-access).
  90. *
  91. * What we do here is normal TLB miss handing for the _original_ miss,
  92. * followed by inserting the TLB entry for the virtual page table page
  93. * that the VHPT walker was attempting to access. The latter gets
  94. * inserted as long as page table entry above pte level have valid
  95. * mappings for the faulting address. The TLB entry for the original
  96. * miss gets inserted only if the pte entry indicates that the page is
  97. * present.
  98. *
  99. * do_page_fault gets invoked in the following cases:
  100. * - the faulting virtual address uses unimplemented address bits
  101. * - the faulting virtual address has no valid page table mapping
  102. */
  103. MOV_FROM_IFA(r16) // get address that caused the TLB miss
  104. #ifdef CONFIG_HUGETLB_PAGE
  105. movl r18=PAGE_SHIFT
  106. MOV_FROM_ITIR(r25)
  107. #endif
  108. ;;
  109. RSM_PSR_DT // use physical addressing for data
  110. mov r31=pr // save the predicate registers
  111. mov r19=IA64_KR(PT_BASE) // get page table base address
  112. shl r21=r16,3 // shift bit 60 into sign bit
  113. shr.u r17=r16,61 // get the region number into r17
  114. ;;
  115. shr.u r22=r21,3
  116. #ifdef CONFIG_HUGETLB_PAGE
  117. extr.u r26=r25,2,6
  118. ;;
  119. cmp.ne p8,p0=r18,r26
  120. sub r27=r26,r18
  121. ;;
  122. (p8) dep r25=r18,r25,2,6
  123. (p8) shr r22=r22,r27
  124. #endif
  125. ;;
  126. cmp.eq p6,p7=5,r17 // is IFA pointing into to region 5?
  127. shr.u r18=r22,PGDIR_SHIFT // get bottom portion of pgd index bit
  128. ;;
  129. (p7) dep r17=r17,r19,(PAGE_SHIFT-3),3 // put region number bits in place
  130. srlz.d
  131. LOAD_PHYSICAL(p6, r19, swapper_pg_dir) // region 5 is rooted at swapper_pg_dir
  132. .pred.rel "mutex", p6, p7
  133. (p6) shr.u r21=r21,PGDIR_SHIFT+PAGE_SHIFT
  134. (p7) shr.u r21=r21,PGDIR_SHIFT+PAGE_SHIFT-3
  135. ;;
  136. (p6) dep r17=r18,r19,3,(PAGE_SHIFT-3) // r17=pgd_offset for region 5
  137. (p7) dep r17=r18,r17,3,(PAGE_SHIFT-6) // r17=pgd_offset for region[0-4]
  138. cmp.eq p7,p6=0,r21 // unused address bits all zeroes?
  139. #if CONFIG_PGTABLE_LEVELS == 4
  140. shr.u r28=r22,PUD_SHIFT // shift pud index into position
  141. #else
  142. shr.u r18=r22,PMD_SHIFT // shift pmd index into position
  143. #endif
  144. ;;
  145. ld8 r17=[r17] // get *pgd (may be 0)
  146. ;;
  147. (p7) cmp.eq p6,p7=r17,r0 // was pgd_present(*pgd) == NULL?
  148. #if CONFIG_PGTABLE_LEVELS == 4
  149. dep r28=r28,r17,3,(PAGE_SHIFT-3) // r28=pud_offset(pgd,addr)
  150. ;;
  151. shr.u r18=r22,PMD_SHIFT // shift pmd index into position
  152. (p7) ld8 r29=[r28] // get *pud (may be 0)
  153. ;;
  154. (p7) cmp.eq.or.andcm p6,p7=r29,r0 // was pud_present(*pud) == NULL?
  155. dep r17=r18,r29,3,(PAGE_SHIFT-3) // r17=pmd_offset(pud,addr)
  156. #else
  157. dep r17=r18,r17,3,(PAGE_SHIFT-3) // r17=pmd_offset(pgd,addr)
  158. #endif
  159. ;;
  160. (p7) ld8 r20=[r17] // get *pmd (may be 0)
  161. shr.u r19=r22,PAGE_SHIFT // shift pte index into position
  162. ;;
  163. (p7) cmp.eq.or.andcm p6,p7=r20,r0 // was pmd_present(*pmd) == NULL?
  164. dep r21=r19,r20,3,(PAGE_SHIFT-3) // r21=pte_offset(pmd,addr)
  165. ;;
  166. (p7) ld8 r18=[r21] // read *pte
  167. MOV_FROM_ISR(r19) // cr.isr bit 32 tells us if this is an insn miss
  168. ;;
  169. (p7) tbit.z p6,p7=r18,_PAGE_P_BIT // page present bit cleared?
  170. MOV_FROM_IHA(r22) // get the VHPT address that caused the TLB miss
  171. ;; // avoid RAW on p7
  172. (p7) tbit.nz.unc p10,p11=r19,32 // is it an instruction TLB miss?
  173. dep r23=0,r20,0,PAGE_SHIFT // clear low bits to get page address
  174. ;;
  175. ITC_I_AND_D(p10, p11, r18, r24) // insert the instruction TLB entry and
  176. // insert the data TLB entry
  177. (p6) br.cond.spnt.many page_fault // handle bad address/page not present (page fault)
  178. MOV_TO_IFA(r22, r24)
  179. #ifdef CONFIG_HUGETLB_PAGE
  180. MOV_TO_ITIR(p8, r25, r24) // change to default page-size for VHPT
  181. #endif
  182. /*
  183. * Now compute and insert the TLB entry for the virtual page table. We never
  184. * execute in a page table page so there is no need to set the exception deferral
  185. * bit.
  186. */
  187. adds r24=__DIRTY_BITS_NO_ED|_PAGE_PL_0|_PAGE_AR_RW,r23
  188. ;;
  189. ITC_D(p7, r24, r25)
  190. ;;
  191. #ifdef CONFIG_SMP
  192. /*
  193. * Tell the assemblers dependency-violation checker that the above "itc" instructions
  194. * cannot possibly affect the following loads:
  195. */
  196. dv_serialize_data
  197. /*
  198. * Re-check pagetable entry. If they changed, we may have received a ptc.g
  199. * between reading the pagetable and the "itc". If so, flush the entry we
  200. * inserted and retry. At this point, we have:
  201. *
  202. * r28 = equivalent of pud_offset(pgd, ifa)
  203. * r17 = equivalent of pmd_offset(pud, ifa)
  204. * r21 = equivalent of pte_offset(pmd, ifa)
  205. *
  206. * r29 = *pud
  207. * r20 = *pmd
  208. * r18 = *pte
  209. */
  210. ld8 r25=[r21] // read *pte again
  211. ld8 r26=[r17] // read *pmd again
  212. #if CONFIG_PGTABLE_LEVELS == 4
  213. ld8 r19=[r28] // read *pud again
  214. #endif
  215. cmp.ne p6,p7=r0,r0
  216. ;;
  217. cmp.ne.or.andcm p6,p7=r26,r20 // did *pmd change
  218. #if CONFIG_PGTABLE_LEVELS == 4
  219. cmp.ne.or.andcm p6,p7=r19,r29 // did *pud change
  220. #endif
  221. mov r27=PAGE_SHIFT<<2
  222. ;;
  223. (p6) ptc.l r22,r27 // purge PTE page translation
  224. (p7) cmp.ne.or.andcm p6,p7=r25,r18 // did *pte change
  225. ;;
  226. (p6) ptc.l r16,r27 // purge translation
  227. #endif
  228. mov pr=r31,-1 // restore predicate registers
  229. RFI
  230. END(vhpt_miss)
  231. .org ia64_ivt+0x400
  232. /////////////////////////////////////////////////////////////////////////////////////////
  233. // 0x0400 Entry 1 (size 64 bundles) ITLB (21)
  234. ENTRY(itlb_miss)
  235. DBG_FAULT(1)
  236. /*
  237. * The ITLB handler accesses the PTE via the virtually mapped linear
  238. * page table. If a nested TLB miss occurs, we switch into physical
  239. * mode, walk the page table, and then re-execute the PTE read and
  240. * go on normally after that.
  241. */
  242. MOV_FROM_IFA(r16) // get virtual address
  243. mov r29=b0 // save b0
  244. mov r31=pr // save predicates
  245. .itlb_fault:
  246. MOV_FROM_IHA(r17) // get virtual address of PTE
  247. movl r30=1f // load nested fault continuation point
  248. ;;
  249. 1: ld8 r18=[r17] // read *pte
  250. ;;
  251. mov b0=r29
  252. tbit.z p6,p0=r18,_PAGE_P_BIT // page present bit cleared?
  253. (p6) br.cond.spnt page_fault
  254. ;;
  255. ITC_I(p0, r18, r19)
  256. ;;
  257. #ifdef CONFIG_SMP
  258. /*
  259. * Tell the assemblers dependency-violation checker that the above "itc" instructions
  260. * cannot possibly affect the following loads:
  261. */
  262. dv_serialize_data
  263. ld8 r19=[r17] // read *pte again and see if same
  264. mov r20=PAGE_SHIFT<<2 // setup page size for purge
  265. ;;
  266. cmp.ne p7,p0=r18,r19
  267. ;;
  268. (p7) ptc.l r16,r20
  269. #endif
  270. mov pr=r31,-1
  271. RFI
  272. END(itlb_miss)
  273. .org ia64_ivt+0x0800
  274. /////////////////////////////////////////////////////////////////////////////////////////
  275. // 0x0800 Entry 2 (size 64 bundles) DTLB (9,48)
  276. ENTRY(dtlb_miss)
  277. DBG_FAULT(2)
  278. /*
  279. * The DTLB handler accesses the PTE via the virtually mapped linear
  280. * page table. If a nested TLB miss occurs, we switch into physical
  281. * mode, walk the page table, and then re-execute the PTE read and
  282. * go on normally after that.
  283. */
  284. MOV_FROM_IFA(r16) // get virtual address
  285. mov r29=b0 // save b0
  286. mov r31=pr // save predicates
  287. dtlb_fault:
  288. MOV_FROM_IHA(r17) // get virtual address of PTE
  289. movl r30=1f // load nested fault continuation point
  290. ;;
  291. 1: ld8 r18=[r17] // read *pte
  292. ;;
  293. mov b0=r29
  294. tbit.z p6,p0=r18,_PAGE_P_BIT // page present bit cleared?
  295. (p6) br.cond.spnt page_fault
  296. ;;
  297. ITC_D(p0, r18, r19)
  298. ;;
  299. #ifdef CONFIG_SMP
  300. /*
  301. * Tell the assemblers dependency-violation checker that the above "itc" instructions
  302. * cannot possibly affect the following loads:
  303. */
  304. dv_serialize_data
  305. ld8 r19=[r17] // read *pte again and see if same
  306. mov r20=PAGE_SHIFT<<2 // setup page size for purge
  307. ;;
  308. cmp.ne p7,p0=r18,r19
  309. ;;
  310. (p7) ptc.l r16,r20
  311. #endif
  312. mov pr=r31,-1
  313. RFI
  314. END(dtlb_miss)
  315. .org ia64_ivt+0x0c00
  316. /////////////////////////////////////////////////////////////////////////////////////////
  317. // 0x0c00 Entry 3 (size 64 bundles) Alt ITLB (19)
  318. ENTRY(alt_itlb_miss)
  319. DBG_FAULT(3)
  320. MOV_FROM_IFA(r16) // get address that caused the TLB miss
  321. movl r17=PAGE_KERNEL
  322. MOV_FROM_IPSR(p0, r21)
  323. movl r19=(((1 << IA64_MAX_PHYS_BITS) - 1) & ~0xfff)
  324. mov r31=pr
  325. ;;
  326. #ifdef CONFIG_DISABLE_VHPT
  327. shr.u r22=r16,61 // get the region number into r21
  328. ;;
  329. cmp.gt p8,p0=6,r22 // user mode
  330. ;;
  331. THASH(p8, r17, r16, r23)
  332. ;;
  333. MOV_TO_IHA(p8, r17, r23)
  334. (p8) mov r29=b0 // save b0
  335. (p8) br.cond.dptk .itlb_fault
  336. #endif
  337. extr.u r23=r21,IA64_PSR_CPL0_BIT,2 // extract psr.cpl
  338. and r19=r19,r16 // clear ed, reserved bits, and PTE control bits
  339. shr.u r18=r16,57 // move address bit 61 to bit 4
  340. ;;
  341. andcm r18=0x10,r18 // bit 4=~address-bit(61)
  342. cmp.ne p8,p0=r0,r23 // psr.cpl != 0?
  343. or r19=r17,r19 // insert PTE control bits into r19
  344. ;;
  345. or r19=r19,r18 // set bit 4 (uncached) if the access was to region 6
  346. (p8) br.cond.spnt page_fault
  347. ;;
  348. ITC_I(p0, r19, r18) // insert the TLB entry
  349. mov pr=r31,-1
  350. RFI
  351. END(alt_itlb_miss)
  352. .org ia64_ivt+0x1000
  353. /////////////////////////////////////////////////////////////////////////////////////////
  354. // 0x1000 Entry 4 (size 64 bundles) Alt DTLB (7,46)
  355. ENTRY(alt_dtlb_miss)
  356. DBG_FAULT(4)
  357. MOV_FROM_IFA(r16) // get address that caused the TLB miss
  358. movl r17=PAGE_KERNEL
  359. MOV_FROM_ISR(r20)
  360. movl r19=(((1 << IA64_MAX_PHYS_BITS) - 1) & ~0xfff)
  361. MOV_FROM_IPSR(p0, r21)
  362. mov r31=pr
  363. mov r24=PERCPU_ADDR
  364. ;;
  365. #ifdef CONFIG_DISABLE_VHPT
  366. shr.u r22=r16,61 // get the region number into r21
  367. ;;
  368. cmp.gt p8,p0=6,r22 // access to region 0-5
  369. ;;
  370. THASH(p8, r17, r16, r25)
  371. ;;
  372. MOV_TO_IHA(p8, r17, r25)
  373. (p8) mov r29=b0 // save b0
  374. (p8) br.cond.dptk dtlb_fault
  375. #endif
  376. cmp.ge p10,p11=r16,r24 // access to per_cpu_data?
  377. tbit.z p12,p0=r16,61 // access to region 6?
  378. mov r25=PERCPU_PAGE_SHIFT << 2
  379. mov r26=PERCPU_PAGE_SIZE
  380. nop.m 0
  381. nop.b 0
  382. ;;
  383. (p10) mov r19=IA64_KR(PER_CPU_DATA)
  384. (p11) and r19=r19,r16 // clear non-ppn fields
  385. extr.u r23=r21,IA64_PSR_CPL0_BIT,2 // extract psr.cpl
  386. and r22=IA64_ISR_CODE_MASK,r20 // get the isr.code field
  387. tbit.nz p6,p7=r20,IA64_ISR_SP_BIT // is speculation bit on?
  388. tbit.nz p9,p0=r20,IA64_ISR_NA_BIT // is non-access bit on?
  389. ;;
  390. (p10) sub r19=r19,r26
  391. MOV_TO_ITIR(p10, r25, r24)
  392. cmp.ne p8,p0=r0,r23
  393. (p9) cmp.eq.or.andcm p6,p7=IA64_ISR_CODE_LFETCH,r22 // check isr.code field
  394. (p12) dep r17=-1,r17,4,1 // set ma=UC for region 6 addr
  395. (p8) br.cond.spnt page_fault
  396. dep r21=-1,r21,IA64_PSR_ED_BIT,1
  397. ;;
  398. or r19=r19,r17 // insert PTE control bits into r19
  399. MOV_TO_IPSR(p6, r21, r24)
  400. ;;
  401. ITC_D(p7, r19, r18) // insert the TLB entry
  402. mov pr=r31,-1
  403. RFI
  404. END(alt_dtlb_miss)
  405. .org ia64_ivt+0x1400
  406. /////////////////////////////////////////////////////////////////////////////////////////
  407. // 0x1400 Entry 5 (size 64 bundles) Data nested TLB (6,45)
  408. ENTRY(nested_dtlb_miss)
  409. /*
  410. * In the absence of kernel bugs, we get here when the virtually mapped linear
  411. * page table is accessed non-speculatively (e.g., in the Dirty-bit, Instruction
  412. * Access-bit, or Data Access-bit faults). If the DTLB entry for the virtual page
  413. * table is missing, a nested TLB miss fault is triggered and control is
  414. * transferred to this point. When this happens, we lookup the pte for the
  415. * faulting address by walking the page table in physical mode and return to the
  416. * continuation point passed in register r30 (or call page_fault if the address is
  417. * not mapped).
  418. *
  419. * Input: r16: faulting address
  420. * r29: saved b0
  421. * r30: continuation address
  422. * r31: saved pr
  423. *
  424. * Output: r17: physical address of PTE of faulting address
  425. * r29: saved b0
  426. * r30: continuation address
  427. * r31: saved pr
  428. *
  429. * Clobbered: b0, r18, r19, r21, r22, psr.dt (cleared)
  430. */
  431. RSM_PSR_DT // switch to using physical data addressing
  432. mov r19=IA64_KR(PT_BASE) // get the page table base address
  433. shl r21=r16,3 // shift bit 60 into sign bit
  434. MOV_FROM_ITIR(r18)
  435. ;;
  436. shr.u r17=r16,61 // get the region number into r17
  437. extr.u r18=r18,2,6 // get the faulting page size
  438. ;;
  439. cmp.eq p6,p7=5,r17 // is faulting address in region 5?
  440. add r22=-PAGE_SHIFT,r18 // adjustment for hugetlb address
  441. add r18=PGDIR_SHIFT-PAGE_SHIFT,r18
  442. ;;
  443. shr.u r22=r16,r22
  444. shr.u r18=r16,r18
  445. (p7) dep r17=r17,r19,(PAGE_SHIFT-3),3 // put region number bits in place
  446. srlz.d
  447. LOAD_PHYSICAL(p6, r19, swapper_pg_dir) // region 5 is rooted at swapper_pg_dir
  448. .pred.rel "mutex", p6, p7
  449. (p6) shr.u r21=r21,PGDIR_SHIFT+PAGE_SHIFT
  450. (p7) shr.u r21=r21,PGDIR_SHIFT+PAGE_SHIFT-3
  451. ;;
  452. (p6) dep r17=r18,r19,3,(PAGE_SHIFT-3) // r17=pgd_offset for region 5
  453. (p7) dep r17=r18,r17,3,(PAGE_SHIFT-6) // r17=pgd_offset for region[0-4]
  454. cmp.eq p7,p6=0,r21 // unused address bits all zeroes?
  455. #if CONFIG_PGTABLE_LEVELS == 4
  456. shr.u r18=r22,PUD_SHIFT // shift pud index into position
  457. #else
  458. shr.u r18=r22,PMD_SHIFT // shift pmd index into position
  459. #endif
  460. ;;
  461. ld8 r17=[r17] // get *pgd (may be 0)
  462. ;;
  463. (p7) cmp.eq p6,p7=r17,r0 // was pgd_present(*pgd) == NULL?
  464. dep r17=r18,r17,3,(PAGE_SHIFT-3) // r17=p[u|m]d_offset(pgd,addr)
  465. ;;
  466. #if CONFIG_PGTABLE_LEVELS == 4
  467. (p7) ld8 r17=[r17] // get *pud (may be 0)
  468. shr.u r18=r22,PMD_SHIFT // shift pmd index into position
  469. ;;
  470. (p7) cmp.eq.or.andcm p6,p7=r17,r0 // was pud_present(*pud) == NULL?
  471. dep r17=r18,r17,3,(PAGE_SHIFT-3) // r17=pmd_offset(pud,addr)
  472. ;;
  473. #endif
  474. (p7) ld8 r17=[r17] // get *pmd (may be 0)
  475. shr.u r19=r22,PAGE_SHIFT // shift pte index into position
  476. ;;
  477. (p7) cmp.eq.or.andcm p6,p7=r17,r0 // was pmd_present(*pmd) == NULL?
  478. dep r17=r19,r17,3,(PAGE_SHIFT-3) // r17=pte_offset(pmd,addr);
  479. (p6) br.cond.spnt page_fault
  480. mov b0=r30
  481. br.sptk.many b0 // return to continuation point
  482. END(nested_dtlb_miss)
  483. .org ia64_ivt+0x1800
  484. /////////////////////////////////////////////////////////////////////////////////////////
  485. // 0x1800 Entry 6 (size 64 bundles) Instruction Key Miss (24)
  486. ENTRY(ikey_miss)
  487. DBG_FAULT(6)
  488. FAULT(6)
  489. END(ikey_miss)
  490. .org ia64_ivt+0x1c00
  491. /////////////////////////////////////////////////////////////////////////////////////////
  492. // 0x1c00 Entry 7 (size 64 bundles) Data Key Miss (12,51)
  493. ENTRY(dkey_miss)
  494. DBG_FAULT(7)
  495. FAULT(7)
  496. END(dkey_miss)
  497. .org ia64_ivt+0x2000
  498. /////////////////////////////////////////////////////////////////////////////////////////
  499. // 0x2000 Entry 8 (size 64 bundles) Dirty-bit (54)
  500. ENTRY(dirty_bit)
  501. DBG_FAULT(8)
  502. /*
  503. * What we do here is to simply turn on the dirty bit in the PTE. We need to
  504. * update both the page-table and the TLB entry. To efficiently access the PTE,
  505. * we address it through the virtual page table. Most likely, the TLB entry for
  506. * the relevant virtual page table page is still present in the TLB so we can
  507. * normally do this without additional TLB misses. In case the necessary virtual
  508. * page table TLB entry isn't present, we take a nested TLB miss hit where we look
  509. * up the physical address of the L3 PTE and then continue at label 1 below.
  510. */
  511. MOV_FROM_IFA(r16) // get the address that caused the fault
  512. movl r30=1f // load continuation point in case of nested fault
  513. ;;
  514. THASH(p0, r17, r16, r18) // compute virtual address of L3 PTE
  515. mov r29=b0 // save b0 in case of nested fault
  516. mov r31=pr // save pr
  517. #ifdef CONFIG_SMP
  518. mov r28=ar.ccv // save ar.ccv
  519. ;;
  520. 1: ld8 r18=[r17]
  521. ;; // avoid RAW on r18
  522. mov ar.ccv=r18 // set compare value for cmpxchg
  523. or r25=_PAGE_D|_PAGE_A,r18 // set the dirty and accessed bits
  524. tbit.z p7,p6 = r18,_PAGE_P_BIT // Check present bit
  525. ;;
  526. (p6) cmpxchg8.acq r26=[r17],r25,ar.ccv // Only update if page is present
  527. mov r24=PAGE_SHIFT<<2
  528. ;;
  529. (p6) cmp.eq p6,p7=r26,r18 // Only compare if page is present
  530. ;;
  531. ITC_D(p6, r25, r18) // install updated PTE
  532. ;;
  533. /*
  534. * Tell the assemblers dependency-violation checker that the above "itc" instructions
  535. * cannot possibly affect the following loads:
  536. */
  537. dv_serialize_data
  538. ld8 r18=[r17] // read PTE again
  539. ;;
  540. cmp.eq p6,p7=r18,r25 // is it same as the newly installed
  541. ;;
  542. (p7) ptc.l r16,r24
  543. mov b0=r29 // restore b0
  544. mov ar.ccv=r28
  545. #else
  546. ;;
  547. 1: ld8 r18=[r17]
  548. ;; // avoid RAW on r18
  549. or r18=_PAGE_D|_PAGE_A,r18 // set the dirty and accessed bits
  550. mov b0=r29 // restore b0
  551. ;;
  552. st8 [r17]=r18 // store back updated PTE
  553. ITC_D(p0, r18, r16) // install updated PTE
  554. #endif
  555. mov pr=r31,-1 // restore pr
  556. RFI
  557. END(dirty_bit)
  558. .org ia64_ivt+0x2400
  559. /////////////////////////////////////////////////////////////////////////////////////////
  560. // 0x2400 Entry 9 (size 64 bundles) Instruction Access-bit (27)
  561. ENTRY(iaccess_bit)
  562. DBG_FAULT(9)
  563. // Like Entry 8, except for instruction access
  564. MOV_FROM_IFA(r16) // get the address that caused the fault
  565. movl r30=1f // load continuation point in case of nested fault
  566. mov r31=pr // save predicates
  567. #ifdef CONFIG_ITANIUM
  568. /*
  569. * Erratum 10 (IFA may contain incorrect address) has "NoFix" status.
  570. */
  571. MOV_FROM_IPSR(p0, r17)
  572. ;;
  573. MOV_FROM_IIP(r18)
  574. tbit.z p6,p0=r17,IA64_PSR_IS_BIT // IA64 instruction set?
  575. ;;
  576. (p6) mov r16=r18 // if so, use cr.iip instead of cr.ifa
  577. #endif /* CONFIG_ITANIUM */
  578. ;;
  579. THASH(p0, r17, r16, r18) // compute virtual address of L3 PTE
  580. mov r29=b0 // save b0 in case of nested fault)
  581. #ifdef CONFIG_SMP
  582. mov r28=ar.ccv // save ar.ccv
  583. ;;
  584. 1: ld8 r18=[r17]
  585. ;;
  586. mov ar.ccv=r18 // set compare value for cmpxchg
  587. or r25=_PAGE_A,r18 // set the accessed bit
  588. tbit.z p7,p6 = r18,_PAGE_P_BIT // Check present bit
  589. ;;
  590. (p6) cmpxchg8.acq r26=[r17],r25,ar.ccv // Only if page present
  591. mov r24=PAGE_SHIFT<<2
  592. ;;
  593. (p6) cmp.eq p6,p7=r26,r18 // Only if page present
  594. ;;
  595. ITC_I(p6, r25, r26) // install updated PTE
  596. ;;
  597. /*
  598. * Tell the assemblers dependency-violation checker that the above "itc" instructions
  599. * cannot possibly affect the following loads:
  600. */
  601. dv_serialize_data
  602. ld8 r18=[r17] // read PTE again
  603. ;;
  604. cmp.eq p6,p7=r18,r25 // is it same as the newly installed
  605. ;;
  606. (p7) ptc.l r16,r24
  607. mov b0=r29 // restore b0
  608. mov ar.ccv=r28
  609. #else /* !CONFIG_SMP */
  610. ;;
  611. 1: ld8 r18=[r17]
  612. ;;
  613. or r18=_PAGE_A,r18 // set the accessed bit
  614. mov b0=r29 // restore b0
  615. ;;
  616. st8 [r17]=r18 // store back updated PTE
  617. ITC_I(p0, r18, r16) // install updated PTE
  618. #endif /* !CONFIG_SMP */
  619. mov pr=r31,-1
  620. RFI
  621. END(iaccess_bit)
  622. .org ia64_ivt+0x2800
  623. /////////////////////////////////////////////////////////////////////////////////////////
  624. // 0x2800 Entry 10 (size 64 bundles) Data Access-bit (15,55)
  625. ENTRY(daccess_bit)
  626. DBG_FAULT(10)
  627. // Like Entry 8, except for data access
  628. MOV_FROM_IFA(r16) // get the address that caused the fault
  629. movl r30=1f // load continuation point in case of nested fault
  630. ;;
  631. THASH(p0, r17, r16, r18) // compute virtual address of L3 PTE
  632. mov r31=pr
  633. mov r29=b0 // save b0 in case of nested fault)
  634. #ifdef CONFIG_SMP
  635. mov r28=ar.ccv // save ar.ccv
  636. ;;
  637. 1: ld8 r18=[r17]
  638. ;; // avoid RAW on r18
  639. mov ar.ccv=r18 // set compare value for cmpxchg
  640. or r25=_PAGE_A,r18 // set the dirty bit
  641. tbit.z p7,p6 = r18,_PAGE_P_BIT // Check present bit
  642. ;;
  643. (p6) cmpxchg8.acq r26=[r17],r25,ar.ccv // Only if page is present
  644. mov r24=PAGE_SHIFT<<2
  645. ;;
  646. (p6) cmp.eq p6,p7=r26,r18 // Only if page is present
  647. ;;
  648. ITC_D(p6, r25, r26) // install updated PTE
  649. /*
  650. * Tell the assemblers dependency-violation checker that the above "itc" instructions
  651. * cannot possibly affect the following loads:
  652. */
  653. dv_serialize_data
  654. ;;
  655. ld8 r18=[r17] // read PTE again
  656. ;;
  657. cmp.eq p6,p7=r18,r25 // is it same as the newly installed
  658. ;;
  659. (p7) ptc.l r16,r24
  660. mov ar.ccv=r28
  661. #else
  662. ;;
  663. 1: ld8 r18=[r17]
  664. ;; // avoid RAW on r18
  665. or r18=_PAGE_A,r18 // set the accessed bit
  666. ;;
  667. st8 [r17]=r18 // store back updated PTE
  668. ITC_D(p0, r18, r16) // install updated PTE
  669. #endif
  670. mov b0=r29 // restore b0
  671. mov pr=r31,-1
  672. RFI
  673. END(daccess_bit)
  674. .org ia64_ivt+0x2c00
  675. /////////////////////////////////////////////////////////////////////////////////////////
  676. // 0x2c00 Entry 11 (size 64 bundles) Break instruction (33)
  677. ENTRY(break_fault)
  678. /*
  679. * The streamlined system call entry/exit paths only save/restore the initial part
  680. * of pt_regs. This implies that the callers of system-calls must adhere to the
  681. * normal procedure calling conventions.
  682. *
  683. * Registers to be saved & restored:
  684. * CR registers: cr.ipsr, cr.iip, cr.ifs
  685. * AR registers: ar.unat, ar.pfs, ar.rsc, ar.rnat, ar.bspstore, ar.fpsr
  686. * others: pr, b0, b6, loadrs, r1, r11, r12, r13, r15
  687. * Registers to be restored only:
  688. * r8-r11: output value from the system call.
  689. *
  690. * During system call exit, scratch registers (including r15) are modified/cleared
  691. * to prevent leaking bits from kernel to user level.
  692. */
  693. DBG_FAULT(11)
  694. mov.m r16=IA64_KR(CURRENT) // M2 r16 <- current task (12 cyc)
  695. MOV_FROM_IPSR(p0, r29) // M2 (12 cyc)
  696. mov r31=pr // I0 (2 cyc)
  697. MOV_FROM_IIM(r17) // M2 (2 cyc)
  698. mov.m r27=ar.rsc // M2 (12 cyc)
  699. mov r18=__IA64_BREAK_SYSCALL // A
  700. mov.m ar.rsc=0 // M2
  701. mov.m r21=ar.fpsr // M2 (12 cyc)
  702. mov r19=b6 // I0 (2 cyc)
  703. ;;
  704. mov.m r23=ar.bspstore // M2 (12 cyc)
  705. mov.m r24=ar.rnat // M2 (5 cyc)
  706. mov.i r26=ar.pfs // I0 (2 cyc)
  707. invala // M0|1
  708. nop.m 0 // M
  709. mov r20=r1 // A save r1
  710. nop.m 0
  711. movl r30=sys_call_table // X
  712. MOV_FROM_IIP(r28) // M2 (2 cyc)
  713. cmp.eq p0,p7=r18,r17 // I0 is this a system call?
  714. (p7) br.cond.spnt non_syscall // B no ->
  715. //
  716. // From this point on, we are definitely on the syscall-path
  717. // and we can use (non-banked) scratch registers.
  718. //
  719. ///////////////////////////////////////////////////////////////////////
  720. mov r1=r16 // A move task-pointer to "addl"-addressable reg
  721. mov r2=r16 // A setup r2 for ia64_syscall_setup
  722. add r9=TI_FLAGS+IA64_TASK_SIZE,r16 // A r9 = &current_thread_info()->flags
  723. adds r16=IA64_TASK_THREAD_ON_USTACK_OFFSET,r16
  724. adds r15=-1024,r15 // A subtract 1024 from syscall number
  725. mov r3=NR_syscalls - 1
  726. ;;
  727. ld1.bias r17=[r16] // M0|1 r17 = current->thread.on_ustack flag
  728. ld4 r9=[r9] // M0|1 r9 = current_thread_info()->flags
  729. extr.u r8=r29,41,2 // I0 extract ei field from cr.ipsr
  730. shladd r30=r15,3,r30 // A r30 = sys_call_table + 8*(syscall-1024)
  731. addl r22=IA64_RBS_OFFSET,r1 // A compute base of RBS
  732. cmp.leu p6,p7=r15,r3 // A syscall number in range?
  733. ;;
  734. lfetch.fault.excl.nt1 [r22] // M0|1 prefetch RBS
  735. (p6) ld8 r30=[r30] // M0|1 load address of syscall entry point
  736. tnat.nz.or p7,p0=r15 // I0 is syscall nr a NaT?
  737. mov.m ar.bspstore=r22 // M2 switch to kernel RBS
  738. cmp.eq p8,p9=2,r8 // A isr.ei==2?
  739. ;;
  740. (p8) mov r8=0 // A clear ei to 0
  741. (p7) movl r30=sys_ni_syscall // X
  742. (p8) adds r28=16,r28 // A switch cr.iip to next bundle
  743. (p9) adds r8=1,r8 // A increment ei to next slot
  744. #ifdef CONFIG_VIRT_CPU_ACCOUNTING_NATIVE
  745. ;;
  746. mov b6=r30 // I0 setup syscall handler branch reg early
  747. #else
  748. nop.i 0
  749. ;;
  750. #endif
  751. mov.m r25=ar.unat // M2 (5 cyc)
  752. dep r29=r8,r29,41,2 // I0 insert new ei into cr.ipsr
  753. adds r15=1024,r15 // A restore original syscall number
  754. //
  755. // If any of the above loads miss in L1D, we'll stall here until
  756. // the data arrives.
  757. //
  758. ///////////////////////////////////////////////////////////////////////
  759. st1 [r16]=r0 // M2|3 clear current->thread.on_ustack flag
  760. #ifdef CONFIG_VIRT_CPU_ACCOUNTING_NATIVE
  761. MOV_FROM_ITC(p0, p14, r30, r18) // M get cycle for accounting
  762. #else
  763. mov b6=r30 // I0 setup syscall handler branch reg early
  764. #endif
  765. cmp.eq pKStk,pUStk=r0,r17 // A were we on kernel stacks already?
  766. and r9=_TIF_SYSCALL_TRACEAUDIT,r9 // A mask trace or audit
  767. mov r18=ar.bsp // M2 (12 cyc)
  768. (pKStk) br.cond.spnt .break_fixup // B we're already in kernel-mode -- fix up RBS
  769. ;;
  770. .back_from_break_fixup:
  771. (pUStk) addl r1=IA64_STK_OFFSET-IA64_PT_REGS_SIZE,r1 // A compute base of memory stack
  772. cmp.eq p14,p0=r9,r0 // A are syscalls being traced/audited?
  773. br.call.sptk.many b7=ia64_syscall_setup // B
  774. 1:
  775. #ifdef CONFIG_VIRT_CPU_ACCOUNTING_NATIVE
  776. // mov.m r30=ar.itc is called in advance, and r13 is current
  777. add r16=TI_AC_STAMP+IA64_TASK_SIZE,r13 // A
  778. add r17=TI_AC_LEAVE+IA64_TASK_SIZE,r13 // A
  779. (pKStk) br.cond.spnt .skip_accounting // B unlikely skip
  780. ;;
  781. ld8 r18=[r16],TI_AC_STIME-TI_AC_STAMP // M get last stamp
  782. ld8 r19=[r17],TI_AC_UTIME-TI_AC_LEAVE // M time at leave
  783. ;;
  784. ld8 r20=[r16],TI_AC_STAMP-TI_AC_STIME // M cumulated stime
  785. ld8 r21=[r17] // M cumulated utime
  786. sub r22=r19,r18 // A stime before leave
  787. ;;
  788. st8 [r16]=r30,TI_AC_STIME-TI_AC_STAMP // M update stamp
  789. sub r18=r30,r19 // A elapsed time in user
  790. ;;
  791. add r20=r20,r22 // A sum stime
  792. add r21=r21,r18 // A sum utime
  793. ;;
  794. st8 [r16]=r20 // M update stime
  795. st8 [r17]=r21 // M update utime
  796. ;;
  797. .skip_accounting:
  798. #endif
  799. mov ar.rsc=0x3 // M2 set eager mode, pl 0, LE, loadrs=0
  800. nop 0
  801. BSW_1(r2, r14) // B (6 cyc) regs are saved, switch to bank 1
  802. ;;
  803. SSM_PSR_IC_AND_DEFAULT_BITS_AND_SRLZ_I(r3, r16) // M2 now it's safe to re-enable intr.-collection
  804. // M0 ensure interruption collection is on
  805. movl r3=ia64_ret_from_syscall // X
  806. ;;
  807. mov rp=r3 // I0 set the real return addr
  808. (p10) br.cond.spnt.many ia64_ret_from_syscall // B return if bad call-frame or r15 is a NaT
  809. SSM_PSR_I(p15, p15, r16) // M2 restore psr.i
  810. (p14) br.call.sptk.many b6=b6 // B invoke syscall-handker (ignore return addr)
  811. br.cond.spnt.many ia64_trace_syscall // B do syscall-tracing thingamagic
  812. // NOT REACHED
  813. ///////////////////////////////////////////////////////////////////////
  814. // On entry, we optimistically assumed that we're coming from user-space.
  815. // For the rare cases where a system-call is done from within the kernel,
  816. // we fix things up at this point:
  817. .break_fixup:
  818. add r1=-IA64_PT_REGS_SIZE,sp // A allocate space for pt_regs structure
  819. mov ar.rnat=r24 // M2 restore kernel's AR.RNAT
  820. ;;
  821. mov ar.bspstore=r23 // M2 restore kernel's AR.BSPSTORE
  822. br.cond.sptk .back_from_break_fixup
  823. END(break_fault)
  824. .org ia64_ivt+0x3000
  825. /////////////////////////////////////////////////////////////////////////////////////////
  826. // 0x3000 Entry 12 (size 64 bundles) External Interrupt (4)
  827. ENTRY(interrupt)
  828. /* interrupt handler has become too big to fit this area. */
  829. br.sptk.many __interrupt
  830. END(interrupt)
  831. .org ia64_ivt+0x3400
  832. /////////////////////////////////////////////////////////////////////////////////////////
  833. // 0x3400 Entry 13 (size 64 bundles) Reserved
  834. DBG_FAULT(13)
  835. FAULT(13)
  836. .org ia64_ivt+0x3800
  837. /////////////////////////////////////////////////////////////////////////////////////////
  838. // 0x3800 Entry 14 (size 64 bundles) Reserved
  839. DBG_FAULT(14)
  840. FAULT(14)
  841. /*
  842. * There is no particular reason for this code to be here, other than that
  843. * there happens to be space here that would go unused otherwise. If this
  844. * fault ever gets "unreserved", simply moved the following code to a more
  845. * suitable spot...
  846. *
  847. * ia64_syscall_setup() is a separate subroutine so that it can
  848. * allocate stacked registers so it can safely demine any
  849. * potential NaT values from the input registers.
  850. *
  851. * On entry:
  852. * - executing on bank 0 or bank 1 register set (doesn't matter)
  853. * - r1: stack pointer
  854. * - r2: current task pointer
  855. * - r3: preserved
  856. * - r11: original contents (saved ar.pfs to be saved)
  857. * - r12: original contents (sp to be saved)
  858. * - r13: original contents (tp to be saved)
  859. * - r15: original contents (syscall # to be saved)
  860. * - r18: saved bsp (after switching to kernel stack)
  861. * - r19: saved b6
  862. * - r20: saved r1 (gp)
  863. * - r21: saved ar.fpsr
  864. * - r22: kernel's register backing store base (krbs_base)
  865. * - r23: saved ar.bspstore
  866. * - r24: saved ar.rnat
  867. * - r25: saved ar.unat
  868. * - r26: saved ar.pfs
  869. * - r27: saved ar.rsc
  870. * - r28: saved cr.iip
  871. * - r29: saved cr.ipsr
  872. * - r30: ar.itc for accounting (don't touch)
  873. * - r31: saved pr
  874. * - b0: original contents (to be saved)
  875. * On exit:
  876. * - p10: TRUE if syscall is invoked with more than 8 out
  877. * registers or r15's Nat is true
  878. * - r1: kernel's gp
  879. * - r3: preserved (same as on entry)
  880. * - r8: -EINVAL if p10 is true
  881. * - r12: points to kernel stack
  882. * - r13: points to current task
  883. * - r14: preserved (same as on entry)
  884. * - p13: preserved
  885. * - p15: TRUE if interrupts need to be re-enabled
  886. * - ar.fpsr: set to kernel settings
  887. * - b6: preserved (same as on entry)
  888. */
  889. GLOBAL_ENTRY(ia64_syscall_setup)
  890. #if PT(B6) != 0
  891. # error This code assumes that b6 is the first field in pt_regs.
  892. #endif
  893. st8 [r1]=r19 // save b6
  894. add r16=PT(CR_IPSR),r1 // initialize first base pointer
  895. add r17=PT(R11),r1 // initialize second base pointer
  896. ;;
  897. alloc r19=ar.pfs,8,0,0,0 // ensure in0-in7 are writable
  898. st8 [r16]=r29,PT(AR_PFS)-PT(CR_IPSR) // save cr.ipsr
  899. tnat.nz p8,p0=in0
  900. st8.spill [r17]=r11,PT(CR_IIP)-PT(R11) // save r11
  901. tnat.nz p9,p0=in1
  902. (pKStk) mov r18=r0 // make sure r18 isn't NaT
  903. ;;
  904. st8 [r16]=r26,PT(CR_IFS)-PT(AR_PFS) // save ar.pfs
  905. st8 [r17]=r28,PT(AR_UNAT)-PT(CR_IIP) // save cr.iip
  906. mov r28=b0 // save b0 (2 cyc)
  907. ;;
  908. st8 [r17]=r25,PT(AR_RSC)-PT(AR_UNAT) // save ar.unat
  909. dep r19=0,r19,38,26 // clear all bits but 0..37 [I0]
  910. (p8) mov in0=-1
  911. ;;
  912. st8 [r16]=r19,PT(AR_RNAT)-PT(CR_IFS) // store ar.pfs.pfm in cr.ifs
  913. extr.u r11=r19,7,7 // I0 // get sol of ar.pfs
  914. and r8=0x7f,r19 // A // get sof of ar.pfs
  915. st8 [r17]=r27,PT(AR_BSPSTORE)-PT(AR_RSC)// save ar.rsc
  916. tbit.nz p15,p0=r29,IA64_PSR_I_BIT // I0
  917. (p9) mov in1=-1
  918. ;;
  919. (pUStk) sub r18=r18,r22 // r18=RSE.ndirty*8
  920. tnat.nz p10,p0=in2
  921. add r11=8,r11
  922. ;;
  923. (pKStk) adds r16=PT(PR)-PT(AR_RNAT),r16 // skip over ar_rnat field
  924. (pKStk) adds r17=PT(B0)-PT(AR_BSPSTORE),r17 // skip over ar_bspstore field
  925. tnat.nz p11,p0=in3
  926. ;;
  927. (p10) mov in2=-1
  928. tnat.nz p12,p0=in4 // [I0]
  929. (p11) mov in3=-1
  930. ;;
  931. (pUStk) st8 [r16]=r24,PT(PR)-PT(AR_RNAT) // save ar.rnat
  932. (pUStk) st8 [r17]=r23,PT(B0)-PT(AR_BSPSTORE) // save ar.bspstore
  933. shl r18=r18,16 // compute ar.rsc to be used for "loadrs"
  934. ;;
  935. st8 [r16]=r31,PT(LOADRS)-PT(PR) // save predicates
  936. st8 [r17]=r28,PT(R1)-PT(B0) // save b0
  937. tnat.nz p13,p0=in5 // [I0]
  938. ;;
  939. st8 [r16]=r18,PT(R12)-PT(LOADRS) // save ar.rsc value for "loadrs"
  940. st8.spill [r17]=r20,PT(R13)-PT(R1) // save original r1
  941. (p12) mov in4=-1
  942. ;;
  943. .mem.offset 0,0; st8.spill [r16]=r12,PT(AR_FPSR)-PT(R12) // save r12
  944. .mem.offset 8,0; st8.spill [r17]=r13,PT(R15)-PT(R13) // save r13
  945. (p13) mov in5=-1
  946. ;;
  947. st8 [r16]=r21,PT(R8)-PT(AR_FPSR) // save ar.fpsr
  948. tnat.nz p13,p0=in6
  949. cmp.lt p10,p9=r11,r8 // frame size can't be more than local+8
  950. ;;
  951. mov r8=1
  952. (p9) tnat.nz p10,p0=r15
  953. adds r12=-16,r1 // switch to kernel memory stack (with 16 bytes of scratch)
  954. st8.spill [r17]=r15 // save r15
  955. tnat.nz p8,p0=in7
  956. nop.i 0
  957. mov r13=r2 // establish `current'
  958. movl r1=__gp // establish kernel global pointer
  959. ;;
  960. st8 [r16]=r8 // ensure pt_regs.r8 != 0 (see handle_syscall_error)
  961. (p13) mov in6=-1
  962. (p8) mov in7=-1
  963. cmp.eq pSys,pNonSys=r0,r0 // set pSys=1, pNonSys=0
  964. movl r17=FPSR_DEFAULT
  965. ;;
  966. mov.m ar.fpsr=r17 // set ar.fpsr to kernel default value
  967. (p10) mov r8=-EINVAL
  968. br.ret.sptk.many b7
  969. END(ia64_syscall_setup)
  970. .org ia64_ivt+0x3c00
  971. /////////////////////////////////////////////////////////////////////////////////////////
  972. // 0x3c00 Entry 15 (size 64 bundles) Reserved
  973. DBG_FAULT(15)
  974. FAULT(15)
  975. .org ia64_ivt+0x4000
  976. /////////////////////////////////////////////////////////////////////////////////////////
  977. // 0x4000 Entry 16 (size 64 bundles) Reserved
  978. DBG_FAULT(16)
  979. FAULT(16)
  980. #if defined(CONFIG_VIRT_CPU_ACCOUNTING_NATIVE)
  981. /*
  982. * There is no particular reason for this code to be here, other than
  983. * that there happens to be space here that would go unused otherwise.
  984. * If this fault ever gets "unreserved", simply moved the following
  985. * code to a more suitable spot...
  986. *
  987. * account_sys_enter is called from SAVE_MIN* macros if accounting is
  988. * enabled and if the macro is entered from user mode.
  989. */
  990. GLOBAL_ENTRY(account_sys_enter)
  991. // mov.m r20=ar.itc is called in advance, and r13 is current
  992. add r16=TI_AC_STAMP+IA64_TASK_SIZE,r13
  993. add r17=TI_AC_LEAVE+IA64_TASK_SIZE,r13
  994. ;;
  995. ld8 r18=[r16],TI_AC_STIME-TI_AC_STAMP // time at last check in kernel
  996. ld8 r19=[r17],TI_AC_UTIME-TI_AC_LEAVE // time at left from kernel
  997. ;;
  998. ld8 r23=[r16],TI_AC_STAMP-TI_AC_STIME // cumulated stime
  999. ld8 r21=[r17] // cumulated utime
  1000. sub r22=r19,r18 // stime before leave kernel
  1001. ;;
  1002. st8 [r16]=r20,TI_AC_STIME-TI_AC_STAMP // update stamp
  1003. sub r18=r20,r19 // elapsed time in user mode
  1004. ;;
  1005. add r23=r23,r22 // sum stime
  1006. add r21=r21,r18 // sum utime
  1007. ;;
  1008. st8 [r16]=r23 // update stime
  1009. st8 [r17]=r21 // update utime
  1010. ;;
  1011. br.ret.sptk.many rp
  1012. END(account_sys_enter)
  1013. #endif
  1014. .org ia64_ivt+0x4400
  1015. /////////////////////////////////////////////////////////////////////////////////////////
  1016. // 0x4400 Entry 17 (size 64 bundles) Reserved
  1017. DBG_FAULT(17)
  1018. FAULT(17)
  1019. .org ia64_ivt+0x4800
  1020. /////////////////////////////////////////////////////////////////////////////////////////
  1021. // 0x4800 Entry 18 (size 64 bundles) Reserved
  1022. DBG_FAULT(18)
  1023. FAULT(18)
  1024. .org ia64_ivt+0x4c00
  1025. /////////////////////////////////////////////////////////////////////////////////////////
  1026. // 0x4c00 Entry 19 (size 64 bundles) Reserved
  1027. DBG_FAULT(19)
  1028. FAULT(19)
  1029. //
  1030. // --- End of long entries, Beginning of short entries
  1031. //
  1032. .org ia64_ivt+0x5000
  1033. /////////////////////////////////////////////////////////////////////////////////////////
  1034. // 0x5000 Entry 20 (size 16 bundles) Page Not Present (10,22,49)
  1035. ENTRY(page_not_present)
  1036. DBG_FAULT(20)
  1037. MOV_FROM_IFA(r16)
  1038. RSM_PSR_DT
  1039. /*
  1040. * The Linux page fault handler doesn't expect non-present pages to be in
  1041. * the TLB. Flush the existing entry now, so we meet that expectation.
  1042. */
  1043. mov r17=PAGE_SHIFT<<2
  1044. ;;
  1045. ptc.l r16,r17
  1046. ;;
  1047. mov r31=pr
  1048. srlz.d
  1049. br.sptk.many page_fault
  1050. END(page_not_present)
  1051. .org ia64_ivt+0x5100
  1052. /////////////////////////////////////////////////////////////////////////////////////////
  1053. // 0x5100 Entry 21 (size 16 bundles) Key Permission (13,25,52)
  1054. ENTRY(key_permission)
  1055. DBG_FAULT(21)
  1056. MOV_FROM_IFA(r16)
  1057. RSM_PSR_DT
  1058. mov r31=pr
  1059. ;;
  1060. srlz.d
  1061. br.sptk.many page_fault
  1062. END(key_permission)
  1063. .org ia64_ivt+0x5200
  1064. /////////////////////////////////////////////////////////////////////////////////////////
  1065. // 0x5200 Entry 22 (size 16 bundles) Instruction Access Rights (26)
  1066. ENTRY(iaccess_rights)
  1067. DBG_FAULT(22)
  1068. MOV_FROM_IFA(r16)
  1069. RSM_PSR_DT
  1070. mov r31=pr
  1071. ;;
  1072. srlz.d
  1073. br.sptk.many page_fault
  1074. END(iaccess_rights)
  1075. .org ia64_ivt+0x5300
  1076. /////////////////////////////////////////////////////////////////////////////////////////
  1077. // 0x5300 Entry 23 (size 16 bundles) Data Access Rights (14,53)
  1078. ENTRY(daccess_rights)
  1079. DBG_FAULT(23)
  1080. MOV_FROM_IFA(r16)
  1081. RSM_PSR_DT
  1082. mov r31=pr
  1083. ;;
  1084. srlz.d
  1085. br.sptk.many page_fault
  1086. END(daccess_rights)
  1087. .org ia64_ivt+0x5400
  1088. /////////////////////////////////////////////////////////////////////////////////////////
  1089. // 0x5400 Entry 24 (size 16 bundles) General Exception (5,32,34,36,38,39)
  1090. ENTRY(general_exception)
  1091. DBG_FAULT(24)
  1092. MOV_FROM_ISR(r16)
  1093. mov r31=pr
  1094. ;;
  1095. cmp4.eq p6,p0=0,r16
  1096. (p6) br.sptk.many dispatch_illegal_op_fault
  1097. ;;
  1098. mov r19=24 // fault number
  1099. br.sptk.many dispatch_to_fault_handler
  1100. END(general_exception)
  1101. .org ia64_ivt+0x5500
  1102. /////////////////////////////////////////////////////////////////////////////////////////
  1103. // 0x5500 Entry 25 (size 16 bundles) Disabled FP-Register (35)
  1104. ENTRY(disabled_fp_reg)
  1105. DBG_FAULT(25)
  1106. rsm psr.dfh // ensure we can access fph
  1107. ;;
  1108. srlz.d
  1109. mov r31=pr
  1110. mov r19=25
  1111. br.sptk.many dispatch_to_fault_handler
  1112. END(disabled_fp_reg)
  1113. .org ia64_ivt+0x5600
  1114. /////////////////////////////////////////////////////////////////////////////////////////
  1115. // 0x5600 Entry 26 (size 16 bundles) Nat Consumption (11,23,37,50)
  1116. ENTRY(nat_consumption)
  1117. DBG_FAULT(26)
  1118. MOV_FROM_IPSR(p0, r16)
  1119. MOV_FROM_ISR(r17)
  1120. mov r31=pr // save PR
  1121. ;;
  1122. and r18=0xf,r17 // r18 = cr.ipsr.code{3:0}
  1123. tbit.z p6,p0=r17,IA64_ISR_NA_BIT
  1124. ;;
  1125. cmp.ne.or p6,p0=IA64_ISR_CODE_LFETCH,r18
  1126. dep r16=-1,r16,IA64_PSR_ED_BIT,1
  1127. (p6) br.cond.spnt 1f // branch if (cr.ispr.na == 0 || cr.ipsr.code{3:0} != LFETCH)
  1128. ;;
  1129. MOV_TO_IPSR(p0, r16, r18)
  1130. mov pr=r31,-1
  1131. ;;
  1132. RFI
  1133. 1: mov pr=r31,-1
  1134. ;;
  1135. FAULT(26)
  1136. END(nat_consumption)
  1137. .org ia64_ivt+0x5700
  1138. /////////////////////////////////////////////////////////////////////////////////////////
  1139. // 0x5700 Entry 27 (size 16 bundles) Speculation (40)
  1140. ENTRY(speculation_vector)
  1141. DBG_FAULT(27)
  1142. /*
  1143. * A [f]chk.[as] instruction needs to take the branch to the recovery code but
  1144. * this part of the architecture is not implemented in hardware on some CPUs, such
  1145. * as Itanium. Thus, in general we need to emulate the behavior. IIM contains
  1146. * the relative target (not yet sign extended). So after sign extending it we
  1147. * simply add it to IIP. We also need to reset the EI field of the IPSR to zero,
  1148. * i.e., the slot to restart into.
  1149. *
  1150. * cr.imm contains zero_ext(imm21)
  1151. */
  1152. MOV_FROM_IIM(r18)
  1153. ;;
  1154. MOV_FROM_IIP(r17)
  1155. shl r18=r18,43 // put sign bit in position (43=64-21)
  1156. ;;
  1157. MOV_FROM_IPSR(p0, r16)
  1158. shr r18=r18,39 // sign extend (39=43-4)
  1159. ;;
  1160. add r17=r17,r18 // now add the offset
  1161. ;;
  1162. MOV_TO_IIP(r17, r19)
  1163. dep r16=0,r16,41,2 // clear EI
  1164. ;;
  1165. MOV_TO_IPSR(p0, r16, r19)
  1166. ;;
  1167. RFI
  1168. END(speculation_vector)
  1169. .org ia64_ivt+0x5800
  1170. /////////////////////////////////////////////////////////////////////////////////////////
  1171. // 0x5800 Entry 28 (size 16 bundles) Reserved
  1172. DBG_FAULT(28)
  1173. FAULT(28)
  1174. .org ia64_ivt+0x5900
  1175. /////////////////////////////////////////////////////////////////////////////////////////
  1176. // 0x5900 Entry 29 (size 16 bundles) Debug (16,28,56)
  1177. ENTRY(debug_vector)
  1178. DBG_FAULT(29)
  1179. FAULT(29)
  1180. END(debug_vector)
  1181. .org ia64_ivt+0x5a00
  1182. /////////////////////////////////////////////////////////////////////////////////////////
  1183. // 0x5a00 Entry 30 (size 16 bundles) Unaligned Reference (57)
  1184. ENTRY(unaligned_access)
  1185. DBG_FAULT(30)
  1186. mov r31=pr // prepare to save predicates
  1187. ;;
  1188. br.sptk.many dispatch_unaligned_handler
  1189. END(unaligned_access)
  1190. .org ia64_ivt+0x5b00
  1191. /////////////////////////////////////////////////////////////////////////////////////////
  1192. // 0x5b00 Entry 31 (size 16 bundles) Unsupported Data Reference (57)
  1193. ENTRY(unsupported_data_reference)
  1194. DBG_FAULT(31)
  1195. FAULT(31)
  1196. END(unsupported_data_reference)
  1197. .org ia64_ivt+0x5c00
  1198. /////////////////////////////////////////////////////////////////////////////////////////
  1199. // 0x5c00 Entry 32 (size 16 bundles) Floating-Point Fault (64)
  1200. ENTRY(floating_point_fault)
  1201. DBG_FAULT(32)
  1202. FAULT(32)
  1203. END(floating_point_fault)
  1204. .org ia64_ivt+0x5d00
  1205. /////////////////////////////////////////////////////////////////////////////////////////
  1206. // 0x5d00 Entry 33 (size 16 bundles) Floating Point Trap (66)
  1207. ENTRY(floating_point_trap)
  1208. DBG_FAULT(33)
  1209. FAULT(33)
  1210. END(floating_point_trap)
  1211. .org ia64_ivt+0x5e00
  1212. /////////////////////////////////////////////////////////////////////////////////////////
  1213. // 0x5e00 Entry 34 (size 16 bundles) Lower Privilege Transfer Trap (66)
  1214. ENTRY(lower_privilege_trap)
  1215. DBG_FAULT(34)
  1216. FAULT(34)
  1217. END(lower_privilege_trap)
  1218. .org ia64_ivt+0x5f00
  1219. /////////////////////////////////////////////////////////////////////////////////////////
  1220. // 0x5f00 Entry 35 (size 16 bundles) Taken Branch Trap (68)
  1221. ENTRY(taken_branch_trap)
  1222. DBG_FAULT(35)
  1223. FAULT(35)
  1224. END(taken_branch_trap)
  1225. .org ia64_ivt+0x6000
  1226. /////////////////////////////////////////////////////////////////////////////////////////
  1227. // 0x6000 Entry 36 (size 16 bundles) Single Step Trap (69)
  1228. ENTRY(single_step_trap)
  1229. DBG_FAULT(36)
  1230. FAULT(36)
  1231. END(single_step_trap)
  1232. .org ia64_ivt+0x6100
  1233. /////////////////////////////////////////////////////////////////////////////////////////
  1234. // 0x6100 Entry 37 (size 16 bundles) Reserved
  1235. DBG_FAULT(37)
  1236. FAULT(37)
  1237. .org ia64_ivt+0x6200
  1238. /////////////////////////////////////////////////////////////////////////////////////////
  1239. // 0x6200 Entry 38 (size 16 bundles) Reserved
  1240. DBG_FAULT(38)
  1241. FAULT(38)
  1242. .org ia64_ivt+0x6300
  1243. /////////////////////////////////////////////////////////////////////////////////////////
  1244. // 0x6300 Entry 39 (size 16 bundles) Reserved
  1245. DBG_FAULT(39)
  1246. FAULT(39)
  1247. .org ia64_ivt+0x6400
  1248. /////////////////////////////////////////////////////////////////////////////////////////
  1249. // 0x6400 Entry 40 (size 16 bundles) Reserved
  1250. DBG_FAULT(40)
  1251. FAULT(40)
  1252. .org ia64_ivt+0x6500
  1253. /////////////////////////////////////////////////////////////////////////////////////////
  1254. // 0x6500 Entry 41 (size 16 bundles) Reserved
  1255. DBG_FAULT(41)
  1256. FAULT(41)
  1257. .org ia64_ivt+0x6600
  1258. /////////////////////////////////////////////////////////////////////////////////////////
  1259. // 0x6600 Entry 42 (size 16 bundles) Reserved
  1260. DBG_FAULT(42)
  1261. FAULT(42)
  1262. .org ia64_ivt+0x6700
  1263. /////////////////////////////////////////////////////////////////////////////////////////
  1264. // 0x6700 Entry 43 (size 16 bundles) Reserved
  1265. DBG_FAULT(43)
  1266. FAULT(43)
  1267. .org ia64_ivt+0x6800
  1268. /////////////////////////////////////////////////////////////////////////////////////////
  1269. // 0x6800 Entry 44 (size 16 bundles) Reserved
  1270. DBG_FAULT(44)
  1271. FAULT(44)
  1272. .org ia64_ivt+0x6900
  1273. /////////////////////////////////////////////////////////////////////////////////////////
  1274. // 0x6900 Entry 45 (size 16 bundles) IA-32 Exeception (17,18,29,41,42,43,44,58,60,61,62,72,73,75,76,77)
  1275. ENTRY(ia32_exception)
  1276. DBG_FAULT(45)
  1277. FAULT(45)
  1278. END(ia32_exception)
  1279. .org ia64_ivt+0x6a00
  1280. /////////////////////////////////////////////////////////////////////////////////////////
  1281. // 0x6a00 Entry 46 (size 16 bundles) IA-32 Intercept (30,31,59,70,71)
  1282. ENTRY(ia32_intercept)
  1283. DBG_FAULT(46)
  1284. FAULT(46)
  1285. END(ia32_intercept)
  1286. .org ia64_ivt+0x6b00
  1287. /////////////////////////////////////////////////////////////////////////////////////////
  1288. // 0x6b00 Entry 47 (size 16 bundles) IA-32 Interrupt (74)
  1289. ENTRY(ia32_interrupt)
  1290. DBG_FAULT(47)
  1291. FAULT(47)
  1292. END(ia32_interrupt)
  1293. .org ia64_ivt+0x6c00
  1294. /////////////////////////////////////////////////////////////////////////////////////////
  1295. // 0x6c00 Entry 48 (size 16 bundles) Reserved
  1296. DBG_FAULT(48)
  1297. FAULT(48)
  1298. .org ia64_ivt+0x6d00
  1299. /////////////////////////////////////////////////////////////////////////////////////////
  1300. // 0x6d00 Entry 49 (size 16 bundles) Reserved
  1301. DBG_FAULT(49)
  1302. FAULT(49)
  1303. .org ia64_ivt+0x6e00
  1304. /////////////////////////////////////////////////////////////////////////////////////////
  1305. // 0x6e00 Entry 50 (size 16 bundles) Reserved
  1306. DBG_FAULT(50)
  1307. FAULT(50)
  1308. .org ia64_ivt+0x6f00
  1309. /////////////////////////////////////////////////////////////////////////////////////////
  1310. // 0x6f00 Entry 51 (size 16 bundles) Reserved
  1311. DBG_FAULT(51)
  1312. FAULT(51)
  1313. .org ia64_ivt+0x7000
  1314. /////////////////////////////////////////////////////////////////////////////////////////
  1315. // 0x7000 Entry 52 (size 16 bundles) Reserved
  1316. DBG_FAULT(52)
  1317. FAULT(52)
  1318. .org ia64_ivt+0x7100
  1319. /////////////////////////////////////////////////////////////////////////////////////////
  1320. // 0x7100 Entry 53 (size 16 bundles) Reserved
  1321. DBG_FAULT(53)
  1322. FAULT(53)
  1323. .org ia64_ivt+0x7200
  1324. /////////////////////////////////////////////////////////////////////////////////////////
  1325. // 0x7200 Entry 54 (size 16 bundles) Reserved
  1326. DBG_FAULT(54)
  1327. FAULT(54)
  1328. .org ia64_ivt+0x7300
  1329. /////////////////////////////////////////////////////////////////////////////////////////
  1330. // 0x7300 Entry 55 (size 16 bundles) Reserved
  1331. DBG_FAULT(55)
  1332. FAULT(55)
  1333. .org ia64_ivt+0x7400
  1334. /////////////////////////////////////////////////////////////////////////////////////////
  1335. // 0x7400 Entry 56 (size 16 bundles) Reserved
  1336. DBG_FAULT(56)
  1337. FAULT(56)
  1338. .org ia64_ivt+0x7500
  1339. /////////////////////////////////////////////////////////////////////////////////////////
  1340. // 0x7500 Entry 57 (size 16 bundles) Reserved
  1341. DBG_FAULT(57)
  1342. FAULT(57)
  1343. .org ia64_ivt+0x7600
  1344. /////////////////////////////////////////////////////////////////////////////////////////
  1345. // 0x7600 Entry 58 (size 16 bundles) Reserved
  1346. DBG_FAULT(58)
  1347. FAULT(58)
  1348. .org ia64_ivt+0x7700
  1349. /////////////////////////////////////////////////////////////////////////////////////////
  1350. // 0x7700 Entry 59 (size 16 bundles) Reserved
  1351. DBG_FAULT(59)
  1352. FAULT(59)
  1353. .org ia64_ivt+0x7800
  1354. /////////////////////////////////////////////////////////////////////////////////////////
  1355. // 0x7800 Entry 60 (size 16 bundles) Reserved
  1356. DBG_FAULT(60)
  1357. FAULT(60)
  1358. .org ia64_ivt+0x7900
  1359. /////////////////////////////////////////////////////////////////////////////////////////
  1360. // 0x7900 Entry 61 (size 16 bundles) Reserved
  1361. DBG_FAULT(61)
  1362. FAULT(61)
  1363. .org ia64_ivt+0x7a00
  1364. /////////////////////////////////////////////////////////////////////////////////////////
  1365. // 0x7a00 Entry 62 (size 16 bundles) Reserved
  1366. DBG_FAULT(62)
  1367. FAULT(62)
  1368. .org ia64_ivt+0x7b00
  1369. /////////////////////////////////////////////////////////////////////////////////////////
  1370. // 0x7b00 Entry 63 (size 16 bundles) Reserved
  1371. DBG_FAULT(63)
  1372. FAULT(63)
  1373. .org ia64_ivt+0x7c00
  1374. /////////////////////////////////////////////////////////////////////////////////////////
  1375. // 0x7c00 Entry 64 (size 16 bundles) Reserved
  1376. DBG_FAULT(64)
  1377. FAULT(64)
  1378. .org ia64_ivt+0x7d00
  1379. /////////////////////////////////////////////////////////////////////////////////////////
  1380. // 0x7d00 Entry 65 (size 16 bundles) Reserved
  1381. DBG_FAULT(65)
  1382. FAULT(65)
  1383. .org ia64_ivt+0x7e00
  1384. /////////////////////////////////////////////////////////////////////////////////////////
  1385. // 0x7e00 Entry 66 (size 16 bundles) Reserved
  1386. DBG_FAULT(66)
  1387. FAULT(66)
  1388. .org ia64_ivt+0x7f00
  1389. /////////////////////////////////////////////////////////////////////////////////////////
  1390. // 0x7f00 Entry 67 (size 16 bundles) Reserved
  1391. DBG_FAULT(67)
  1392. FAULT(67)
  1393. //-----------------------------------------------------------------------------------
  1394. // call do_page_fault (predicates are in r31, psr.dt may be off, r16 is faulting address)
  1395. ENTRY(page_fault)
  1396. SSM_PSR_DT_AND_SRLZ_I
  1397. ;;
  1398. SAVE_MIN_WITH_COVER
  1399. alloc r15=ar.pfs,0,0,3,0
  1400. MOV_FROM_IFA(out0)
  1401. MOV_FROM_ISR(out1)
  1402. SSM_PSR_IC_AND_DEFAULT_BITS_AND_SRLZ_I(r14, r3)
  1403. adds r3=8,r2 // set up second base pointer
  1404. SSM_PSR_I(p15, p15, r14) // restore psr.i
  1405. movl r14=ia64_leave_kernel
  1406. ;;
  1407. SAVE_REST
  1408. mov rp=r14
  1409. ;;
  1410. adds out2=16,r12 // out2 = pointer to pt_regs
  1411. br.call.sptk.many b6=ia64_do_page_fault // ignore return address
  1412. END(page_fault)
  1413. ENTRY(non_syscall)
  1414. mov ar.rsc=r27 // restore ar.rsc before SAVE_MIN_WITH_COVER
  1415. ;;
  1416. SAVE_MIN_WITH_COVER
  1417. // There is no particular reason for this code to be here, other than that
  1418. // there happens to be space here that would go unused otherwise. If this
  1419. // fault ever gets "unreserved", simply moved the following code to a more
  1420. // suitable spot...
  1421. alloc r14=ar.pfs,0,0,2,0
  1422. MOV_FROM_IIM(out0)
  1423. add out1=16,sp
  1424. adds r3=8,r2 // set up second base pointer for SAVE_REST
  1425. SSM_PSR_IC_AND_DEFAULT_BITS_AND_SRLZ_I(r15, r24)
  1426. // guarantee that interruption collection is on
  1427. SSM_PSR_I(p15, p15, r15) // restore psr.i
  1428. movl r15=ia64_leave_kernel
  1429. ;;
  1430. SAVE_REST
  1431. mov rp=r15
  1432. ;;
  1433. br.call.sptk.many b6=ia64_bad_break // avoid WAW on CFM and ignore return addr
  1434. END(non_syscall)
  1435. ENTRY(__interrupt)
  1436. DBG_FAULT(12)
  1437. mov r31=pr // prepare to save predicates
  1438. ;;
  1439. SAVE_MIN_WITH_COVER // uses r31; defines r2 and r3
  1440. SSM_PSR_IC_AND_DEFAULT_BITS_AND_SRLZ_I(r3, r14)
  1441. // ensure everybody knows psr.ic is back on
  1442. adds r3=8,r2 // set up second base pointer for SAVE_REST
  1443. ;;
  1444. SAVE_REST
  1445. ;;
  1446. MCA_RECOVER_RANGE(interrupt)
  1447. alloc r14=ar.pfs,0,0,2,0 // must be first in an insn group
  1448. MOV_FROM_IVR(out0, r8) // pass cr.ivr as first arg
  1449. add out1=16,sp // pass pointer to pt_regs as second arg
  1450. ;;
  1451. srlz.d // make sure we see the effect of cr.ivr
  1452. movl r14=ia64_leave_kernel
  1453. ;;
  1454. mov rp=r14
  1455. br.call.sptk.many b6=ia64_handle_irq
  1456. END(__interrupt)
  1457. /*
  1458. * There is no particular reason for this code to be here, other than that
  1459. * there happens to be space here that would go unused otherwise. If this
  1460. * fault ever gets "unreserved", simply moved the following code to a more
  1461. * suitable spot...
  1462. */
  1463. ENTRY(dispatch_unaligned_handler)
  1464. SAVE_MIN_WITH_COVER
  1465. ;;
  1466. alloc r14=ar.pfs,0,0,2,0 // now it's safe (must be first in insn group!)
  1467. MOV_FROM_IFA(out0)
  1468. adds out1=16,sp
  1469. SSM_PSR_IC_AND_DEFAULT_BITS_AND_SRLZ_I(r3, r24)
  1470. // guarantee that interruption collection is on
  1471. SSM_PSR_I(p15, p15, r3) // restore psr.i
  1472. adds r3=8,r2 // set up second base pointer
  1473. ;;
  1474. SAVE_REST
  1475. movl r14=ia64_leave_kernel
  1476. ;;
  1477. mov rp=r14
  1478. br.sptk.many ia64_prepare_handle_unaligned
  1479. END(dispatch_unaligned_handler)
  1480. /*
  1481. * There is no particular reason for this code to be here, other than that
  1482. * there happens to be space here that would go unused otherwise. If this
  1483. * fault ever gets "unreserved", simply moved the following code to a more
  1484. * suitable spot...
  1485. */
  1486. ENTRY(dispatch_to_fault_handler)
  1487. /*
  1488. * Input:
  1489. * psr.ic: off
  1490. * r19: fault vector number (e.g., 24 for General Exception)
  1491. * r31: contains saved predicates (pr)
  1492. */
  1493. SAVE_MIN_WITH_COVER_R19
  1494. alloc r14=ar.pfs,0,0,5,0
  1495. MOV_FROM_ISR(out1)
  1496. MOV_FROM_IFA(out2)
  1497. MOV_FROM_IIM(out3)
  1498. MOV_FROM_ITIR(out4)
  1499. ;;
  1500. SSM_PSR_IC_AND_DEFAULT_BITS_AND_SRLZ_I(r3, out0)
  1501. // guarantee that interruption collection is on
  1502. mov out0=r15
  1503. ;;
  1504. SSM_PSR_I(p15, p15, r3) // restore psr.i
  1505. adds r3=8,r2 // set up second base pointer for SAVE_REST
  1506. ;;
  1507. SAVE_REST
  1508. movl r14=ia64_leave_kernel
  1509. ;;
  1510. mov rp=r14
  1511. br.call.sptk.many b6=ia64_fault
  1512. END(dispatch_to_fault_handler)
  1513. /*
  1514. * Squatting in this space ...
  1515. *
  1516. * This special case dispatcher for illegal operation faults allows preserved
  1517. * registers to be modified through a callback function (asm only) that is handed
  1518. * back from the fault handler in r8. Up to three arguments can be passed to the
  1519. * callback function by returning an aggregate with the callback as its first
  1520. * element, followed by the arguments.
  1521. */
  1522. ENTRY(dispatch_illegal_op_fault)
  1523. .prologue
  1524. .body
  1525. SAVE_MIN_WITH_COVER
  1526. SSM_PSR_IC_AND_DEFAULT_BITS_AND_SRLZ_I(r3, r24)
  1527. // guarantee that interruption collection is on
  1528. ;;
  1529. SSM_PSR_I(p15, p15, r3) // restore psr.i
  1530. adds r3=8,r2 // set up second base pointer for SAVE_REST
  1531. ;;
  1532. alloc r14=ar.pfs,0,0,1,0 // must be first in insn group
  1533. mov out0=ar.ec
  1534. ;;
  1535. SAVE_REST
  1536. PT_REGS_UNWIND_INFO(0)
  1537. ;;
  1538. br.call.sptk.many rp=ia64_illegal_op_fault
  1539. .ret0: ;;
  1540. alloc r14=ar.pfs,0,0,3,0 // must be first in insn group
  1541. mov out0=r9
  1542. mov out1=r10
  1543. mov out2=r11
  1544. movl r15=ia64_leave_kernel
  1545. ;;
  1546. mov rp=r15
  1547. mov b6=r8
  1548. ;;
  1549. cmp.ne p6,p0=0,r8
  1550. (p6) br.call.dpnt.many b6=b6 // call returns to ia64_leave_kernel
  1551. br.sptk.many ia64_leave_kernel
  1552. END(dispatch_illegal_op_fault)