head.S 14 KB

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