head.S 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572
  1. /*
  2. * Copyright IBM Corp. 1999,2010
  3. *
  4. * Author(s): Hartmut Penner <hp@de.ibm.com>
  5. * Martin Schwidefsky <schwidefsky@de.ibm.com>
  6. * Rob van der Heij <rvdhei@iae.nl>
  7. * Heiko Carstens <heiko.carstens@de.ibm.com>
  8. *
  9. * There are 5 different IPL methods
  10. * 1) load the image directly into ram at address 0 and do an PSW restart
  11. * 2) linload will load the image from address 0x10000 to memory 0x10000
  12. * and start the code thru LPSW 0x0008000080010000 (VM only, deprecated)
  13. * 3) generate the tape ipl header, store the generated image on a tape
  14. * and ipl from it
  15. * In case of SL tape you need to IPL 5 times to get past VOL1 etc
  16. * 4) generate the vm reader ipl header, move the generated image to the
  17. * VM reader (use option NOH!) and do a ipl from reader (VM only)
  18. * 5) direct call of start by the SALIPL loader
  19. * We use the cpuid to distinguish between VM and native ipl
  20. * params for kernel are pushed to 0x10400 (see setup.h)
  21. *
  22. */
  23. #include <linux/init.h>
  24. #include <linux/linkage.h>
  25. #include <asm/asm-offsets.h>
  26. #include <asm/thread_info.h>
  27. #include <asm/page.h>
  28. #ifdef CONFIG_64BIT
  29. #define ARCH_OFFSET 4
  30. #else
  31. #define ARCH_OFFSET 0
  32. #endif
  33. __HEAD
  34. #ifndef CONFIG_IPL
  35. .org 0
  36. .long 0x00080000,0x80000000+startup # Just a restart PSW
  37. #else
  38. #ifdef CONFIG_IPL_TAPE
  39. #define IPL_BS 1024
  40. .org 0
  41. .long 0x00080000,0x80000000+iplstart # The first 24 bytes are loaded
  42. .long 0x27000000,0x60000001 # by ipl to addresses 0-23.
  43. .long 0x02000000,0x20000000+IPL_BS # (a PSW and two CCWs).
  44. .long 0x00000000,0x00000000 # external old psw
  45. .long 0x00000000,0x00000000 # svc old psw
  46. .long 0x00000000,0x00000000 # program check old psw
  47. .long 0x00000000,0x00000000 # machine check old psw
  48. .long 0x00000000,0x00000000 # io old psw
  49. .long 0x00000000,0x00000000
  50. .long 0x00000000,0x00000000
  51. .long 0x00000000,0x00000000
  52. .long 0x000a0000,0x00000058 # external new psw
  53. .long 0x000a0000,0x00000060 # svc new psw
  54. .long 0x000a0000,0x00000068 # program check new psw
  55. .long 0x000a0000,0x00000070 # machine check new psw
  56. .long 0x00080000,0x80000000+.Lioint # io new psw
  57. .org 0x100
  58. #
  59. # subroutine for loading from tape
  60. # Parameters:
  61. # R1 = device number
  62. # R2 = load address
  63. .Lloader:
  64. st %r14,.Lldret
  65. la %r3,.Lorbread # r3 = address of orb
  66. la %r5,.Lirb # r5 = address of irb
  67. st %r2,.Lccwread+4 # initialize CCW data addresses
  68. lctl %c6,%c6,.Lcr6
  69. slr %r2,%r2
  70. .Lldlp:
  71. la %r6,3 # 3 retries
  72. .Lssch:
  73. ssch 0(%r3) # load chunk of IPL_BS bytes
  74. bnz .Llderr
  75. .Lw4end:
  76. bas %r14,.Lwait4io
  77. tm 8(%r5),0x82 # do we have a problem ?
  78. bnz .Lrecov
  79. slr %r7,%r7
  80. icm %r7,3,10(%r5) # get residual count
  81. lcr %r7,%r7
  82. la %r7,IPL_BS(%r7) # IPL_BS-residual=#bytes read
  83. ar %r2,%r7 # add to total size
  84. tm 8(%r5),0x01 # found a tape mark ?
  85. bnz .Ldone
  86. l %r0,.Lccwread+4 # update CCW data addresses
  87. ar %r0,%r7
  88. st %r0,.Lccwread+4
  89. b .Lldlp
  90. .Ldone:
  91. l %r14,.Lldret
  92. br %r14 # r2 contains the total size
  93. .Lrecov:
  94. bas %r14,.Lsense # do the sensing
  95. bct %r6,.Lssch # dec. retry count & branch
  96. b .Llderr
  97. #
  98. # Sense subroutine
  99. #
  100. .Lsense:
  101. st %r14,.Lsnsret
  102. la %r7,.Lorbsense
  103. ssch 0(%r7) # start sense command
  104. bnz .Llderr
  105. bas %r14,.Lwait4io
  106. l %r14,.Lsnsret
  107. tm 8(%r5),0x82 # do we have a problem ?
  108. bnz .Llderr
  109. br %r14
  110. #
  111. # Wait for interrupt subroutine
  112. #
  113. .Lwait4io:
  114. lpsw .Lwaitpsw
  115. .Lioint:
  116. c %r1,0xb8 # compare subchannel number
  117. bne .Lwait4io
  118. tsch 0(%r5)
  119. slr %r0,%r0
  120. tm 8(%r5),0x82 # do we have a problem ?
  121. bnz .Lwtexit
  122. tm 8(%r5),0x04 # got device end ?
  123. bz .Lwait4io
  124. .Lwtexit:
  125. br %r14
  126. .Llderr:
  127. lpsw .Lcrash
  128. .align 8
  129. .Lorbread:
  130. .long 0x00000000,0x0080ff00,.Lccwread
  131. .align 8
  132. .Lorbsense:
  133. .long 0x00000000,0x0080ff00,.Lccwsense
  134. .align 8
  135. .Lccwread:
  136. .long 0x02200000+IPL_BS,0x00000000
  137. .Lccwsense:
  138. .long 0x04200001,0x00000000
  139. .Lwaitpsw:
  140. .long 0x020a0000,0x80000000+.Lioint
  141. .Lirb: .long 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0
  142. .Lcr6: .long 0xff000000
  143. .align 8
  144. .Lcrash:.long 0x000a0000,0x00000000
  145. .Lldret:.long 0
  146. .Lsnsret: .long 0
  147. #endif /* CONFIG_IPL_TAPE */
  148. #ifdef CONFIG_IPL_VM
  149. #define IPL_BS 0x730
  150. .org 0
  151. .long 0x00080000,0x80000000+iplstart # The first 24 bytes are loaded
  152. .long 0x02000018,0x60000050 # by ipl to addresses 0-23.
  153. .long 0x02000068,0x60000050 # (a PSW and two CCWs).
  154. .fill 80-24,1,0x40 # bytes 24-79 are discarded !!
  155. .long 0x020000f0,0x60000050 # The next 160 byte are loaded
  156. .long 0x02000140,0x60000050 # to addresses 0x18-0xb7
  157. .long 0x02000190,0x60000050 # They form the continuation
  158. .long 0x020001e0,0x60000050 # of the CCW program started
  159. .long 0x02000230,0x60000050 # by ipl and load the range
  160. .long 0x02000280,0x60000050 # 0x0f0-0x730 from the image
  161. .long 0x020002d0,0x60000050 # to the range 0x0f0-0x730
  162. .long 0x02000320,0x60000050 # in memory. At the end of
  163. .long 0x02000370,0x60000050 # the channel program the PSW
  164. .long 0x020003c0,0x60000050 # at location 0 is loaded.
  165. .long 0x02000410,0x60000050 # Initial processing starts
  166. .long 0x02000460,0x60000050 # at 0xf0 = iplstart.
  167. .long 0x020004b0,0x60000050
  168. .long 0x02000500,0x60000050
  169. .long 0x02000550,0x60000050
  170. .long 0x020005a0,0x60000050
  171. .long 0x020005f0,0x60000050
  172. .long 0x02000640,0x60000050
  173. .long 0x02000690,0x60000050
  174. .long 0x020006e0,0x20000050
  175. .org 0xf0
  176. #
  177. # subroutine for loading cards from the reader
  178. #
  179. .Lloader:
  180. la %r3,.Lorb # r2 = address of orb into r2
  181. la %r5,.Lirb # r4 = address of irb
  182. la %r6,.Lccws
  183. la %r7,20
  184. .Linit:
  185. st %r2,4(%r6) # initialize CCW data addresses
  186. la %r2,0x50(%r2)
  187. la %r6,8(%r6)
  188. bct 7,.Linit
  189. lctl %c6,%c6,.Lcr6 # set IO subclass mask
  190. slr %r2,%r2
  191. .Lldlp:
  192. ssch 0(%r3) # load chunk of 1600 bytes
  193. bnz .Llderr
  194. .Lwait4irq:
  195. mvc 0x78(8),.Lnewpsw # set up IO interrupt psw
  196. lpsw .Lwaitpsw
  197. .Lioint:
  198. c %r1,0xb8 # compare subchannel number
  199. bne .Lwait4irq
  200. tsch 0(%r5)
  201. slr %r0,%r0
  202. ic %r0,8(%r5) # get device status
  203. chi %r0,8 # channel end ?
  204. be .Lcont
  205. chi %r0,12 # channel end + device end ?
  206. be .Lcont
  207. l %r0,4(%r5)
  208. s %r0,8(%r3) # r0/8 = number of ccws executed
  209. mhi %r0,10 # *10 = number of bytes in ccws
  210. lh %r3,10(%r5) # get residual count
  211. sr %r0,%r3 # #ccws*80-residual=#bytes read
  212. ar %r2,%r0
  213. br %r14 # r2 contains the total size
  214. .Lcont:
  215. ahi %r2,0x640 # add 0x640 to total size
  216. la %r6,.Lccws
  217. la %r7,20
  218. .Lincr:
  219. l %r0,4(%r6) # update CCW data addresses
  220. ahi %r0,0x640
  221. st %r0,4(%r6)
  222. ahi %r6,8
  223. bct 7,.Lincr
  224. b .Lldlp
  225. .Llderr:
  226. lpsw .Lcrash
  227. .align 8
  228. .Lorb: .long 0x00000000,0x0080ff00,.Lccws
  229. .Lirb: .long 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0
  230. .Lcr6: .long 0xff000000
  231. .Lloadp:.long 0,0
  232. .align 8
  233. .Lcrash:.long 0x000a0000,0x00000000
  234. .Lnewpsw:
  235. .long 0x00080000,0x80000000+.Lioint
  236. .Lwaitpsw:
  237. .long 0x020a0000,0x80000000+.Lioint
  238. .align 8
  239. .Lccws: .rept 19
  240. .long 0x02600050,0x00000000
  241. .endr
  242. .long 0x02200050,0x00000000
  243. #endif /* CONFIG_IPL_VM */
  244. iplstart:
  245. lh %r1,0xb8 # test if subchannel number
  246. bct %r1,.Lnoload # is valid
  247. l %r1,0xb8 # load ipl subchannel number
  248. la %r2,IPL_BS # load start address
  249. bas %r14,.Lloader # load rest of ipl image
  250. l %r12,.Lparm # pointer to parameter area
  251. st %r1,IPL_DEVICE+ARCH_OFFSET-PARMAREA(%r12) # save ipl device number
  252. #
  253. # load parameter file from ipl device
  254. #
  255. .Lagain1:
  256. l %r2,.Linitrd # ramdisk loc. is temp
  257. bas %r14,.Lloader # load parameter file
  258. ltr %r2,%r2 # got anything ?
  259. bz .Lnopf
  260. chi %r2,895
  261. bnh .Lnotrunc
  262. la %r2,895
  263. .Lnotrunc:
  264. l %r4,.Linitrd
  265. clc 0(3,%r4),.L_hdr # if it is HDRx
  266. bz .Lagain1 # skip dataset header
  267. clc 0(3,%r4),.L_eof # if it is EOFx
  268. bz .Lagain1 # skip dateset trailer
  269. la %r5,0(%r4,%r2)
  270. lr %r3,%r2
  271. la %r3,COMMAND_LINE-PARMAREA(%r12) # load adr. of command line
  272. mvc 0(256,%r3),0(%r4)
  273. mvc 256(256,%r3),256(%r4)
  274. mvc 512(256,%r3),512(%r4)
  275. mvc 768(122,%r3),768(%r4)
  276. slr %r0,%r0
  277. b .Lcntlp
  278. .Ldelspc:
  279. ic %r0,0(%r2,%r3)
  280. chi %r0,0x20 # is it a space ?
  281. be .Lcntlp
  282. ahi %r2,1
  283. b .Leolp
  284. .Lcntlp:
  285. brct %r2,.Ldelspc
  286. .Leolp:
  287. slr %r0,%r0
  288. stc %r0,0(%r2,%r3) # terminate buffer
  289. .Lnopf:
  290. #
  291. # load ramdisk from ipl device
  292. #
  293. .Lagain2:
  294. l %r2,.Linitrd # addr of ramdisk
  295. st %r2,INITRD_START+ARCH_OFFSET-PARMAREA(%r12)
  296. bas %r14,.Lloader # load ramdisk
  297. st %r2,INITRD_SIZE+ARCH_OFFSET-PARMAREA(%r12) # store size of rd
  298. ltr %r2,%r2
  299. bnz .Lrdcont
  300. st %r2,INITRD_START+ARCH_OFFSET-PARMAREA(%r12) # no ramdisk found
  301. .Lrdcont:
  302. l %r2,.Linitrd
  303. clc 0(3,%r2),.L_hdr # skip HDRx and EOFx
  304. bz .Lagain2
  305. clc 0(3,%r2),.L_eof
  306. bz .Lagain2
  307. #ifdef CONFIG_IPL_VM
  308. #
  309. # reset files in VM reader
  310. #
  311. stidp __LC_SAVE_AREA_SYNC # store cpuid
  312. tm __LC_SAVE_AREA_SYNC,0xff# running VM ?
  313. bno .Lnoreset
  314. la %r2,.Lreset
  315. lhi %r3,26
  316. diag %r2,%r3,8
  317. la %r5,.Lirb
  318. stsch 0(%r5) # check if irq is pending
  319. tm 30(%r5),0x0f # by verifying if any of the
  320. bnz .Lwaitforirq # activity or status control
  321. tm 31(%r5),0xff # bits is set in the schib
  322. bz .Lnoreset
  323. .Lwaitforirq:
  324. mvc 0x78(8),.Lrdrnewpsw # set up IO interrupt psw
  325. .Lwaitrdrirq:
  326. lpsw .Lrdrwaitpsw
  327. .Lrdrint:
  328. c %r1,0xb8 # compare subchannel number
  329. bne .Lwaitrdrirq
  330. la %r5,.Lirb
  331. tsch 0(%r5)
  332. .Lnoreset:
  333. b .Lnoload
  334. .align 8
  335. .Lrdrnewpsw:
  336. .long 0x00080000,0x80000000+.Lrdrint
  337. .Lrdrwaitpsw:
  338. .long 0x020a0000,0x80000000+.Lrdrint
  339. #endif
  340. #
  341. # everything loaded, go for it
  342. #
  343. .Lnoload:
  344. l %r1,.Lstartup
  345. br %r1
  346. .Linitrd:.long _end # default address of initrd
  347. .Lparm: .long PARMAREA
  348. .Lstartup: .long startup
  349. .Lreset:.byte 0xc3,0xc8,0xc1,0xd5,0xc7,0xc5,0x40,0xd9,0xc4,0xd9,0x40
  350. .byte 0xc1,0xd3,0xd3,0x40,0xd2,0xc5,0xc5,0xd7,0x40,0xd5,0xd6
  351. .byte 0xc8,0xd6,0xd3,0xc4 # "change rdr all keep nohold"
  352. .L_eof: .long 0xc5d6c600 /* C'EOF' */
  353. .L_hdr: .long 0xc8c4d900 /* C'HDR' */
  354. #endif /* CONFIG_IPL */
  355. #
  356. # SALIPL loader support. Based on a patch by Rob van der Heij.
  357. # This entry point is called directly from the SALIPL loader and
  358. # doesn't need a builtin ipl record.
  359. #
  360. .org 0x800
  361. ENTRY(start)
  362. stm %r0,%r15,0x07b0 # store registers
  363. basr %r12,%r0
  364. .base:
  365. l %r11,.parm
  366. l %r8,.cmd # pointer to command buffer
  367. ltr %r9,%r9 # do we have SALIPL parameters?
  368. bp .sk8x8
  369. mvc 0(64,%r8),0x00b0 # copy saved registers
  370. xc 64(240-64,%r8),0(%r8) # remainder of buffer
  371. tr 0(64,%r8),.lowcase
  372. b .gotr
  373. .sk8x8:
  374. mvc 0(240,%r8),0(%r9) # copy iplparms into buffer
  375. .gotr:
  376. slr %r0,%r0
  377. st %r0,INITRD_SIZE+ARCH_OFFSET-PARMAREA(%r11)
  378. st %r0,INITRD_START+ARCH_OFFSET-PARMAREA(%r11)
  379. j startup # continue with startup
  380. .cmd: .long COMMAND_LINE # address of command line buffer
  381. .parm: .long PARMAREA
  382. .lowcase:
  383. .byte 0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07
  384. .byte 0x08,0x09,0x0a,0x0b,0x0c,0x0d,0x0e,0x0f
  385. .byte 0x10,0x11,0x12,0x13,0x14,0x15,0x16,0x17
  386. .byte 0x18,0x19,0x1a,0x1b,0x1c,0x1d,0x1e,0x1f
  387. .byte 0x20,0x21,0x22,0x23,0x24,0x25,0x26,0x27
  388. .byte 0x28,0x29,0x2a,0x2b,0x2c,0x2d,0x2e,0x2f
  389. .byte 0x30,0x31,0x32,0x33,0x34,0x35,0x36,0x37
  390. .byte 0x38,0x39,0x3a,0x3b,0x3c,0x3d,0x3e,0x3f
  391. .byte 0x40,0x41,0x42,0x43,0x44,0x45,0x46,0x47
  392. .byte 0x48,0x49,0x4a,0x4b,0x4c,0x4d,0x4e,0x4f
  393. .byte 0x50,0x51,0x52,0x53,0x54,0x55,0x56,0x57
  394. .byte 0x58,0x59,0x5a,0x5b,0x5c,0x5d,0x5e,0x5f
  395. .byte 0x60,0x61,0x62,0x63,0x64,0x65,0x66,0x67
  396. .byte 0x68,0x69,0x6a,0x6b,0x6c,0x6d,0x6e,0x6f
  397. .byte 0x70,0x71,0x72,0x73,0x74,0x75,0x76,0x77
  398. .byte 0x78,0x79,0x7a,0x7b,0x7c,0x7d,0x7e,0x7f
  399. .byte 0x80,0x81,0x82,0x83,0x84,0x85,0x86,0x87
  400. .byte 0x88,0x89,0x8a,0x8b,0x8c,0x8d,0x8e,0x8f
  401. .byte 0x90,0x91,0x92,0x93,0x94,0x95,0x96,0x97
  402. .byte 0x98,0x99,0x9a,0x9b,0x9c,0x9d,0x9e,0x9f
  403. .byte 0xa0,0xa1,0xa2,0xa3,0xa4,0xa5,0xa6,0xa7
  404. .byte 0xa8,0xa9,0xaa,0xab,0xac,0xad,0xae,0xaf
  405. .byte 0xb0,0xb1,0xb2,0xb3,0xb4,0xb5,0xb6,0xb7
  406. .byte 0xb8,0xb9,0xba,0xbb,0xbc,0xbd,0xbe,0xbf
  407. .byte 0xc0,0x81,0x82,0x83,0x84,0x85,0x86,0x87 # .abcdefg
  408. .byte 0x88,0x89,0xca,0xcb,0xcc,0xcd,0xce,0xcf # hi
  409. .byte 0xd0,0x91,0x92,0x93,0x94,0x95,0x96,0x97 # .jklmnop
  410. .byte 0x98,0x99,0xda,0xdb,0xdc,0xdd,0xde,0xdf # qr
  411. .byte 0xe0,0xe1,0xa2,0xa3,0xa4,0xa5,0xa6,0xa7 # ..stuvwx
  412. .byte 0xa8,0xa9,0xea,0xeb,0xec,0xed,0xee,0xef # yz
  413. .byte 0xf0,0xf1,0xf2,0xf3,0xf4,0xf5,0xf6,0xf7
  414. .byte 0xf8,0xf9,0xfa,0xfb,0xfc,0xfd,0xfe,0xff
  415. #
  416. # startup-code at 0x10000, running in absolute addressing mode
  417. # this is called either by the ipl loader or directly by PSW restart
  418. # or linload or SALIPL
  419. #
  420. .org 0x10000
  421. ENTRY(startup)
  422. j .Lep_startup_normal
  423. .org 0x10008
  424. #
  425. # This is a list of s390 kernel entry points. At address 0x1000f the number of
  426. # valid entry points is stored.
  427. #
  428. # IMPORTANT: Do not change this table, it is s390 kernel ABI!
  429. #
  430. .ascii "S390EP"
  431. .byte 0x00,0x01
  432. #
  433. # kdump startup-code at 0x10010, running in 64 bit absolute addressing mode
  434. #
  435. .org 0x10010
  436. ENTRY(startup_kdump)
  437. j .Lep_startup_kdump
  438. .Lep_startup_normal:
  439. basr %r13,0 # get base
  440. .LPG0:
  441. xc 0x200(256),0x200 # partially clear lowcore
  442. xc 0x300(256),0x300
  443. xc 0xe00(256),0xe00
  444. stck __LC_LAST_UPDATE_CLOCK
  445. spt 5f-.LPG0(%r13)
  446. mvc __LC_LAST_UPDATE_TIMER(8),5f-.LPG0(%r13)
  447. xc __LC_STFL_FAC_LIST(8),__LC_STFL_FAC_LIST
  448. #ifndef CONFIG_MARCH_G5
  449. # check capabilities against MARCH_{G5,Z900,Z990,Z9_109,Z10}
  450. .insn s,0xb2b10000,__LC_STFL_FAC_LIST # store facility list
  451. tm __LC_STFL_FAC_LIST,0x01 # stfle available ?
  452. jz 0f
  453. la %r0,0
  454. .insn s,0xb2b00000,__LC_STFL_FAC_LIST # store facility list extended
  455. 0: l %r0,__LC_STFL_FAC_LIST
  456. n %r0,2f+8-.LPG0(%r13)
  457. cl %r0,2f+8-.LPG0(%r13)
  458. jne 1f
  459. l %r0,__LC_STFL_FAC_LIST+4
  460. n %r0,2f+12-.LPG0(%r13)
  461. cl %r0,2f+12-.LPG0(%r13)
  462. je 3f
  463. 1: l %r15,.Lstack-.LPG0(%r13)
  464. ahi %r15,-96
  465. la %r2,.Lals_string-.LPG0(%r13)
  466. l %r3,.Lsclp_print-.LPG0(%r13)
  467. basr %r14,%r3
  468. lpsw 2f-.LPG0(%r13) # machine type not good enough, crash
  469. .Lals_string:
  470. .asciz "The Linux kernel requires more recent processor hardware"
  471. .Lsclp_print:
  472. .long _sclp_print_early
  473. .Lstack:
  474. .long 0x8000 + (1<<(PAGE_SHIFT+THREAD_ORDER))
  475. .align 16
  476. 2: .long 0x000a0000,0x8badcccc
  477. #if defined(CONFIG_64BIT)
  478. #if defined(CONFIG_MARCH_Z196)
  479. .long 0xc100efe3, 0xf46c0000
  480. #elif defined(CONFIG_MARCH_Z10)
  481. .long 0xc100efe3, 0xf0680000
  482. #elif defined(CONFIG_MARCH_Z9_109)
  483. .long 0xc100efc3, 0x00000000
  484. #elif defined(CONFIG_MARCH_Z990)
  485. .long 0xc0002000, 0x00000000
  486. #elif defined(CONFIG_MARCH_Z900)
  487. .long 0xc0000000, 0x00000000
  488. #endif
  489. #else
  490. #if defined(CONFIG_MARCH_Z196)
  491. .long 0x8100c880, 0x00000000
  492. #elif defined(CONFIG_MARCH_Z10)
  493. .long 0x8100c880, 0x00000000
  494. #elif defined(CONFIG_MARCH_Z9_109)
  495. .long 0x8100c880, 0x00000000
  496. #elif defined(CONFIG_MARCH_Z990)
  497. .long 0x80002000, 0x00000000
  498. #elif defined(CONFIG_MARCH_Z900)
  499. .long 0x80000000, 0x00000000
  500. #endif
  501. #endif
  502. 3:
  503. #endif
  504. #ifdef CONFIG_64BIT
  505. mvi __LC_AR_MODE_ID,1 # set esame flag
  506. slr %r0,%r0 # set cpuid to zero
  507. lhi %r1,2 # mode 2 = esame (dump)
  508. sigp %r1,%r0,0x12 # switch to esame mode
  509. sam64 # switch to 64 bit mode
  510. larl %r13,4f
  511. lmh %r0,%r15,0(%r13) # clear high-order half
  512. jg startup_continue
  513. 4: .fill 16,4,0x0
  514. #else
  515. mvi __LC_AR_MODE_ID,0 # set ESA flag (mode 0)
  516. l %r13,4f-.LPG0(%r13)
  517. b 0(%r13)
  518. .align 8
  519. 4: .long startup_continue
  520. #endif
  521. .align 8
  522. 5: .long 0x7fffffff,0xffffffff
  523. #include "head_kdump.S"
  524. #
  525. # params at 10400 (setup.h)
  526. #
  527. .org PARMAREA
  528. .long 0,0 # IPL_DEVICE
  529. .long 0,0 # INITRD_START
  530. .long 0,0 # INITRD_SIZE
  531. .long 0,0 # OLDMEM_BASE
  532. .long 0,0 # OLDMEM_SIZE
  533. .org COMMAND_LINE
  534. .byte "root=/dev/ram0 ro"
  535. .byte 0
  536. .org 0x11000