echo.asm 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665
  1. _echo: file format elf32-littlearm
  2. Disassembly of section .text:
  3. 00000000 <main>:
  4. int
  5. main(int argc, char *argv[])
  6. {
  7. int i;
  8. for(i = 1; i < argc; i++)
  9. 0: e3500001 cmp r0, #1
  10. #include "stat.h"
  11. #include "user.h"
  12. int
  13. main(int argc, char *argv[])
  14. {
  15. 4: e92d4878 push {r3, r4, r5, r6, fp, lr}
  16. 8: e1a06000 mov r6, r0
  17. c: e28db014 add fp, sp, #20
  18. int i;
  19. for(i = 1; i < argc; i++)
  20. 10: da000011 ble 5c <main+0x5c>
  21. 14: e3a04001 mov r4, #1
  22. 18: e1a05001 mov r5, r1
  23. printf(1, "%s%s", argv[i], i+1 < argc ? " " : "\n");
  24. 1c: e2844001 add r4, r4, #1
  25. 20: e1540006 cmp r4, r6
  26. 24: e5b52004 ldr r2, [r5, #4]!
  27. 28: e3a00001 mov r0, #1
  28. 2c: e59f102c ldr r1, [pc, #44] ; 60 <main+0x60>
  29. 30: 0a000007 beq 54 <main+0x54>
  30. 34: e59f3028 ldr r3, [pc, #40] ; 64 <main+0x64>
  31. 38: e2844001 add r4, r4, #1
  32. 3c: eb000205 bl 858 <printf>
  33. 40: e1540006 cmp r4, r6
  34. 44: e5b52004 ldr r2, [r5, #4]!
  35. 48: e3a00001 mov r0, #1
  36. 4c: e59f100c ldr r1, [pc, #12] ; 60 <main+0x60>
  37. 50: 1afffff7 bne 34 <main+0x34>
  38. 54: e59f300c ldr r3, [pc, #12] ; 68 <main+0x68>
  39. 58: eb0001fe bl 858 <printf>
  40. exit();
  41. 5c: eb0000aa bl 30c <exit>
  42. 60: 00000b40 .word 0x00000b40
  43. 64: 00000b48 .word 0x00000b48
  44. 68: 00000b4c .word 0x00000b4c
  45. 0000006c <strcpy>:
  46. #include "user.h"
  47. #include "arm.h"
  48. char*
  49. strcpy(char *s, char *t)
  50. {
  51. 6c: e52db004 push {fp} ; (str fp, [sp, #-4]!)
  52. char *os;
  53. os = s;
  54. while((*s++ = *t++) != 0)
  55. 70: e1a02000 mov r2, r0
  56. #include "user.h"
  57. #include "arm.h"
  58. char*
  59. strcpy(char *s, char *t)
  60. {
  61. 74: e28db000 add fp, sp, #0
  62. char *os;
  63. os = s;
  64. while((*s++ = *t++) != 0)
  65. 78: e4d13001 ldrb r3, [r1], #1
  66. 7c: e3530000 cmp r3, #0
  67. 80: e4c23001 strb r3, [r2], #1
  68. 84: 1afffffb bne 78 <strcpy+0xc>
  69. ;
  70. return os;
  71. }
  72. 88: e28bd000 add sp, fp, #0
  73. 8c: e8bd0800 pop {fp}
  74. 90: e12fff1e bx lr
  75. 00000094 <strcmp>:
  76. int
  77. strcmp(const char *p, const char *q)
  78. {
  79. 94: e52db004 push {fp} ; (str fp, [sp, #-4]!)
  80. 98: e28db000 add fp, sp, #0
  81. while(*p && *p == *q)
  82. 9c: e5d03000 ldrb r3, [r0]
  83. a0: e5d12000 ldrb r2, [r1]
  84. a4: e3530000 cmp r3, #0
  85. a8: 1a000004 bne c0 <strcmp+0x2c>
  86. ac: ea000005 b c8 <strcmp+0x34>
  87. b0: e5f03001 ldrb r3, [r0, #1]!
  88. b4: e3530000 cmp r3, #0
  89. b8: 0a000006 beq d8 <strcmp+0x44>
  90. bc: e5f12001 ldrb r2, [r1, #1]!
  91. c0: e1530002 cmp r3, r2
  92. c4: 0afffff9 beq b0 <strcmp+0x1c>
  93. p++, q++;
  94. return (uchar)*p - (uchar)*q;
  95. }
  96. c8: e0620003 rsb r0, r2, r3
  97. cc: e28bd000 add sp, fp, #0
  98. d0: e8bd0800 pop {fp}
  99. d4: e12fff1e bx lr
  100. }
  101. int
  102. strcmp(const char *p, const char *q)
  103. {
  104. while(*p && *p == *q)
  105. d8: e5d12001 ldrb r2, [r1, #1]
  106. dc: eafffff9 b c8 <strcmp+0x34>
  107. 000000e0 <strlen>:
  108. return (uchar)*p - (uchar)*q;
  109. }
  110. uint
  111. strlen(char *s)
  112. {
  113. e0: e52db004 push {fp} ; (str fp, [sp, #-4]!)
  114. e4: e28db000 add fp, sp, #0
  115. int n;
  116. for(n = 0; s[n]; n++)
  117. e8: e5d03000 ldrb r3, [r0]
  118. ec: e3530000 cmp r3, #0
  119. f0: 01a00003 moveq r0, r3
  120. f4: 0a000006 beq 114 <strlen+0x34>
  121. f8: e1a02000 mov r2, r0
  122. fc: e3a03000 mov r3, #0
  123. 100: e5f21001 ldrb r1, [r2, #1]!
  124. 104: e2833001 add r3, r3, #1
  125. 108: e1a00003 mov r0, r3
  126. 10c: e3510000 cmp r1, #0
  127. 110: 1afffffa bne 100 <strlen+0x20>
  128. ;
  129. return n;
  130. }
  131. 114: e28bd000 add sp, fp, #0
  132. 118: e8bd0800 pop {fp}
  133. 11c: e12fff1e bx lr
  134. 00000120 <memset>:
  135. memset(void *dst, int c, uint n)
  136. {
  137. char *p=dst;
  138. u32 rc=n;
  139. while (rc-- > 0) *p++ = c;
  140. 120: e3520000 cmp r2, #0
  141. return n;
  142. }
  143. void*
  144. memset(void *dst, int c, uint n)
  145. {
  146. 124: e52db004 push {fp} ; (str fp, [sp, #-4]!)
  147. 128: e28db000 add fp, sp, #0
  148. char *p=dst;
  149. u32 rc=n;
  150. while (rc-- > 0) *p++ = c;
  151. 12c: 0a000006 beq 14c <memset+0x2c>
  152. 130: e6ef1071 uxtb r1, r1
  153. 134: e1a03002 mov r3, r2
  154. }
  155. void*
  156. memset(void *dst, int c, uint n)
  157. {
  158. char *p=dst;
  159. 138: e1a0c000 mov ip, r0
  160. u32 rc=n;
  161. while (rc-- > 0) *p++ = c;
  162. 13c: e2533001 subs r3, r3, #1
  163. 140: e4cc1001 strb r1, [ip], #1
  164. 144: 1afffffc bne 13c <memset+0x1c>
  165. 148: e0800002 add r0, r0, r2
  166. return (void *)p;
  167. }
  168. 14c: e28bd000 add sp, fp, #0
  169. 150: e8bd0800 pop {fp}
  170. 154: e12fff1e bx lr
  171. 00000158 <strchr>:
  172. char*
  173. strchr(const char *s, char c)
  174. {
  175. 158: e52db004 push {fp} ; (str fp, [sp, #-4]!)
  176. 15c: e28db000 add fp, sp, #0
  177. for(; *s; s++)
  178. 160: e5d03000 ldrb r3, [r0]
  179. 164: e3530000 cmp r3, #0
  180. 168: 1a000004 bne 180 <strchr+0x28>
  181. 16c: ea000008 b 194 <strchr+0x3c>
  182. 170: e5d03001 ldrb r3, [r0, #1]
  183. 174: e2800001 add r0, r0, #1
  184. 178: e3530000 cmp r3, #0
  185. 17c: 0a000004 beq 194 <strchr+0x3c>
  186. if(*s == c)
  187. 180: e1530001 cmp r3, r1
  188. 184: 1afffff9 bne 170 <strchr+0x18>
  189. return (char*)s;
  190. return 0;
  191. }
  192. 188: e28bd000 add sp, fp, #0
  193. 18c: e8bd0800 pop {fp}
  194. 190: e12fff1e bx lr
  195. strchr(const char *s, char c)
  196. {
  197. for(; *s; s++)
  198. if(*s == c)
  199. return (char*)s;
  200. return 0;
  201. 194: e1a00003 mov r0, r3
  202. 198: eafffffa b 188 <strchr+0x30>
  203. 0000019c <gets>:
  204. }
  205. char*
  206. gets(char *buf, int max)
  207. {
  208. 19c: e92d49f0 push {r4, r5, r6, r7, r8, fp, lr}
  209. 1a0: e28db018 add fp, sp, #24
  210. 1a4: e24dd00c sub sp, sp, #12
  211. 1a8: e1a08000 mov r8, r0
  212. 1ac: e1a07001 mov r7, r1
  213. int i, cc;
  214. char c;
  215. for(i=0; i+1 < max; ){
  216. 1b0: e1a06000 mov r6, r0
  217. 1b4: e3a05000 mov r5, #0
  218. 1b8: ea000008 b 1e0 <gets+0x44>
  219. cc = read(0, &c, 1);
  220. 1bc: eb000079 bl 3a8 <read>
  221. if(cc < 1)
  222. 1c0: e3500000 cmp r0, #0
  223. 1c4: da00000b ble 1f8 <gets+0x5c>
  224. break;
  225. buf[i++] = c;
  226. 1c8: e55b301d ldrb r3, [fp, #-29]
  227. if(c == '\n' || c == '\r')
  228. 1cc: e1a05004 mov r5, r4
  229. 1d0: e353000a cmp r3, #10
  230. 1d4: 1353000d cmpne r3, #13
  231. for(i=0; i+1 < max; ){
  232. cc = read(0, &c, 1);
  233. if(cc < 1)
  234. break;
  235. buf[i++] = c;
  236. 1d8: e4c63001 strb r3, [r6], #1
  237. if(c == '\n' || c == '\r')
  238. 1dc: 0a00000a beq 20c <gets+0x70>
  239. {
  240. int i, cc;
  241. char c;
  242. for(i=0; i+1 < max; ){
  243. cc = read(0, &c, 1);
  244. 1e0: e3a02001 mov r2, #1
  245. gets(char *buf, int max)
  246. {
  247. int i, cc;
  248. char c;
  249. for(i=0; i+1 < max; ){
  250. 1e4: e0854002 add r4, r5, r2
  251. 1e8: e1540007 cmp r4, r7
  252. cc = read(0, &c, 1);
  253. 1ec: e3a00000 mov r0, #0
  254. 1f0: e24b101d sub r1, fp, #29
  255. gets(char *buf, int max)
  256. {
  257. int i, cc;
  258. char c;
  259. for(i=0; i+1 < max; ){
  260. 1f4: bafffff0 blt 1bc <gets+0x20>
  261. break;
  262. buf[i++] = c;
  263. if(c == '\n' || c == '\r')
  264. break;
  265. }
  266. buf[i] = '\0';
  267. 1f8: e3a03000 mov r3, #0
  268. 1fc: e7c83005 strb r3, [r8, r5]
  269. return buf;
  270. }
  271. 200: e1a00008 mov r0, r8
  272. 204: e24bd018 sub sp, fp, #24
  273. 208: e8bd89f0 pop {r4, r5, r6, r7, r8, fp, pc}
  274. gets(char *buf, int max)
  275. {
  276. int i, cc;
  277. char c;
  278. for(i=0; i+1 < max; ){
  279. 20c: e1a05004 mov r5, r4
  280. 210: eafffff8 b 1f8 <gets+0x5c>
  281. 00000214 <stat>:
  282. return buf;
  283. }
  284. int
  285. stat(char *n, struct stat *st)
  286. {
  287. 214: e92d4830 push {r4, r5, fp, lr}
  288. 218: e1a05001 mov r5, r1
  289. 21c: e28db00c add fp, sp, #12
  290. int fd;
  291. int r;
  292. fd = open(n, O_RDONLY);
  293. 220: e3a01000 mov r1, #0
  294. 224: eb0000a0 bl 4ac <open>
  295. if(fd < 0)
  296. 228: e2504000 subs r4, r0, #0
  297. return -1;
  298. 22c: b3e05000 mvnlt r5, #0
  299. {
  300. int fd;
  301. int r;
  302. fd = open(n, O_RDONLY);
  303. if(fd < 0)
  304. 230: ba000004 blt 248 <stat+0x34>
  305. return -1;
  306. r = fstat(fd, st);
  307. 234: e1a01005 mov r1, r5
  308. 238: eb0000c2 bl 548 <fstat>
  309. 23c: e1a05000 mov r5, r0
  310. close(fd);
  311. 240: e1a00004 mov r0, r4
  312. 244: eb000071 bl 410 <close>
  313. return r;
  314. }
  315. 248: e1a00005 mov r0, r5
  316. 24c: e8bd8830 pop {r4, r5, fp, pc}
  317. 00000250 <atoi>:
  318. int
  319. atoi(const char *s)
  320. {
  321. 250: e52db004 push {fp} ; (str fp, [sp, #-4]!)
  322. 254: e28db000 add fp, sp, #0
  323. int n;
  324. n = 0;
  325. while('0' <= *s && *s <= '9')
  326. 258: e5d03000 ldrb r3, [r0]
  327. 25c: e2432030 sub r2, r3, #48 ; 0x30
  328. 260: e6ef2072 uxtb r2, r2
  329. 264: e3520009 cmp r2, #9
  330. int
  331. atoi(const char *s)
  332. {
  333. int n;
  334. n = 0;
  335. 268: 83a00000 movhi r0, #0
  336. while('0' <= *s && *s <= '9')
  337. 26c: 8a000009 bhi 298 <atoi+0x48>
  338. 270: e1a02000 mov r2, r0
  339. int
  340. atoi(const char *s)
  341. {
  342. int n;
  343. n = 0;
  344. 274: e3a00000 mov r0, #0
  345. while('0' <= *s && *s <= '9')
  346. n = n*10 + *s++ - '0';
  347. 278: e0800100 add r0, r0, r0, lsl #2
  348. 27c: e0830080 add r0, r3, r0, lsl #1
  349. atoi(const char *s)
  350. {
  351. int n;
  352. n = 0;
  353. while('0' <= *s && *s <= '9')
  354. 280: e5f23001 ldrb r3, [r2, #1]!
  355. n = n*10 + *s++ - '0';
  356. 284: e2400030 sub r0, r0, #48 ; 0x30
  357. atoi(const char *s)
  358. {
  359. int n;
  360. n = 0;
  361. while('0' <= *s && *s <= '9')
  362. 288: e2431030 sub r1, r3, #48 ; 0x30
  363. 28c: e6ef1071 uxtb r1, r1
  364. 290: e3510009 cmp r1, #9
  365. 294: 9afffff7 bls 278 <atoi+0x28>
  366. n = n*10 + *s++ - '0';
  367. return n;
  368. }
  369. 298: e28bd000 add sp, fp, #0
  370. 29c: e8bd0800 pop {fp}
  371. 2a0: e12fff1e bx lr
  372. 000002a4 <memmove>:
  373. {
  374. char *dst, *src;
  375. dst = vdst;
  376. src = vsrc;
  377. while(n-- > 0)
  378. 2a4: e3520000 cmp r2, #0
  379. return n;
  380. }
  381. void*
  382. memmove(void *vdst, void *vsrc, int n)
  383. {
  384. 2a8: e52db004 push {fp} ; (str fp, [sp, #-4]!)
  385. 2ac: e28db000 add fp, sp, #0
  386. char *dst, *src;
  387. dst = vdst;
  388. src = vsrc;
  389. while(n-- > 0)
  390. 2b0: da000005 ble 2cc <memmove+0x28>
  391. n = n*10 + *s++ - '0';
  392. return n;
  393. }
  394. void*
  395. memmove(void *vdst, void *vsrc, int n)
  396. 2b4: e0802002 add r2, r0, r2
  397. {
  398. char *dst, *src;
  399. dst = vdst;
  400. 2b8: e1a03000 mov r3, r0
  401. src = vsrc;
  402. while(n-- > 0)
  403. *dst++ = *src++;
  404. 2bc: e4d1c001 ldrb ip, [r1], #1
  405. 2c0: e4c3c001 strb ip, [r3], #1
  406. {
  407. char *dst, *src;
  408. dst = vdst;
  409. src = vsrc;
  410. while(n-- > 0)
  411. 2c4: e1530002 cmp r3, r2
  412. 2c8: 1afffffb bne 2bc <memmove+0x18>
  413. *dst++ = *src++;
  414. return vdst;
  415. }
  416. 2cc: e28bd000 add sp, fp, #0
  417. 2d0: e8bd0800 pop {fp}
  418. 2d4: e12fff1e bx lr
  419. 000002d8 <fork>:
  420. 2d8: e92d4000 push {lr}
  421. 2dc: e92d0008 push {r3}
  422. 2e0: e92d0004 push {r2}
  423. 2e4: e92d0002 push {r1}
  424. 2e8: e92d0001 push {r0}
  425. 2ec: e3a00001 mov r0, #1
  426. 2f0: ef000040 svc 0x00000040
  427. 2f4: e8bd0002 pop {r1}
  428. 2f8: e8bd0002 pop {r1}
  429. 2fc: e8bd0004 pop {r2}
  430. 300: e8bd0008 pop {r3}
  431. 304: e8bd4000 pop {lr}
  432. 308: e12fff1e bx lr
  433. 0000030c <exit>:
  434. 30c: e92d4000 push {lr}
  435. 310: e92d0008 push {r3}
  436. 314: e92d0004 push {r2}
  437. 318: e92d0002 push {r1}
  438. 31c: e92d0001 push {r0}
  439. 320: e3a00002 mov r0, #2
  440. 324: ef000040 svc 0x00000040
  441. 328: e8bd0002 pop {r1}
  442. 32c: e8bd0002 pop {r1}
  443. 330: e8bd0004 pop {r2}
  444. 334: e8bd0008 pop {r3}
  445. 338: e8bd4000 pop {lr}
  446. 33c: e12fff1e bx lr
  447. 00000340 <wait>:
  448. 340: e92d4000 push {lr}
  449. 344: e92d0008 push {r3}
  450. 348: e92d0004 push {r2}
  451. 34c: e92d0002 push {r1}
  452. 350: e92d0001 push {r0}
  453. 354: e3a00003 mov r0, #3
  454. 358: ef000040 svc 0x00000040
  455. 35c: e8bd0002 pop {r1}
  456. 360: e8bd0002 pop {r1}
  457. 364: e8bd0004 pop {r2}
  458. 368: e8bd0008 pop {r3}
  459. 36c: e8bd4000 pop {lr}
  460. 370: e12fff1e bx lr
  461. 00000374 <pipe>:
  462. 374: e92d4000 push {lr}
  463. 378: e92d0008 push {r3}
  464. 37c: e92d0004 push {r2}
  465. 380: e92d0002 push {r1}
  466. 384: e92d0001 push {r0}
  467. 388: e3a00004 mov r0, #4
  468. 38c: ef000040 svc 0x00000040
  469. 390: e8bd0002 pop {r1}
  470. 394: e8bd0002 pop {r1}
  471. 398: e8bd0004 pop {r2}
  472. 39c: e8bd0008 pop {r3}
  473. 3a0: e8bd4000 pop {lr}
  474. 3a4: e12fff1e bx lr
  475. 000003a8 <read>:
  476. 3a8: e92d4000 push {lr}
  477. 3ac: e92d0008 push {r3}
  478. 3b0: e92d0004 push {r2}
  479. 3b4: e92d0002 push {r1}
  480. 3b8: e92d0001 push {r0}
  481. 3bc: e3a00005 mov r0, #5
  482. 3c0: ef000040 svc 0x00000040
  483. 3c4: e8bd0002 pop {r1}
  484. 3c8: e8bd0002 pop {r1}
  485. 3cc: e8bd0004 pop {r2}
  486. 3d0: e8bd0008 pop {r3}
  487. 3d4: e8bd4000 pop {lr}
  488. 3d8: e12fff1e bx lr
  489. 000003dc <write>:
  490. 3dc: e92d4000 push {lr}
  491. 3e0: e92d0008 push {r3}
  492. 3e4: e92d0004 push {r2}
  493. 3e8: e92d0002 push {r1}
  494. 3ec: e92d0001 push {r0}
  495. 3f0: e3a00010 mov r0, #16
  496. 3f4: ef000040 svc 0x00000040
  497. 3f8: e8bd0002 pop {r1}
  498. 3fc: e8bd0002 pop {r1}
  499. 400: e8bd0004 pop {r2}
  500. 404: e8bd0008 pop {r3}
  501. 408: e8bd4000 pop {lr}
  502. 40c: e12fff1e bx lr
  503. 00000410 <close>:
  504. 410: e92d4000 push {lr}
  505. 414: e92d0008 push {r3}
  506. 418: e92d0004 push {r2}
  507. 41c: e92d0002 push {r1}
  508. 420: e92d0001 push {r0}
  509. 424: e3a00015 mov r0, #21
  510. 428: ef000040 svc 0x00000040
  511. 42c: e8bd0002 pop {r1}
  512. 430: e8bd0002 pop {r1}
  513. 434: e8bd0004 pop {r2}
  514. 438: e8bd0008 pop {r3}
  515. 43c: e8bd4000 pop {lr}
  516. 440: e12fff1e bx lr
  517. 00000444 <kill>:
  518. 444: e92d4000 push {lr}
  519. 448: e92d0008 push {r3}
  520. 44c: e92d0004 push {r2}
  521. 450: e92d0002 push {r1}
  522. 454: e92d0001 push {r0}
  523. 458: e3a00006 mov r0, #6
  524. 45c: ef000040 svc 0x00000040
  525. 460: e8bd0002 pop {r1}
  526. 464: e8bd0002 pop {r1}
  527. 468: e8bd0004 pop {r2}
  528. 46c: e8bd0008 pop {r3}
  529. 470: e8bd4000 pop {lr}
  530. 474: e12fff1e bx lr
  531. 00000478 <exec>:
  532. 478: e92d4000 push {lr}
  533. 47c: e92d0008 push {r3}
  534. 480: e92d0004 push {r2}
  535. 484: e92d0002 push {r1}
  536. 488: e92d0001 push {r0}
  537. 48c: e3a00007 mov r0, #7
  538. 490: ef000040 svc 0x00000040
  539. 494: e8bd0002 pop {r1}
  540. 498: e8bd0002 pop {r1}
  541. 49c: e8bd0004 pop {r2}
  542. 4a0: e8bd0008 pop {r3}
  543. 4a4: e8bd4000 pop {lr}
  544. 4a8: e12fff1e bx lr
  545. 000004ac <open>:
  546. 4ac: e92d4000 push {lr}
  547. 4b0: e92d0008 push {r3}
  548. 4b4: e92d0004 push {r2}
  549. 4b8: e92d0002 push {r1}
  550. 4bc: e92d0001 push {r0}
  551. 4c0: e3a0000f mov r0, #15
  552. 4c4: ef000040 svc 0x00000040
  553. 4c8: e8bd0002 pop {r1}
  554. 4cc: e8bd0002 pop {r1}
  555. 4d0: e8bd0004 pop {r2}
  556. 4d4: e8bd0008 pop {r3}
  557. 4d8: e8bd4000 pop {lr}
  558. 4dc: e12fff1e bx lr
  559. 000004e0 <mknod>:
  560. 4e0: e92d4000 push {lr}
  561. 4e4: e92d0008 push {r3}
  562. 4e8: e92d0004 push {r2}
  563. 4ec: e92d0002 push {r1}
  564. 4f0: e92d0001 push {r0}
  565. 4f4: e3a00011 mov r0, #17
  566. 4f8: ef000040 svc 0x00000040
  567. 4fc: e8bd0002 pop {r1}
  568. 500: e8bd0002 pop {r1}
  569. 504: e8bd0004 pop {r2}
  570. 508: e8bd0008 pop {r3}
  571. 50c: e8bd4000 pop {lr}
  572. 510: e12fff1e bx lr
  573. 00000514 <unlink>:
  574. 514: e92d4000 push {lr}
  575. 518: e92d0008 push {r3}
  576. 51c: e92d0004 push {r2}
  577. 520: e92d0002 push {r1}
  578. 524: e92d0001 push {r0}
  579. 528: e3a00012 mov r0, #18
  580. 52c: ef000040 svc 0x00000040
  581. 530: e8bd0002 pop {r1}
  582. 534: e8bd0002 pop {r1}
  583. 538: e8bd0004 pop {r2}
  584. 53c: e8bd0008 pop {r3}
  585. 540: e8bd4000 pop {lr}
  586. 544: e12fff1e bx lr
  587. 00000548 <fstat>:
  588. 548: e92d4000 push {lr}
  589. 54c: e92d0008 push {r3}
  590. 550: e92d0004 push {r2}
  591. 554: e92d0002 push {r1}
  592. 558: e92d0001 push {r0}
  593. 55c: e3a00008 mov r0, #8
  594. 560: ef000040 svc 0x00000040
  595. 564: e8bd0002 pop {r1}
  596. 568: e8bd0002 pop {r1}
  597. 56c: e8bd0004 pop {r2}
  598. 570: e8bd0008 pop {r3}
  599. 574: e8bd4000 pop {lr}
  600. 578: e12fff1e bx lr
  601. 0000057c <link>:
  602. 57c: e92d4000 push {lr}
  603. 580: e92d0008 push {r3}
  604. 584: e92d0004 push {r2}
  605. 588: e92d0002 push {r1}
  606. 58c: e92d0001 push {r0}
  607. 590: e3a00013 mov r0, #19
  608. 594: ef000040 svc 0x00000040
  609. 598: e8bd0002 pop {r1}
  610. 59c: e8bd0002 pop {r1}
  611. 5a0: e8bd0004 pop {r2}
  612. 5a4: e8bd0008 pop {r3}
  613. 5a8: e8bd4000 pop {lr}
  614. 5ac: e12fff1e bx lr
  615. 000005b0 <mkdir>:
  616. 5b0: e92d4000 push {lr}
  617. 5b4: e92d0008 push {r3}
  618. 5b8: e92d0004 push {r2}
  619. 5bc: e92d0002 push {r1}
  620. 5c0: e92d0001 push {r0}
  621. 5c4: e3a00014 mov r0, #20
  622. 5c8: ef000040 svc 0x00000040
  623. 5cc: e8bd0002 pop {r1}
  624. 5d0: e8bd0002 pop {r1}
  625. 5d4: e8bd0004 pop {r2}
  626. 5d8: e8bd0008 pop {r3}
  627. 5dc: e8bd4000 pop {lr}
  628. 5e0: e12fff1e bx lr
  629. 000005e4 <chdir>:
  630. 5e4: e92d4000 push {lr}
  631. 5e8: e92d0008 push {r3}
  632. 5ec: e92d0004 push {r2}
  633. 5f0: e92d0002 push {r1}
  634. 5f4: e92d0001 push {r0}
  635. 5f8: e3a00009 mov r0, #9
  636. 5fc: ef000040 svc 0x00000040
  637. 600: e8bd0002 pop {r1}
  638. 604: e8bd0002 pop {r1}
  639. 608: e8bd0004 pop {r2}
  640. 60c: e8bd0008 pop {r3}
  641. 610: e8bd4000 pop {lr}
  642. 614: e12fff1e bx lr
  643. 00000618 <dup>:
  644. 618: e92d4000 push {lr}
  645. 61c: e92d0008 push {r3}
  646. 620: e92d0004 push {r2}
  647. 624: e92d0002 push {r1}
  648. 628: e92d0001 push {r0}
  649. 62c: e3a0000a mov r0, #10
  650. 630: ef000040 svc 0x00000040
  651. 634: e8bd0002 pop {r1}
  652. 638: e8bd0002 pop {r1}
  653. 63c: e8bd0004 pop {r2}
  654. 640: e8bd0008 pop {r3}
  655. 644: e8bd4000 pop {lr}
  656. 648: e12fff1e bx lr
  657. 0000064c <getpid>:
  658. 64c: e92d4000 push {lr}
  659. 650: e92d0008 push {r3}
  660. 654: e92d0004 push {r2}
  661. 658: e92d0002 push {r1}
  662. 65c: e92d0001 push {r0}
  663. 660: e3a0000b mov r0, #11
  664. 664: ef000040 svc 0x00000040
  665. 668: e8bd0002 pop {r1}
  666. 66c: e8bd0002 pop {r1}
  667. 670: e8bd0004 pop {r2}
  668. 674: e8bd0008 pop {r3}
  669. 678: e8bd4000 pop {lr}
  670. 67c: e12fff1e bx lr
  671. 00000680 <sbrk>:
  672. 680: e92d4000 push {lr}
  673. 684: e92d0008 push {r3}
  674. 688: e92d0004 push {r2}
  675. 68c: e92d0002 push {r1}
  676. 690: e92d0001 push {r0}
  677. 694: e3a0000c mov r0, #12
  678. 698: ef000040 svc 0x00000040
  679. 69c: e8bd0002 pop {r1}
  680. 6a0: e8bd0002 pop {r1}
  681. 6a4: e8bd0004 pop {r2}
  682. 6a8: e8bd0008 pop {r3}
  683. 6ac: e8bd4000 pop {lr}
  684. 6b0: e12fff1e bx lr
  685. 000006b4 <sleep>:
  686. 6b4: e92d4000 push {lr}
  687. 6b8: e92d0008 push {r3}
  688. 6bc: e92d0004 push {r2}
  689. 6c0: e92d0002 push {r1}
  690. 6c4: e92d0001 push {r0}
  691. 6c8: e3a0000d mov r0, #13
  692. 6cc: ef000040 svc 0x00000040
  693. 6d0: e8bd0002 pop {r1}
  694. 6d4: e8bd0002 pop {r1}
  695. 6d8: e8bd0004 pop {r2}
  696. 6dc: e8bd0008 pop {r3}
  697. 6e0: e8bd4000 pop {lr}
  698. 6e4: e12fff1e bx lr
  699. 000006e8 <uptime>:
  700. 6e8: e92d4000 push {lr}
  701. 6ec: e92d0008 push {r3}
  702. 6f0: e92d0004 push {r2}
  703. 6f4: e92d0002 push {r1}
  704. 6f8: e92d0001 push {r0}
  705. 6fc: e3a0000e mov r0, #14
  706. 700: ef000040 svc 0x00000040
  707. 704: e8bd0002 pop {r1}
  708. 708: e8bd0002 pop {r1}
  709. 70c: e8bd0004 pop {r2}
  710. 710: e8bd0008 pop {r3}
  711. 714: e8bd4000 pop {lr}
  712. 718: e12fff1e bx lr
  713. 0000071c <putc>:
  714. #include "stat.h"
  715. #include "user.h"
  716. static void
  717. putc(int fd, char c)
  718. {
  719. 71c: e92d4800 push {fp, lr}
  720. 720: e28db004 add fp, sp, #4
  721. 724: e24b3004 sub r3, fp, #4
  722. 728: e24dd008 sub sp, sp, #8
  723. write(fd, &c, 1);
  724. 72c: e3a02001 mov r2, #1
  725. #include "stat.h"
  726. #include "user.h"
  727. static void
  728. putc(int fd, char c)
  729. {
  730. 730: e5631001 strb r1, [r3, #-1]!
  731. write(fd, &c, 1);
  732. 734: e1a01003 mov r1, r3
  733. 738: ebffff27 bl 3dc <write>
  734. }
  735. 73c: e24bd004 sub sp, fp, #4
  736. 740: e8bd8800 pop {fp, pc}
  737. 00000744 <printint>:
  738. return q;
  739. }
  740. static void
  741. printint(int fd, int xx, int base, int sgn)
  742. {
  743. 744: e92d4ff0 push {r4, r5, r6, r7, r8, r9, sl, fp, lr}
  744. 748: e1a04000 mov r4, r0
  745. char buf[16];
  746. int i, neg;
  747. uint x, y, b;
  748. neg = 0;
  749. if(sgn && xx < 0){
  750. 74c: e1a00fa1 lsr r0, r1, #31
  751. 750: e3530000 cmp r3, #0
  752. 754: 03a03000 moveq r3, #0
  753. 758: 12003001 andne r3, r0, #1
  754. return q;
  755. }
  756. static void
  757. printint(int fd, int xx, int base, int sgn)
  758. {
  759. 75c: e28db020 add fp, sp, #32
  760. char buf[16];
  761. int i, neg;
  762. uint x, y, b;
  763. neg = 0;
  764. if(sgn && xx < 0){
  765. 760: e3530000 cmp r3, #0
  766. return q;
  767. }
  768. static void
  769. printint(int fd, int xx, int base, int sgn)
  770. {
  771. 764: e24dd014 sub sp, sp, #20
  772. 768: e59f909c ldr r9, [pc, #156] ; 80c <printint+0xc8>
  773. uint x, y, b;
  774. neg = 0;
  775. if(sgn && xx < 0){
  776. neg = 1;
  777. x = -xx;
  778. 76c: 12611000 rsbne r1, r1, #0
  779. int i, neg;
  780. uint x, y, b;
  781. neg = 0;
  782. if(sgn && xx < 0){
  783. neg = 1;
  784. 770: 13a03001 movne r3, #1
  785. } else {
  786. x = xx;
  787. }
  788. b = base;
  789. i = 0;
  790. 774: e3a0a000 mov sl, #0
  791. 778: e24b6034 sub r6, fp, #52 ; 0x34
  792. for(i=31;i>=0;i--){
  793. r = r << 1;
  794. r = r | ((n >> i) & 1);
  795. if(r >= d) {
  796. r = r - d;
  797. q = q | (1 << i);
  798. 77c: e3a08001 mov r8, #1
  799. write(fd, &c, 1);
  800. }
  801. u32 div(u32 n, u32 d) // long division
  802. {
  803. u32 q=0, r=0;
  804. 780: e3a07000 mov r7, #0
  805. int i;
  806. for(i=31;i>=0;i--){
  807. 784: e3a0001f mov r0, #31
  808. write(fd, &c, 1);
  809. }
  810. u32 div(u32 n, u32 d) // long division
  811. {
  812. u32 q=0, r=0;
  813. 788: e1a0c007 mov ip, r7
  814. int i;
  815. for(i=31;i>=0;i--){
  816. r = r << 1;
  817. r = r | ((n >> i) & 1);
  818. 78c: e1a0e031 lsr lr, r1, r0
  819. 790: e20ee001 and lr, lr, #1
  820. 794: e18ec08c orr ip, lr, ip, lsl #1
  821. if(r >= d) {
  822. 798: e152000c cmp r2, ip
  823. r = r - d;
  824. q = q | (1 << i);
  825. 79c: 91877018 orrls r7, r7, r8, lsl r0
  826. for(i=31;i>=0;i--){
  827. r = r << 1;
  828. r = r | ((n >> i) & 1);
  829. if(r >= d) {
  830. r = r - d;
  831. 7a0: 9062c00c rsbls ip, r2, ip
  832. u32 div(u32 n, u32 d) // long division
  833. {
  834. u32 q=0, r=0;
  835. int i;
  836. for(i=31;i>=0;i--){
  837. 7a4: e2500001 subs r0, r0, #1
  838. 7a8: 2afffff7 bcs 78c <printint+0x48>
  839. b = base;
  840. i = 0;
  841. do{
  842. y = div(x, b);
  843. buf[i++] = digits[x - y * b];
  844. 7ac: e0000792 mul r0, r2, r7
  845. }while((x = y) != 0);
  846. 7b0: e3570000 cmp r7, #0
  847. b = base;
  848. i = 0;
  849. do{
  850. y = div(x, b);
  851. buf[i++] = digits[x - y * b];
  852. 7b4: e0601001 rsb r1, r0, r1
  853. 7b8: e28a5001 add r5, sl, #1
  854. 7bc: e7d91001 ldrb r1, [r9, r1]
  855. 7c0: e7c6100a strb r1, [r6, sl]
  856. }while((x = y) != 0);
  857. 7c4: 11a01007 movne r1, r7
  858. b = base;
  859. i = 0;
  860. do{
  861. y = div(x, b);
  862. buf[i++] = digits[x - y * b];
  863. 7c8: 11a0a005 movne sl, r5
  864. 7cc: 1affffeb bne 780 <printint+0x3c>
  865. }while((x = y) != 0);
  866. if(neg)
  867. 7d0: e3530000 cmp r3, #0
  868. buf[i++] = '-';
  869. 7d4: 124b2024 subne r2, fp, #36 ; 0x24
  870. 7d8: 10823005 addne r3, r2, r5
  871. 7dc: 128a5002 addne r5, sl, #2
  872. while(--i >= 0)
  873. 7e0: e2455001 sub r5, r5, #1
  874. do{
  875. y = div(x, b);
  876. buf[i++] = digits[x - y * b];
  877. }while((x = y) != 0);
  878. if(neg)
  879. buf[i++] = '-';
  880. 7e4: 13a0202d movne r2, #45 ; 0x2d
  881. 7e8: 15432010 strbne r2, [r3, #-16]
  882. while(--i >= 0)
  883. putc(fd, buf[i]);
  884. 7ec: e7d61005 ldrb r1, [r6, r5]
  885. 7f0: e1a00004 mov r0, r4
  886. buf[i++] = digits[x - y * b];
  887. }while((x = y) != 0);
  888. if(neg)
  889. buf[i++] = '-';
  890. while(--i >= 0)
  891. 7f4: e2455001 sub r5, r5, #1
  892. putc(fd, buf[i]);
  893. 7f8: ebffffc7 bl 71c <putc>
  894. buf[i++] = digits[x - y * b];
  895. }while((x = y) != 0);
  896. if(neg)
  897. buf[i++] = '-';
  898. while(--i >= 0)
  899. 7fc: e3750001 cmn r5, #1
  900. 800: 1afffff9 bne 7ec <printint+0xa8>
  901. putc(fd, buf[i]);
  902. }
  903. 804: e24bd020 sub sp, fp, #32
  904. 808: e8bd8ff0 pop {r4, r5, r6, r7, r8, r9, sl, fp, pc}
  905. 80c: 00000b50 .word 0x00000b50
  906. 00000810 <div>:
  907. write(fd, &c, 1);
  908. }
  909. u32 div(u32 n, u32 d) // long division
  910. {
  911. u32 q=0, r=0;
  912. 810: e3a03000 mov r3, #0
  913. {
  914. write(fd, &c, 1);
  915. }
  916. u32 div(u32 n, u32 d) // long division
  917. {
  918. 814: e92d0830 push {r4, r5, fp}
  919. 818: e1a02000 mov r2, r0
  920. 81c: e28db008 add fp, sp, #8
  921. u32 q=0, r=0;
  922. int i;
  923. for(i=31;i>=0;i--){
  924. 820: e3a0c01f mov ip, #31
  925. write(fd, &c, 1);
  926. }
  927. u32 div(u32 n, u32 d) // long division
  928. {
  929. u32 q=0, r=0;
  930. 824: e1a00003 mov r0, r3
  931. for(i=31;i>=0;i--){
  932. r = r << 1;
  933. r = r | ((n >> i) & 1);
  934. if(r >= d) {
  935. r = r - d;
  936. q = q | (1 << i);
  937. 828: e3a05001 mov r5, #1
  938. u32 q=0, r=0;
  939. int i;
  940. for(i=31;i>=0;i--){
  941. r = r << 1;
  942. r = r | ((n >> i) & 1);
  943. 82c: e1a04c32 lsr r4, r2, ip
  944. 830: e2044001 and r4, r4, #1
  945. 834: e1843083 orr r3, r4, r3, lsl #1
  946. if(r >= d) {
  947. 838: e1530001 cmp r3, r1
  948. r = r - d;
  949. q = q | (1 << i);
  950. 83c: 21800c15 orrcs r0, r0, r5, lsl ip
  951. for(i=31;i>=0;i--){
  952. r = r << 1;
  953. r = r | ((n >> i) & 1);
  954. if(r >= d) {
  955. r = r - d;
  956. 840: 20613003 rsbcs r3, r1, r3
  957. u32 div(u32 n, u32 d) // long division
  958. {
  959. u32 q=0, r=0;
  960. int i;
  961. for(i=31;i>=0;i--){
  962. 844: e25cc001 subs ip, ip, #1
  963. 848: 2afffff7 bcs 82c <div+0x1c>
  964. r = r - d;
  965. q = q | (1 << i);
  966. }
  967. }
  968. return q;
  969. }
  970. 84c: e24bd008 sub sp, fp, #8
  971. 850: e8bd0830 pop {r4, r5, fp}
  972. 854: e12fff1e bx lr
  973. 00000858 <printf>:
  974. }
  975. // Print to the given fd. Only understands %d, %x, %p, %s.
  976. void
  977. printf(int fd, char *fmt, ...)
  978. {
  979. 858: e92d000e push {r1, r2, r3}
  980. 85c: e92d4ff0 push {r4, r5, r6, r7, r8, r9, sl, fp, lr}
  981. 860: e28db020 add fp, sp, #32
  982. 864: e1a05000 mov r5, r0
  983. int c, i, state;
  984. uint *ap;
  985. state = 0;
  986. ap = (uint*)(void*)&fmt + 1;
  987. for(i = 0; fmt[i]; i++){
  988. 868: e59b4004 ldr r4, [fp, #4]
  989. 86c: e5d48000 ldrb r8, [r4]
  990. 870: e3580000 cmp r8, #0
  991. 874: 0a000027 beq 918 <printf+0xc0>
  992. ap++;
  993. } else if(c == 's'){
  994. s = (char*)*ap;
  995. ap++;
  996. if(s == 0)
  997. s = "(null)";
  998. 878: e59f712c ldr r7, [pc, #300] ; 9ac <printf+0x154>
  999. char *s;
  1000. int c, i, state;
  1001. uint *ap;
  1002. state = 0;
  1003. ap = (uint*)(void*)&fmt + 1;
  1004. 87c: e28b6008 add r6, fp, #8
  1005. {
  1006. char *s;
  1007. int c, i, state;
  1008. uint *ap;
  1009. state = 0;
  1010. 880: e3a0a000 mov sl, #0
  1011. 884: ea000008 b 8ac <printf+0x54>
  1012. ap = (uint*)(void*)&fmt + 1;
  1013. for(i = 0; fmt[i]; i++){
  1014. c = fmt[i] & 0xff;
  1015. if(state == 0){
  1016. if(c == '%'){
  1017. 888: e3580025 cmp r8, #37 ; 0x25
  1018. state = '%';
  1019. 88c: 01a0a008 moveq sl, r8
  1020. state = 0;
  1021. ap = (uint*)(void*)&fmt + 1;
  1022. for(i = 0; fmt[i]; i++){
  1023. c = fmt[i] & 0xff;
  1024. if(state == 0){
  1025. if(c == '%'){
  1026. 890: 0a000002 beq 8a0 <printf+0x48>
  1027. state = '%';
  1028. } else {
  1029. putc(fd, c);
  1030. 894: e1a00005 mov r0, r5
  1031. 898: e1a01008 mov r1, r8
  1032. 89c: ebffff9e bl 71c <putc>
  1033. int c, i, state;
  1034. uint *ap;
  1035. state = 0;
  1036. ap = (uint*)(void*)&fmt + 1;
  1037. for(i = 0; fmt[i]; i++){
  1038. 8a0: e5f48001 ldrb r8, [r4, #1]!
  1039. 8a4: e3580000 cmp r8, #0
  1040. 8a8: 0a00001a beq 918 <printf+0xc0>
  1041. c = fmt[i] & 0xff;
  1042. if(state == 0){
  1043. 8ac: e35a0000 cmp sl, #0
  1044. 8b0: 0afffff4 beq 888 <printf+0x30>
  1045. if(c == '%'){
  1046. state = '%';
  1047. } else {
  1048. putc(fd, c);
  1049. }
  1050. } else if(state == '%'){
  1051. 8b4: e35a0025 cmp sl, #37 ; 0x25
  1052. 8b8: 1afffff8 bne 8a0 <printf+0x48>
  1053. if(c == 'd'){
  1054. 8bc: e3580064 cmp r8, #100 ; 0x64
  1055. 8c0: 0a00002c beq 978 <printf+0x120>
  1056. printint(fd, *ap, 10, 1);
  1057. ap++;
  1058. } else if(c == 'x' || c == 'p'){
  1059. 8c4: e3580078 cmp r8, #120 ; 0x78
  1060. 8c8: 13580070 cmpne r8, #112 ; 0x70
  1061. 8cc: 13a09000 movne r9, #0
  1062. 8d0: 03a09001 moveq r9, #1
  1063. 8d4: 0a000013 beq 928 <printf+0xd0>
  1064. printint(fd, *ap, 16, 0);
  1065. ap++;
  1066. } else if(c == 's'){
  1067. 8d8: e3580073 cmp r8, #115 ; 0x73
  1068. 8dc: 0a000018 beq 944 <printf+0xec>
  1069. s = "(null)";
  1070. while(*s != 0){
  1071. putc(fd, *s);
  1072. s++;
  1073. }
  1074. } else if(c == 'c'){
  1075. 8e0: e3580063 cmp r8, #99 ; 0x63
  1076. 8e4: 0a00002a beq 994 <printf+0x13c>
  1077. putc(fd, *ap);
  1078. ap++;
  1079. } else if(c == '%'){
  1080. 8e8: e3580025 cmp r8, #37 ; 0x25
  1081. putc(fd, c);
  1082. 8ec: e1a0100a mov r1, sl
  1083. 8f0: e1a00005 mov r0, r5
  1084. s++;
  1085. }
  1086. } else if(c == 'c'){
  1087. putc(fd, *ap);
  1088. ap++;
  1089. } else if(c == '%'){
  1090. 8f4: 0a000002 beq 904 <printf+0xac>
  1091. putc(fd, c);
  1092. } else {
  1093. // Unknown % sequence. Print it to draw attention.
  1094. putc(fd, '%');
  1095. 8f8: ebffff87 bl 71c <putc>
  1096. putc(fd, c);
  1097. 8fc: e1a00005 mov r0, r5
  1098. 900: e1a01008 mov r1, r8
  1099. 904: ebffff84 bl 71c <putc>
  1100. int c, i, state;
  1101. uint *ap;
  1102. state = 0;
  1103. ap = (uint*)(void*)&fmt + 1;
  1104. for(i = 0; fmt[i]; i++){
  1105. 908: e5f48001 ldrb r8, [r4, #1]!
  1106. } else {
  1107. // Unknown % sequence. Print it to draw attention.
  1108. putc(fd, '%');
  1109. putc(fd, c);
  1110. }
  1111. state = 0;
  1112. 90c: e1a0a009 mov sl, r9
  1113. int c, i, state;
  1114. uint *ap;
  1115. state = 0;
  1116. ap = (uint*)(void*)&fmt + 1;
  1117. for(i = 0; fmt[i]; i++){
  1118. 910: e3580000 cmp r8, #0
  1119. 914: 1affffe4 bne 8ac <printf+0x54>
  1120. putc(fd, c);
  1121. }
  1122. state = 0;
  1123. }
  1124. }
  1125. }
  1126. 918: e24bd020 sub sp, fp, #32
  1127. 91c: e8bd4ff0 pop {r4, r5, r6, r7, r8, r9, sl, fp, lr}
  1128. 920: e28dd00c add sp, sp, #12
  1129. 924: e12fff1e bx lr
  1130. } else if(state == '%'){
  1131. if(c == 'd'){
  1132. printint(fd, *ap, 10, 1);
  1133. ap++;
  1134. } else if(c == 'x' || c == 'p'){
  1135. printint(fd, *ap, 16, 0);
  1136. 928: e1a00005 mov r0, r5
  1137. 92c: e4961004 ldr r1, [r6], #4
  1138. 930: e3a02010 mov r2, #16
  1139. 934: e3a03000 mov r3, #0
  1140. 938: ebffff81 bl 744 <printint>
  1141. } else {
  1142. // Unknown % sequence. Print it to draw attention.
  1143. putc(fd, '%');
  1144. putc(fd, c);
  1145. }
  1146. state = 0;
  1147. 93c: e3a0a000 mov sl, #0
  1148. 940: eaffffd6 b 8a0 <printf+0x48>
  1149. ap++;
  1150. } else if(c == 'x' || c == 'p'){
  1151. printint(fd, *ap, 16, 0);
  1152. ap++;
  1153. } else if(c == 's'){
  1154. s = (char*)*ap;
  1155. 944: e4968004 ldr r8, [r6], #4
  1156. ap++;
  1157. if(s == 0)
  1158. s = "(null)";
  1159. 948: e3580000 cmp r8, #0
  1160. 94c: 01a08007 moveq r8, r7
  1161. while(*s != 0){
  1162. 950: e5d81000 ldrb r1, [r8]
  1163. 954: e3510000 cmp r1, #0
  1164. 958: 0a000004 beq 970 <printf+0x118>
  1165. putc(fd, *s);
  1166. 95c: e1a00005 mov r0, r5
  1167. 960: ebffff6d bl 71c <putc>
  1168. } else if(c == 's'){
  1169. s = (char*)*ap;
  1170. ap++;
  1171. if(s == 0)
  1172. s = "(null)";
  1173. while(*s != 0){
  1174. 964: e5f81001 ldrb r1, [r8, #1]!
  1175. 968: e3510000 cmp r1, #0
  1176. 96c: 1afffffa bne 95c <printf+0x104>
  1177. } else {
  1178. // Unknown % sequence. Print it to draw attention.
  1179. putc(fd, '%');
  1180. putc(fd, c);
  1181. }
  1182. state = 0;
  1183. 970: e1a0a001 mov sl, r1
  1184. 974: eaffffc9 b 8a0 <printf+0x48>
  1185. } else {
  1186. putc(fd, c);
  1187. }
  1188. } else if(state == '%'){
  1189. if(c == 'd'){
  1190. printint(fd, *ap, 10, 1);
  1191. 978: e1a00005 mov r0, r5
  1192. 97c: e4961004 ldr r1, [r6], #4
  1193. 980: e3a0200a mov r2, #10
  1194. 984: e3a03001 mov r3, #1
  1195. 988: ebffff6d bl 744 <printint>
  1196. } else {
  1197. // Unknown % sequence. Print it to draw attention.
  1198. putc(fd, '%');
  1199. putc(fd, c);
  1200. }
  1201. state = 0;
  1202. 98c: e3a0a000 mov sl, #0
  1203. 990: eaffffc2 b 8a0 <printf+0x48>
  1204. while(*s != 0){
  1205. putc(fd, *s);
  1206. s++;
  1207. }
  1208. } else if(c == 'c'){
  1209. putc(fd, *ap);
  1210. 994: e4961004 ldr r1, [r6], #4
  1211. 998: e1a00005 mov r0, r5
  1212. } else {
  1213. // Unknown % sequence. Print it to draw attention.
  1214. putc(fd, '%');
  1215. putc(fd, c);
  1216. }
  1217. state = 0;
  1218. 99c: e1a0a009 mov sl, r9
  1219. while(*s != 0){
  1220. putc(fd, *s);
  1221. s++;
  1222. }
  1223. } else if(c == 'c'){
  1224. putc(fd, *ap);
  1225. 9a0: e6ef1071 uxtb r1, r1
  1226. 9a4: ebffff5c bl 71c <putc>
  1227. 9a8: eaffffbc b 8a0 <printf+0x48>
  1228. 9ac: 00000b64 .word 0x00000b64
  1229. 000009b0 <free>:
  1230. free(void *ap)
  1231. {
  1232. Header *bp, *p;
  1233. bp = (Header*)ap - 1;
  1234. for(p = freep; !(bp > p && bp < p->s.ptr); p = p->s.ptr)
  1235. 9b0: e59f3098 ldr r3, [pc, #152] ; a50 <free+0xa0>
  1236. static Header base;
  1237. static Header *freep;
  1238. void
  1239. free(void *ap)
  1240. {
  1241. 9b4: e92d0830 push {r4, r5, fp}
  1242. Header *bp, *p;
  1243. bp = (Header*)ap - 1;
  1244. 9b8: e240c008 sub ip, r0, #8
  1245. for(p = freep; !(bp > p && bp < p->s.ptr); p = p->s.ptr)
  1246. 9bc: e5932000 ldr r2, [r3]
  1247. static Header base;
  1248. static Header *freep;
  1249. void
  1250. free(void *ap)
  1251. {
  1252. 9c0: e28db008 add fp, sp, #8
  1253. Header *bp, *p;
  1254. bp = (Header*)ap - 1;
  1255. for(p = freep; !(bp > p && bp < p->s.ptr); p = p->s.ptr)
  1256. 9c4: e152000c cmp r2, ip
  1257. 9c8: e5921000 ldr r1, [r2]
  1258. 9cc: 2a000001 bcs 9d8 <free+0x28>
  1259. 9d0: e15c0001 cmp ip, r1
  1260. 9d4: 3a000007 bcc 9f8 <free+0x48>
  1261. if(p >= p->s.ptr && (bp > p || bp < p->s.ptr))
  1262. 9d8: e1520001 cmp r2, r1
  1263. 9dc: 3a000003 bcc 9f0 <free+0x40>
  1264. 9e0: e152000c cmp r2, ip
  1265. 9e4: 3a000003 bcc 9f8 <free+0x48>
  1266. 9e8: e15c0001 cmp ip, r1
  1267. 9ec: 3a000001 bcc 9f8 <free+0x48>
  1268. static Header base;
  1269. static Header *freep;
  1270. void
  1271. free(void *ap)
  1272. {
  1273. 9f0: e1a02001 mov r2, r1
  1274. 9f4: eafffff2 b 9c4 <free+0x14>
  1275. bp = (Header*)ap - 1;
  1276. for(p = freep; !(bp > p && bp < p->s.ptr); p = p->s.ptr)
  1277. if(p >= p->s.ptr && (bp > p || bp < p->s.ptr))
  1278. break;
  1279. if(bp + bp->s.size == p->s.ptr){
  1280. 9f8: e5104004 ldr r4, [r0, #-4]
  1281. if(p + p->s.size == bp){
  1282. p->s.size += bp->s.size;
  1283. p->s.ptr = bp->s.ptr;
  1284. } else
  1285. p->s.ptr = bp;
  1286. freep = p;
  1287. 9fc: e5832000 str r2, [r3]
  1288. bp = (Header*)ap - 1;
  1289. for(p = freep; !(bp > p && bp < p->s.ptr); p = p->s.ptr)
  1290. if(p >= p->s.ptr && (bp > p || bp < p->s.ptr))
  1291. break;
  1292. if(bp + bp->s.size == p->s.ptr){
  1293. a00: e08c5184 add r5, ip, r4, lsl #3
  1294. a04: e1550001 cmp r5, r1
  1295. bp->s.size += p->s.ptr->s.size;
  1296. a08: 05911004 ldreq r1, [r1, #4]
  1297. a0c: 00814004 addeq r4, r1, r4
  1298. a10: 05004004 streq r4, [r0, #-4]
  1299. bp->s.ptr = p->s.ptr->s.ptr;
  1300. a14: 05921000 ldreq r1, [r2]
  1301. a18: 05911000 ldreq r1, [r1]
  1302. } else
  1303. bp->s.ptr = p->s.ptr;
  1304. a1c: e5001008 str r1, [r0, #-8]
  1305. if(p + p->s.size == bp){
  1306. a20: e5921004 ldr r1, [r2, #4]
  1307. a24: e0824181 add r4, r2, r1, lsl #3
  1308. a28: e15c0004 cmp ip, r4
  1309. p->s.size += bp->s.size;
  1310. p->s.ptr = bp->s.ptr;
  1311. } else
  1312. p->s.ptr = bp;
  1313. a2c: 1582c000 strne ip, [r2]
  1314. bp->s.size += p->s.ptr->s.size;
  1315. bp->s.ptr = p->s.ptr->s.ptr;
  1316. } else
  1317. bp->s.ptr = p->s.ptr;
  1318. if(p + p->s.size == bp){
  1319. p->s.size += bp->s.size;
  1320. a30: 0510c004 ldreq ip, [r0, #-4]
  1321. a34: 008c1001 addeq r1, ip, r1
  1322. a38: 05821004 streq r1, [r2, #4]
  1323. p->s.ptr = bp->s.ptr;
  1324. a3c: 05101008 ldreq r1, [r0, #-8]
  1325. a40: 05821000 streq r1, [r2]
  1326. } else
  1327. p->s.ptr = bp;
  1328. freep = p;
  1329. }
  1330. a44: e24bd008 sub sp, fp, #8
  1331. a48: e8bd0830 pop {r4, r5, fp}
  1332. a4c: e12fff1e bx lr
  1333. a50: 00000b6c .word 0x00000b6c
  1334. 00000a54 <malloc>:
  1335. return freep;
  1336. }
  1337. void*
  1338. malloc(uint nbytes)
  1339. {
  1340. a54: e92d49f8 push {r3, r4, r5, r6, r7, r8, fp, lr}
  1341. Header *p, *prevp;
  1342. uint nunits;
  1343. nunits = (nbytes + sizeof(Header) - 1)/sizeof(Header) + 1;
  1344. a58: e2804007 add r4, r0, #7
  1345. if((prevp = freep) == 0){
  1346. a5c: e59f50d4 ldr r5, [pc, #212] ; b38 <malloc+0xe4>
  1347. malloc(uint nbytes)
  1348. {
  1349. Header *p, *prevp;
  1350. uint nunits;
  1351. nunits = (nbytes + sizeof(Header) - 1)/sizeof(Header) + 1;
  1352. a60: e1a041a4 lsr r4, r4, #3
  1353. return freep;
  1354. }
  1355. void*
  1356. malloc(uint nbytes)
  1357. {
  1358. a64: e28db01c add fp, sp, #28
  1359. Header *p, *prevp;
  1360. uint nunits;
  1361. nunits = (nbytes + sizeof(Header) - 1)/sizeof(Header) + 1;
  1362. if((prevp = freep) == 0){
  1363. a68: e5953000 ldr r3, [r5]
  1364. malloc(uint nbytes)
  1365. {
  1366. Header *p, *prevp;
  1367. uint nunits;
  1368. nunits = (nbytes + sizeof(Header) - 1)/sizeof(Header) + 1;
  1369. a6c: e2844001 add r4, r4, #1
  1370. if((prevp = freep) == 0){
  1371. a70: e3530000 cmp r3, #0
  1372. a74: 0a00002b beq b28 <malloc+0xd4>
  1373. a78: e5930000 ldr r0, [r3]
  1374. a7c: e5902004 ldr r2, [r0, #4]
  1375. base.s.ptr = freep = prevp = &base;
  1376. base.s.size = 0;
  1377. }
  1378. for(p = prevp->s.ptr; ; prevp = p, p = p->s.ptr){
  1379. if(p->s.size >= nunits){
  1380. a80: e1520004 cmp r2, r4
  1381. a84: 2a00001b bcs af8 <malloc+0xa4>
  1382. morecore(uint nu)
  1383. {
  1384. char *p;
  1385. Header *hp;
  1386. if(nu < 4096)
  1387. a88: e59f80ac ldr r8, [pc, #172] ; b3c <malloc+0xe8>
  1388. p->s.size -= nunits;
  1389. p += p->s.size;
  1390. p->s.size = nunits;
  1391. }
  1392. freep = prevp;
  1393. return (void*)(p + 1);
  1394. a8c: e1a07184 lsl r7, r4, #3
  1395. a90: ea000003 b aa4 <malloc+0x50>
  1396. nunits = (nbytes + sizeof(Header) - 1)/sizeof(Header) + 1;
  1397. if((prevp = freep) == 0){
  1398. base.s.ptr = freep = prevp = &base;
  1399. base.s.size = 0;
  1400. }
  1401. for(p = prevp->s.ptr; ; prevp = p, p = p->s.ptr){
  1402. a94: e5930000 ldr r0, [r3]
  1403. if(p->s.size >= nunits){
  1404. a98: e5902004 ldr r2, [r0, #4]
  1405. a9c: e1540002 cmp r4, r2
  1406. aa0: 9a000014 bls af8 <malloc+0xa4>
  1407. p->s.size = nunits;
  1408. }
  1409. freep = prevp;
  1410. return (void*)(p + 1);
  1411. }
  1412. if(p == freep)
  1413. aa4: e5952000 ldr r2, [r5]
  1414. aa8: e1a03000 mov r3, r0
  1415. aac: e1500002 cmp r0, r2
  1416. ab0: 1afffff7 bne a94 <malloc+0x40>
  1417. morecore(uint nu)
  1418. {
  1419. char *p;
  1420. Header *hp;
  1421. if(nu < 4096)
  1422. ab4: e1540008 cmp r4, r8
  1423. nu = 4096;
  1424. p = sbrk(nu * sizeof(Header));
  1425. ab8: 81a00007 movhi r0, r7
  1426. abc: 93a00902 movls r0, #32768 ; 0x8000
  1427. morecore(uint nu)
  1428. {
  1429. char *p;
  1430. Header *hp;
  1431. if(nu < 4096)
  1432. ac0: 81a06004 movhi r6, r4
  1433. ac4: 93a06a01 movls r6, #4096 ; 0x1000
  1434. nu = 4096;
  1435. p = sbrk(nu * sizeof(Header));
  1436. ac8: ebfffeec bl 680 <sbrk>
  1437. acc: e1a03000 mov r3, r0
  1438. if(p == (char*)-1)
  1439. ad0: e3730001 cmn r3, #1
  1440. return 0;
  1441. hp = (Header*)p;
  1442. hp->s.size = nu;
  1443. free((void*)(hp + 1));
  1444. ad4: e2800008 add r0, r0, #8
  1445. Header *hp;
  1446. if(nu < 4096)
  1447. nu = 4096;
  1448. p = sbrk(nu * sizeof(Header));
  1449. if(p == (char*)-1)
  1450. ad8: 0a000010 beq b20 <malloc+0xcc>
  1451. return 0;
  1452. hp = (Header*)p;
  1453. hp->s.size = nu;
  1454. adc: e5836004 str r6, [r3, #4]
  1455. free((void*)(hp + 1));
  1456. ae0: ebffffb2 bl 9b0 <free>
  1457. return freep;
  1458. ae4: e5953000 ldr r3, [r5]
  1459. }
  1460. freep = prevp;
  1461. return (void*)(p + 1);
  1462. }
  1463. if(p == freep)
  1464. if((p = morecore(nunits)) == 0)
  1465. ae8: e3530000 cmp r3, #0
  1466. aec: 1affffe8 bne a94 <malloc+0x40>
  1467. return 0;
  1468. af0: e1a00003 mov r0, r3
  1469. }
  1470. }
  1471. af4: e8bd89f8 pop {r3, r4, r5, r6, r7, r8, fp, pc}
  1472. base.s.ptr = freep = prevp = &base;
  1473. base.s.size = 0;
  1474. }
  1475. for(p = prevp->s.ptr; ; prevp = p, p = p->s.ptr){
  1476. if(p->s.size >= nunits){
  1477. if(p->s.size == nunits)
  1478. af8: e1540002 cmp r4, r2
  1479. prevp->s.ptr = p->s.ptr;
  1480. else {
  1481. p->s.size -= nunits;
  1482. afc: 10642002 rsbne r2, r4, r2
  1483. b00: 15802004 strne r2, [r0, #4]
  1484. base.s.size = 0;
  1485. }
  1486. for(p = prevp->s.ptr; ; prevp = p, p = p->s.ptr){
  1487. if(p->s.size >= nunits){
  1488. if(p->s.size == nunits)
  1489. prevp->s.ptr = p->s.ptr;
  1490. b04: 05902000 ldreq r2, [r0]
  1491. else {
  1492. p->s.size -= nunits;
  1493. p += p->s.size;
  1494. b08: 10800182 addne r0, r0, r2, lsl #3
  1495. base.s.size = 0;
  1496. }
  1497. for(p = prevp->s.ptr; ; prevp = p, p = p->s.ptr){
  1498. if(p->s.size >= nunits){
  1499. if(p->s.size == nunits)
  1500. prevp->s.ptr = p->s.ptr;
  1501. b0c: 05832000 streq r2, [r3]
  1502. else {
  1503. p->s.size -= nunits;
  1504. p += p->s.size;
  1505. p->s.size = nunits;
  1506. b10: 15804004 strne r4, [r0, #4]
  1507. }
  1508. freep = prevp;
  1509. b14: e5853000 str r3, [r5]
  1510. return (void*)(p + 1);
  1511. b18: e2800008 add r0, r0, #8
  1512. b1c: e8bd89f8 pop {r3, r4, r5, r6, r7, r8, fp, pc}
  1513. }
  1514. if(p == freep)
  1515. if((p = morecore(nunits)) == 0)
  1516. return 0;
  1517. b20: e3a00000 mov r0, #0
  1518. b24: e8bd89f8 pop {r3, r4, r5, r6, r7, r8, fp, pc}
  1519. Header *p, *prevp;
  1520. uint nunits;
  1521. nunits = (nbytes + sizeof(Header) - 1)/sizeof(Header) + 1;
  1522. if((prevp = freep) == 0){
  1523. base.s.ptr = freep = prevp = &base;
  1524. b28: e2850004 add r0, r5, #4
  1525. b2c: e5850000 str r0, [r5]
  1526. base.s.size = 0;
  1527. b30: e9850009 stmib r5, {r0, r3}
  1528. b34: eaffffd3 b a88 <malloc+0x34>
  1529. b38: 00000b6c .word 0x00000b6c
  1530. b3c: 00000fff .word 0x00000fff