12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997 |
- _ls: file format elf32-littlearm
- Disassembly of section .text:
- 00000000 <main>:
- int
- main(int argc, char *argv[])
- {
- int i;
- if(argc < 2){
- 0: e3500001 cmp r0, #1
- close(fd);
- }
- int
- main(int argc, char *argv[])
- {
- 4: e92d4878 push {r3, r4, r5, r6, fp, lr}
- 8: e1a04000 mov r4, r0
- c: e28db014 add fp, sp, #20
- int i;
- if(argc < 2){
- ls(".");
- exit();
- 10: c1a06001 movgt r6, r1
- int
- main(int argc, char *argv[])
- {
- int i;
- if(argc < 2){
- 14: c3a05001 movgt r5, #1
- 18: da000005 ble 34 <main+0x34>
- ls(".");
- exit();
- }
- for(i=1; i<argc; i++)
- ls(argv[i]);
- 1c: e5b60004 ldr r0, [r6, #4]!
- if(argc < 2){
- ls(".");
- exit();
- }
- for(i=1; i<argc; i++)
- 20: e2855001 add r5, r5, #1
- ls(argv[i]);
- 24: eb000030 bl ec <ls>
- if(argc < 2){
- ls(".");
- exit();
- }
- for(i=1; i<argc; i++)
- 28: e1550004 cmp r5, r4
- 2c: 1afffffa bne 1c <main+0x1c>
- ls(argv[i]);
- exit();
- 30: eb00013e bl 530 <exit>
- main(int argc, char *argv[])
- {
- int i;
- if(argc < 2){
- ls(".");
- 34: e59f0004 ldr r0, [pc, #4] ; 40 <main+0x40>
- 38: eb00002b bl ec <ls>
- exit();
- 3c: eb00013b bl 530 <exit>
- 40: 00000db0 .word 0x00000db0
- 00000044 <fmtname>:
- #include "user.h"
- #include "fs.h"
- char*
- fmtname(char *path)
- {
- 44: e92d4878 push {r3, r4, r5, r6, fp, lr}
- 48: e28db014 add fp, sp, #20
- 4c: e1a05000 mov r5, r0
- static char buf[DIRSIZ+1];
- char *p;
-
- // Find first character after last slash.
- for(p=path+strlen(path); p >= path && *p != '/'; p--)
- 50: eb0000ab bl 304 <strlen>
- 54: e0954000 adds r4, r5, r0
- 58: 2a00000a bcs 88 <fmtname+0x44>
- 5c: e7d53000 ldrb r3, [r5, r0]
- 60: e353002f cmp r3, #47 ; 0x2f
- 64: 0a000007 beq 88 <fmtname+0x44>
- 68: e1a03004 mov r3, r4
- 6c: ea000002 b 7c <fmtname+0x38>
- 70: e5732001 ldrb r2, [r3, #-1]!
- 74: e352002f cmp r2, #47 ; 0x2f
- 78: 0a000002 beq 88 <fmtname+0x44>
- 7c: e2444001 sub r4, r4, #1
- 80: e1550004 cmp r5, r4
- 84: 9afffff9 bls 70 <fmtname+0x2c>
- ;
- p++;
- 88: e2844001 add r4, r4, #1
-
- // Return blank-padded name.
- if(strlen(p) >= DIRSIZ)
- 8c: e1a00004 mov r0, r4
- 90: eb00009b bl 304 <strlen>
- 94: e350000d cmp r0, #13
- 98: 8a000010 bhi e0 <fmtname+0x9c>
- return p;
- memmove(buf, p, strlen(p));
- 9c: e1a00004 mov r0, r4
- a0: eb000097 bl 304 <strlen>
- a4: e59f503c ldr r5, [pc, #60] ; e8 <fmtname+0xa4>
- a8: e1a01004 mov r1, r4
- ac: e1a02000 mov r2, r0
- b0: e1a00005 mov r0, r5
- b4: eb000103 bl 4c8 <memmove>
- memset(buf+strlen(p), ' ', DIRSIZ-strlen(p));
- b8: e1a00004 mov r0, r4
- bc: eb000090 bl 304 <strlen>
- c0: e1a06000 mov r6, r0
- c4: e1a00004 mov r0, r4
- c8: eb00008d bl 304 <strlen>
- cc: e3a01020 mov r1, #32
- return buf;
- d0: e1a04005 mov r4, r5
-
- // Return blank-padded name.
- if(strlen(p) >= DIRSIZ)
- return p;
- memmove(buf, p, strlen(p));
- memset(buf+strlen(p), ' ', DIRSIZ-strlen(p));
- d4: e260200e rsb r2, r0, #14
- d8: e0850006 add r0, r5, r6
- dc: eb000098 bl 344 <memset>
- return buf;
- }
- e0: e1a00004 mov r0, r4
- e4: e8bd8878 pop {r3, r4, r5, r6, fp, pc}
- e8: 00000dd0 .word 0x00000dd0
- 000000ec <ls>:
- void
- ls(char *path)
- {
- ec: e92d49f0 push {r4, r5, r6, r7, r8, fp, lr}
- f0: e28db018 add fp, sp, #24
- f4: e24ddf8d sub sp, sp, #564 ; 0x234
- char buf[512], *p;
- int fd;
- struct dirent de;
- struct stat st;
-
- if((fd = open(path, 0)) < 0){
- f8: e3a01000 mov r1, #0
- return buf;
- }
- void
- ls(char *path)
- {
- fc: e1a06000 mov r6, r0
- char buf[512], *p;
- int fd;
- struct dirent de;
- struct stat st;
-
- if((fd = open(path, 0)) < 0){
- 100: eb000172 bl 6d0 <open>
- 104: e2504000 subs r4, r0, #0
- 108: ba00004b blt 23c <ls+0x150>
- printf(2, "ls: cannot open %s\n", path);
- return;
- }
-
- if(fstat(fd, &st) < 0){
- 10c: e24b1040 sub r1, fp, #64 ; 0x40
- 110: eb000195 bl 76c <fstat>
- 114: e3500000 cmp r0, #0
- 118: ba000051 blt 264 <ls+0x178>
- printf(2, "ls: cannot stat %s\n", path);
- close(fd);
- return;
- }
-
- switch(st.type){
- 11c: e15b54f0 ldrsh r5, [fp, #-64] ; 0xffffffc0
- 120: e3550001 cmp r5, #1
- 124: 0a000011 beq 170 <ls+0x84>
- 128: e3550002 cmp r5, #2
- 12c: 0a000003 beq 140 <ls+0x54>
- }
- printf(1, "%s %d %d %d\n", fmtname(buf), st.type, st.ino, st.size);
- }
- break;
- }
- close(fd);
- 130: e1a00004 mov r0, r4
- 134: eb00013e bl 634 <close>
- }
- 138: e24bd018 sub sp, fp, #24
- 13c: e8bd89f0 pop {r4, r5, r6, r7, r8, fp, pc}
- return;
- }
-
- switch(st.type){
- case T_FILE:
- printf(1, "%s %d %d %d\n", fmtname(path), st.type, st.ino, st.size);
- 140: e1a00006 mov r0, r6
- 144: ebffffbe bl 44 <fmtname>
- 148: e51bc038 ldr ip, [fp, #-56] ; 0x38
- 14c: e15b34f0 ldrsh r3, [fp, #-64] ; 0xffffffc0
- 150: e58dc000 str ip, [sp]
- 154: e51bc030 ldr ip, [fp, #-48] ; 0x30
- 158: e59f1120 ldr r1, [pc, #288] ; 280 <ls+0x194>
- 15c: e58dc004 str ip, [sp, #4]
- 160: e1a02000 mov r2, r0
- 164: e3a00001 mov r0, #1
- 168: eb000243 bl a7c <printf>
- break;
- 16c: eaffffef b 130 <ls+0x44>
-
- case T_DIR:
- if(strlen(path) + 1 + DIRSIZ + 1 > sizeof buf){
- 170: e1a00006 mov r0, r6
- 174: eb000062 bl 304 <strlen>
- 178: e2800010 add r0, r0, #16
- 17c: e3500c02 cmp r0, #512 ; 0x200
- 180: 8a000029 bhi 22c <ls+0x140>
- printf(1, "ls: path too long\n");
- break;
- }
- strcpy(buf, path);
- 184: e24b5d09 sub r5, fp, #576 ; 0x240
- 188: e1a01006 mov r1, r6
- 18c: e1a00005 mov r0, r5
- 190: eb00003e bl 290 <strcpy>
- p = buf+strlen(buf);
- 194: e1a00005 mov r0, r5
- 198: eb000059 bl 304 <strlen>
- *p++ = '/';
- while(read(fd, &de, sizeof(de)) == sizeof(de)){
- if(de.inum == 0)
- continue;
- memmove(p, de.name, DIRSIZ);
- p[DIRSIZ] = 0;
- 19c: e3a08000 mov r8, #0
- printf(1, "ls: path too long\n");
- break;
- }
- strcpy(buf, path);
- p = buf+strlen(buf);
- *p++ = '/';
- 1a0: e3a0302f mov r3, #47 ; 0x2f
- if(strlen(path) + 1 + DIRSIZ + 1 > sizeof buf){
- printf(1, "ls: path too long\n");
- break;
- }
- strcpy(buf, path);
- p = buf+strlen(buf);
- 1a4: e0856000 add r6, r5, r0
- *p++ = '/';
- 1a8: e2867001 add r7, r6, #1
- 1ac: e7c53000 strb r3, [r5, r0]
- while(read(fd, &de, sizeof(de)) == sizeof(de)){
- 1b0: e24b102c sub r1, fp, #44 ; 0x2c
- 1b4: e1a00004 mov r0, r4
- 1b8: e3a02010 mov r2, #16
- 1bc: eb000102 bl 5cc <read>
- 1c0: e3500010 cmp r0, #16
- 1c4: 1affffd9 bne 130 <ls+0x44>
- if(de.inum == 0)
- 1c8: e15b32bc ldrh r3, [fp, #-44] ; 0xffffffd4
- 1cc: e3530000 cmp r3, #0
- 1d0: 0afffff6 beq 1b0 <ls+0xc4>
- continue;
- memmove(p, de.name, DIRSIZ);
- 1d4: e3a0200e mov r2, #14
- 1d8: e24b102a sub r1, fp, #42 ; 0x2a
- 1dc: e1a00007 mov r0, r7
- 1e0: eb0000b8 bl 4c8 <memmove>
- p[DIRSIZ] = 0;
- if(stat(buf, &st) < 0){
- 1e4: e24b1040 sub r1, fp, #64 ; 0x40
- 1e8: e1a00005 mov r0, r5
- *p++ = '/';
- while(read(fd, &de, sizeof(de)) == sizeof(de)){
- if(de.inum == 0)
- continue;
- memmove(p, de.name, DIRSIZ);
- p[DIRSIZ] = 0;
- 1ec: e5c6800f strb r8, [r6, #15]
- if(stat(buf, &st) < 0){
- 1f0: eb000090 bl 438 <stat>
- 1f4: e3500000 cmp r0, #0
- printf(1, "ls: cannot stat %s\n", buf);
- continue;
- }
- printf(1, "%s %d %d %d\n", fmtname(buf), st.type, st.ino, st.size);
- 1f8: e1a00005 mov r0, r5
- while(read(fd, &de, sizeof(de)) == sizeof(de)){
- if(de.inum == 0)
- continue;
- memmove(p, de.name, DIRSIZ);
- p[DIRSIZ] = 0;
- if(stat(buf, &st) < 0){
- 1fc: ba000013 blt 250 <ls+0x164>
- printf(1, "ls: cannot stat %s\n", buf);
- continue;
- }
- printf(1, "%s %d %d %d\n", fmtname(buf), st.type, st.ino, st.size);
- 200: ebffff8f bl 44 <fmtname>
- 204: e51bc038 ldr ip, [fp, #-56] ; 0x38
- 208: e15b34f0 ldrsh r3, [fp, #-64] ; 0xffffffc0
- 20c: e58dc000 str ip, [sp]
- 210: e51bc030 ldr ip, [fp, #-48] ; 0x30
- 214: e59f1064 ldr r1, [pc, #100] ; 280 <ls+0x194>
- 218: e58dc004 str ip, [sp, #4]
- 21c: e1a02000 mov r2, r0
- 220: e3a00001 mov r0, #1
- 224: eb000214 bl a7c <printf>
- 228: eaffffe0 b 1b0 <ls+0xc4>
- printf(1, "%s %d %d %d\n", fmtname(path), st.type, st.ino, st.size);
- break;
-
- case T_DIR:
- if(strlen(path) + 1 + DIRSIZ + 1 > sizeof buf){
- printf(1, "ls: path too long\n");
- 22c: e1a00005 mov r0, r5
- 230: e59f104c ldr r1, [pc, #76] ; 284 <ls+0x198>
- 234: eb000210 bl a7c <printf>
- break;
- 238: eaffffbc b 130 <ls+0x44>
- int fd;
- struct dirent de;
- struct stat st;
-
- if((fd = open(path, 0)) < 0){
- printf(2, "ls: cannot open %s\n", path);
- 23c: e3a00002 mov r0, #2
- 240: e59f1040 ldr r1, [pc, #64] ; 288 <ls+0x19c>
- 244: e1a02006 mov r2, r6
- 248: eb00020b bl a7c <printf>
- return;
- 24c: eaffffb9 b 138 <ls+0x4c>
- if(de.inum == 0)
- continue;
- memmove(p, de.name, DIRSIZ);
- p[DIRSIZ] = 0;
- if(stat(buf, &st) < 0){
- printf(1, "ls: cannot stat %s\n", buf);
- 250: e3a00001 mov r0, #1
- 254: e59f1030 ldr r1, [pc, #48] ; 28c <ls+0x1a0>
- 258: e1a02005 mov r2, r5
- 25c: eb000206 bl a7c <printf>
- continue;
- 260: eaffffd2 b 1b0 <ls+0xc4>
- printf(2, "ls: cannot open %s\n", path);
- return;
- }
-
- if(fstat(fd, &st) < 0){
- printf(2, "ls: cannot stat %s\n", path);
- 264: e59f1020 ldr r1, [pc, #32] ; 28c <ls+0x1a0>
- 268: e1a02006 mov r2, r6
- 26c: e3a00002 mov r0, #2
- 270: eb000201 bl a7c <printf>
- close(fd);
- 274: e1a00004 mov r0, r4
- 278: eb0000ed bl 634 <close>
- return;
- 27c: eaffffad b 138 <ls+0x4c>
- 280: 00000d8c .word 0x00000d8c
- 284: 00000d9c .word 0x00000d9c
- 288: 00000d64 .word 0x00000d64
- 28c: 00000d78 .word 0x00000d78
- 00000290 <strcpy>:
- #include "user.h"
- #include "arm.h"
- char*
- strcpy(char *s, char *t)
- {
- 290: e52db004 push {fp} ; (str fp, [sp, #-4]!)
- char *os;
- os = s;
- while((*s++ = *t++) != 0)
- 294: e1a02000 mov r2, r0
- #include "user.h"
- #include "arm.h"
- char*
- strcpy(char *s, char *t)
- {
- 298: e28db000 add fp, sp, #0
- char *os;
- os = s;
- while((*s++ = *t++) != 0)
- 29c: e4d13001 ldrb r3, [r1], #1
- 2a0: e3530000 cmp r3, #0
- 2a4: e4c23001 strb r3, [r2], #1
- 2a8: 1afffffb bne 29c <strcpy+0xc>
- ;
- return os;
- }
- 2ac: e28bd000 add sp, fp, #0
- 2b0: e8bd0800 pop {fp}
- 2b4: e12fff1e bx lr
- 000002b8 <strcmp>:
- int
- strcmp(const char *p, const char *q)
- {
- 2b8: e52db004 push {fp} ; (str fp, [sp, #-4]!)
- 2bc: e28db000 add fp, sp, #0
- while(*p && *p == *q)
- 2c0: e5d03000 ldrb r3, [r0]
- 2c4: e5d12000 ldrb r2, [r1]
- 2c8: e3530000 cmp r3, #0
- 2cc: 1a000004 bne 2e4 <strcmp+0x2c>
- 2d0: ea000005 b 2ec <strcmp+0x34>
- 2d4: e5f03001 ldrb r3, [r0, #1]!
- 2d8: e3530000 cmp r3, #0
- 2dc: 0a000006 beq 2fc <strcmp+0x44>
- 2e0: e5f12001 ldrb r2, [r1, #1]!
- 2e4: e1530002 cmp r3, r2
- 2e8: 0afffff9 beq 2d4 <strcmp+0x1c>
- p++, q++;
- return (uchar)*p - (uchar)*q;
- }
- 2ec: e0620003 rsb r0, r2, r3
- 2f0: e28bd000 add sp, fp, #0
- 2f4: e8bd0800 pop {fp}
- 2f8: e12fff1e bx lr
- }
- int
- strcmp(const char *p, const char *q)
- {
- while(*p && *p == *q)
- 2fc: e5d12001 ldrb r2, [r1, #1]
- 300: eafffff9 b 2ec <strcmp+0x34>
- 00000304 <strlen>:
- return (uchar)*p - (uchar)*q;
- }
- uint
- strlen(char *s)
- {
- 304: e52db004 push {fp} ; (str fp, [sp, #-4]!)
- 308: e28db000 add fp, sp, #0
- int n;
- for(n = 0; s[n]; n++)
- 30c: e5d03000 ldrb r3, [r0]
- 310: e3530000 cmp r3, #0
- 314: 01a00003 moveq r0, r3
- 318: 0a000006 beq 338 <strlen+0x34>
- 31c: e1a02000 mov r2, r0
- 320: e3a03000 mov r3, #0
- 324: e5f21001 ldrb r1, [r2, #1]!
- 328: e2833001 add r3, r3, #1
- 32c: e1a00003 mov r0, r3
- 330: e3510000 cmp r1, #0
- 334: 1afffffa bne 324 <strlen+0x20>
- ;
- return n;
- }
- 338: e28bd000 add sp, fp, #0
- 33c: e8bd0800 pop {fp}
- 340: e12fff1e bx lr
- 00000344 <memset>:
- memset(void *dst, int c, uint n)
- {
- char *p=dst;
- u32 rc=n;
- while (rc-- > 0) *p++ = c;
- 344: e3520000 cmp r2, #0
- return n;
- }
- void*
- memset(void *dst, int c, uint n)
- {
- 348: e52db004 push {fp} ; (str fp, [sp, #-4]!)
- 34c: e28db000 add fp, sp, #0
- char *p=dst;
- u32 rc=n;
- while (rc-- > 0) *p++ = c;
- 350: 0a000006 beq 370 <memset+0x2c>
- 354: e6ef1071 uxtb r1, r1
- 358: e1a03002 mov r3, r2
- }
- void*
- memset(void *dst, int c, uint n)
- {
- char *p=dst;
- 35c: e1a0c000 mov ip, r0
- u32 rc=n;
- while (rc-- > 0) *p++ = c;
- 360: e2533001 subs r3, r3, #1
- 364: e4cc1001 strb r1, [ip], #1
- 368: 1afffffc bne 360 <memset+0x1c>
- 36c: e0800002 add r0, r0, r2
- return (void *)p;
- }
- 370: e28bd000 add sp, fp, #0
- 374: e8bd0800 pop {fp}
- 378: e12fff1e bx lr
- 0000037c <strchr>:
- char*
- strchr(const char *s, char c)
- {
- 37c: e52db004 push {fp} ; (str fp, [sp, #-4]!)
- 380: e28db000 add fp, sp, #0
- for(; *s; s++)
- 384: e5d03000 ldrb r3, [r0]
- 388: e3530000 cmp r3, #0
- 38c: 1a000004 bne 3a4 <strchr+0x28>
- 390: ea000008 b 3b8 <strchr+0x3c>
- 394: e5d03001 ldrb r3, [r0, #1]
- 398: e2800001 add r0, r0, #1
- 39c: e3530000 cmp r3, #0
- 3a0: 0a000004 beq 3b8 <strchr+0x3c>
- if(*s == c)
- 3a4: e1530001 cmp r3, r1
- 3a8: 1afffff9 bne 394 <strchr+0x18>
- return (char*)s;
- return 0;
- }
- 3ac: e28bd000 add sp, fp, #0
- 3b0: e8bd0800 pop {fp}
- 3b4: e12fff1e bx lr
- strchr(const char *s, char c)
- {
- for(; *s; s++)
- if(*s == c)
- return (char*)s;
- return 0;
- 3b8: e1a00003 mov r0, r3
- 3bc: eafffffa b 3ac <strchr+0x30>
- 000003c0 <gets>:
- }
- char*
- gets(char *buf, int max)
- {
- 3c0: e92d49f0 push {r4, r5, r6, r7, r8, fp, lr}
- 3c4: e28db018 add fp, sp, #24
- 3c8: e24dd00c sub sp, sp, #12
- 3cc: e1a08000 mov r8, r0
- 3d0: e1a07001 mov r7, r1
- int i, cc;
- char c;
- for(i=0; i+1 < max; ){
- 3d4: e1a06000 mov r6, r0
- 3d8: e3a05000 mov r5, #0
- 3dc: ea000008 b 404 <gets+0x44>
- cc = read(0, &c, 1);
- 3e0: eb000079 bl 5cc <read>
- if(cc < 1)
- 3e4: e3500000 cmp r0, #0
- 3e8: da00000b ble 41c <gets+0x5c>
- break;
- buf[i++] = c;
- 3ec: e55b301d ldrb r3, [fp, #-29]
- if(c == '\n' || c == '\r')
- 3f0: e1a05004 mov r5, r4
- 3f4: e353000a cmp r3, #10
- 3f8: 1353000d cmpne r3, #13
- for(i=0; i+1 < max; ){
- cc = read(0, &c, 1);
- if(cc < 1)
- break;
- buf[i++] = c;
- 3fc: e4c63001 strb r3, [r6], #1
- if(c == '\n' || c == '\r')
- 400: 0a00000a beq 430 <gets+0x70>
- {
- int i, cc;
- char c;
- for(i=0; i+1 < max; ){
- cc = read(0, &c, 1);
- 404: e3a02001 mov r2, #1
- gets(char *buf, int max)
- {
- int i, cc;
- char c;
- for(i=0; i+1 < max; ){
- 408: e0854002 add r4, r5, r2
- 40c: e1540007 cmp r4, r7
- cc = read(0, &c, 1);
- 410: e3a00000 mov r0, #0
- 414: e24b101d sub r1, fp, #29
- gets(char *buf, int max)
- {
- int i, cc;
- char c;
- for(i=0; i+1 < max; ){
- 418: bafffff0 blt 3e0 <gets+0x20>
- break;
- buf[i++] = c;
- if(c == '\n' || c == '\r')
- break;
- }
- buf[i] = '\0';
- 41c: e3a03000 mov r3, #0
- 420: e7c83005 strb r3, [r8, r5]
- return buf;
- }
- 424: e1a00008 mov r0, r8
- 428: e24bd018 sub sp, fp, #24
- 42c: e8bd89f0 pop {r4, r5, r6, r7, r8, fp, pc}
- gets(char *buf, int max)
- {
- int i, cc;
- char c;
- for(i=0; i+1 < max; ){
- 430: e1a05004 mov r5, r4
- 434: eafffff8 b 41c <gets+0x5c>
- 00000438 <stat>:
- return buf;
- }
- int
- stat(char *n, struct stat *st)
- {
- 438: e92d4830 push {r4, r5, fp, lr}
- 43c: e1a05001 mov r5, r1
- 440: e28db00c add fp, sp, #12
- int fd;
- int r;
- fd = open(n, O_RDONLY);
- 444: e3a01000 mov r1, #0
- 448: eb0000a0 bl 6d0 <open>
- if(fd < 0)
- 44c: e2504000 subs r4, r0, #0
- return -1;
- 450: b3e05000 mvnlt r5, #0
- {
- int fd;
- int r;
- fd = open(n, O_RDONLY);
- if(fd < 0)
- 454: ba000004 blt 46c <stat+0x34>
- return -1;
- r = fstat(fd, st);
- 458: e1a01005 mov r1, r5
- 45c: eb0000c2 bl 76c <fstat>
- 460: e1a05000 mov r5, r0
- close(fd);
- 464: e1a00004 mov r0, r4
- 468: eb000071 bl 634 <close>
- return r;
- }
- 46c: e1a00005 mov r0, r5
- 470: e8bd8830 pop {r4, r5, fp, pc}
- 00000474 <atoi>:
- int
- atoi(const char *s)
- {
- 474: e52db004 push {fp} ; (str fp, [sp, #-4]!)
- 478: e28db000 add fp, sp, #0
- int n;
- n = 0;
- while('0' <= *s && *s <= '9')
- 47c: e5d03000 ldrb r3, [r0]
- 480: e2432030 sub r2, r3, #48 ; 0x30
- 484: e6ef2072 uxtb r2, r2
- 488: e3520009 cmp r2, #9
- int
- atoi(const char *s)
- {
- int n;
- n = 0;
- 48c: 83a00000 movhi r0, #0
- while('0' <= *s && *s <= '9')
- 490: 8a000009 bhi 4bc <atoi+0x48>
- 494: e1a02000 mov r2, r0
- int
- atoi(const char *s)
- {
- int n;
- n = 0;
- 498: e3a00000 mov r0, #0
- while('0' <= *s && *s <= '9')
- n = n*10 + *s++ - '0';
- 49c: e0800100 add r0, r0, r0, lsl #2
- 4a0: e0830080 add r0, r3, r0, lsl #1
- atoi(const char *s)
- {
- int n;
- n = 0;
- while('0' <= *s && *s <= '9')
- 4a4: e5f23001 ldrb r3, [r2, #1]!
- n = n*10 + *s++ - '0';
- 4a8: e2400030 sub r0, r0, #48 ; 0x30
- atoi(const char *s)
- {
- int n;
- n = 0;
- while('0' <= *s && *s <= '9')
- 4ac: e2431030 sub r1, r3, #48 ; 0x30
- 4b0: e6ef1071 uxtb r1, r1
- 4b4: e3510009 cmp r1, #9
- 4b8: 9afffff7 bls 49c <atoi+0x28>
- n = n*10 + *s++ - '0';
- return n;
- }
- 4bc: e28bd000 add sp, fp, #0
- 4c0: e8bd0800 pop {fp}
- 4c4: e12fff1e bx lr
- 000004c8 <memmove>:
- {
- char *dst, *src;
-
- dst = vdst;
- src = vsrc;
- while(n-- > 0)
- 4c8: e3520000 cmp r2, #0
- return n;
- }
- void*
- memmove(void *vdst, void *vsrc, int n)
- {
- 4cc: e52db004 push {fp} ; (str fp, [sp, #-4]!)
- 4d0: e28db000 add fp, sp, #0
- char *dst, *src;
-
- dst = vdst;
- src = vsrc;
- while(n-- > 0)
- 4d4: da000005 ble 4f0 <memmove+0x28>
- n = n*10 + *s++ - '0';
- return n;
- }
- void*
- memmove(void *vdst, void *vsrc, int n)
- 4d8: e0802002 add r2, r0, r2
- {
- char *dst, *src;
-
- dst = vdst;
- 4dc: e1a03000 mov r3, r0
- src = vsrc;
- while(n-- > 0)
- *dst++ = *src++;
- 4e0: e4d1c001 ldrb ip, [r1], #1
- 4e4: e4c3c001 strb ip, [r3], #1
- {
- char *dst, *src;
-
- dst = vdst;
- src = vsrc;
- while(n-- > 0)
- 4e8: e1530002 cmp r3, r2
- 4ec: 1afffffb bne 4e0 <memmove+0x18>
- *dst++ = *src++;
- return vdst;
- }
- 4f0: e28bd000 add sp, fp, #0
- 4f4: e8bd0800 pop {fp}
- 4f8: e12fff1e bx lr
- 000004fc <fork>:
- 4fc: e92d4000 push {lr}
- 500: e92d0008 push {r3}
- 504: e92d0004 push {r2}
- 508: e92d0002 push {r1}
- 50c: e92d0001 push {r0}
- 510: e3a00001 mov r0, #1
- 514: ef000040 svc 0x00000040
- 518: e8bd0002 pop {r1}
- 51c: e8bd0002 pop {r1}
- 520: e8bd0004 pop {r2}
- 524: e8bd0008 pop {r3}
- 528: e8bd4000 pop {lr}
- 52c: e12fff1e bx lr
- 00000530 <exit>:
- 530: e92d4000 push {lr}
- 534: e92d0008 push {r3}
- 538: e92d0004 push {r2}
- 53c: e92d0002 push {r1}
- 540: e92d0001 push {r0}
- 544: e3a00002 mov r0, #2
- 548: ef000040 svc 0x00000040
- 54c: e8bd0002 pop {r1}
- 550: e8bd0002 pop {r1}
- 554: e8bd0004 pop {r2}
- 558: e8bd0008 pop {r3}
- 55c: e8bd4000 pop {lr}
- 560: e12fff1e bx lr
- 00000564 <wait>:
- 564: e92d4000 push {lr}
- 568: e92d0008 push {r3}
- 56c: e92d0004 push {r2}
- 570: e92d0002 push {r1}
- 574: e92d0001 push {r0}
- 578: e3a00003 mov r0, #3
- 57c: ef000040 svc 0x00000040
- 580: e8bd0002 pop {r1}
- 584: e8bd0002 pop {r1}
- 588: e8bd0004 pop {r2}
- 58c: e8bd0008 pop {r3}
- 590: e8bd4000 pop {lr}
- 594: e12fff1e bx lr
- 00000598 <pipe>:
- 598: e92d4000 push {lr}
- 59c: e92d0008 push {r3}
- 5a0: e92d0004 push {r2}
- 5a4: e92d0002 push {r1}
- 5a8: e92d0001 push {r0}
- 5ac: e3a00004 mov r0, #4
- 5b0: ef000040 svc 0x00000040
- 5b4: e8bd0002 pop {r1}
- 5b8: e8bd0002 pop {r1}
- 5bc: e8bd0004 pop {r2}
- 5c0: e8bd0008 pop {r3}
- 5c4: e8bd4000 pop {lr}
- 5c8: e12fff1e bx lr
- 000005cc <read>:
- 5cc: e92d4000 push {lr}
- 5d0: e92d0008 push {r3}
- 5d4: e92d0004 push {r2}
- 5d8: e92d0002 push {r1}
- 5dc: e92d0001 push {r0}
- 5e0: e3a00005 mov r0, #5
- 5e4: ef000040 svc 0x00000040
- 5e8: e8bd0002 pop {r1}
- 5ec: e8bd0002 pop {r1}
- 5f0: e8bd0004 pop {r2}
- 5f4: e8bd0008 pop {r3}
- 5f8: e8bd4000 pop {lr}
- 5fc: e12fff1e bx lr
- 00000600 <write>:
- 600: e92d4000 push {lr}
- 604: e92d0008 push {r3}
- 608: e92d0004 push {r2}
- 60c: e92d0002 push {r1}
- 610: e92d0001 push {r0}
- 614: e3a00010 mov r0, #16
- 618: ef000040 svc 0x00000040
- 61c: e8bd0002 pop {r1}
- 620: e8bd0002 pop {r1}
- 624: e8bd0004 pop {r2}
- 628: e8bd0008 pop {r3}
- 62c: e8bd4000 pop {lr}
- 630: e12fff1e bx lr
- 00000634 <close>:
- 634: e92d4000 push {lr}
- 638: e92d0008 push {r3}
- 63c: e92d0004 push {r2}
- 640: e92d0002 push {r1}
- 644: e92d0001 push {r0}
- 648: e3a00015 mov r0, #21
- 64c: ef000040 svc 0x00000040
- 650: e8bd0002 pop {r1}
- 654: e8bd0002 pop {r1}
- 658: e8bd0004 pop {r2}
- 65c: e8bd0008 pop {r3}
- 660: e8bd4000 pop {lr}
- 664: e12fff1e bx lr
- 00000668 <kill>:
- 668: e92d4000 push {lr}
- 66c: e92d0008 push {r3}
- 670: e92d0004 push {r2}
- 674: e92d0002 push {r1}
- 678: e92d0001 push {r0}
- 67c: e3a00006 mov r0, #6
- 680: ef000040 svc 0x00000040
- 684: e8bd0002 pop {r1}
- 688: e8bd0002 pop {r1}
- 68c: e8bd0004 pop {r2}
- 690: e8bd0008 pop {r3}
- 694: e8bd4000 pop {lr}
- 698: e12fff1e bx lr
- 0000069c <exec>:
- 69c: e92d4000 push {lr}
- 6a0: e92d0008 push {r3}
- 6a4: e92d0004 push {r2}
- 6a8: e92d0002 push {r1}
- 6ac: e92d0001 push {r0}
- 6b0: e3a00007 mov r0, #7
- 6b4: ef000040 svc 0x00000040
- 6b8: e8bd0002 pop {r1}
- 6bc: e8bd0002 pop {r1}
- 6c0: e8bd0004 pop {r2}
- 6c4: e8bd0008 pop {r3}
- 6c8: e8bd4000 pop {lr}
- 6cc: e12fff1e bx lr
- 000006d0 <open>:
- 6d0: e92d4000 push {lr}
- 6d4: e92d0008 push {r3}
- 6d8: e92d0004 push {r2}
- 6dc: e92d0002 push {r1}
- 6e0: e92d0001 push {r0}
- 6e4: e3a0000f mov r0, #15
- 6e8: ef000040 svc 0x00000040
- 6ec: e8bd0002 pop {r1}
- 6f0: e8bd0002 pop {r1}
- 6f4: e8bd0004 pop {r2}
- 6f8: e8bd0008 pop {r3}
- 6fc: e8bd4000 pop {lr}
- 700: e12fff1e bx lr
- 00000704 <mknod>:
- 704: e92d4000 push {lr}
- 708: e92d0008 push {r3}
- 70c: e92d0004 push {r2}
- 710: e92d0002 push {r1}
- 714: e92d0001 push {r0}
- 718: e3a00011 mov r0, #17
- 71c: ef000040 svc 0x00000040
- 720: e8bd0002 pop {r1}
- 724: e8bd0002 pop {r1}
- 728: e8bd0004 pop {r2}
- 72c: e8bd0008 pop {r3}
- 730: e8bd4000 pop {lr}
- 734: e12fff1e bx lr
- 00000738 <unlink>:
- 738: e92d4000 push {lr}
- 73c: e92d0008 push {r3}
- 740: e92d0004 push {r2}
- 744: e92d0002 push {r1}
- 748: e92d0001 push {r0}
- 74c: e3a00012 mov r0, #18
- 750: ef000040 svc 0x00000040
- 754: e8bd0002 pop {r1}
- 758: e8bd0002 pop {r1}
- 75c: e8bd0004 pop {r2}
- 760: e8bd0008 pop {r3}
- 764: e8bd4000 pop {lr}
- 768: e12fff1e bx lr
- 0000076c <fstat>:
- 76c: e92d4000 push {lr}
- 770: e92d0008 push {r3}
- 774: e92d0004 push {r2}
- 778: e92d0002 push {r1}
- 77c: e92d0001 push {r0}
- 780: e3a00008 mov r0, #8
- 784: ef000040 svc 0x00000040
- 788: e8bd0002 pop {r1}
- 78c: e8bd0002 pop {r1}
- 790: e8bd0004 pop {r2}
- 794: e8bd0008 pop {r3}
- 798: e8bd4000 pop {lr}
- 79c: e12fff1e bx lr
- 000007a0 <link>:
- 7a0: e92d4000 push {lr}
- 7a4: e92d0008 push {r3}
- 7a8: e92d0004 push {r2}
- 7ac: e92d0002 push {r1}
- 7b0: e92d0001 push {r0}
- 7b4: e3a00013 mov r0, #19
- 7b8: ef000040 svc 0x00000040
- 7bc: e8bd0002 pop {r1}
- 7c0: e8bd0002 pop {r1}
- 7c4: e8bd0004 pop {r2}
- 7c8: e8bd0008 pop {r3}
- 7cc: e8bd4000 pop {lr}
- 7d0: e12fff1e bx lr
- 000007d4 <mkdir>:
- 7d4: e92d4000 push {lr}
- 7d8: e92d0008 push {r3}
- 7dc: e92d0004 push {r2}
- 7e0: e92d0002 push {r1}
- 7e4: e92d0001 push {r0}
- 7e8: e3a00014 mov r0, #20
- 7ec: ef000040 svc 0x00000040
- 7f0: e8bd0002 pop {r1}
- 7f4: e8bd0002 pop {r1}
- 7f8: e8bd0004 pop {r2}
- 7fc: e8bd0008 pop {r3}
- 800: e8bd4000 pop {lr}
- 804: e12fff1e bx lr
- 00000808 <chdir>:
- 808: e92d4000 push {lr}
- 80c: e92d0008 push {r3}
- 810: e92d0004 push {r2}
- 814: e92d0002 push {r1}
- 818: e92d0001 push {r0}
- 81c: e3a00009 mov r0, #9
- 820: ef000040 svc 0x00000040
- 824: e8bd0002 pop {r1}
- 828: e8bd0002 pop {r1}
- 82c: e8bd0004 pop {r2}
- 830: e8bd0008 pop {r3}
- 834: e8bd4000 pop {lr}
- 838: e12fff1e bx lr
- 0000083c <dup>:
- 83c: e92d4000 push {lr}
- 840: e92d0008 push {r3}
- 844: e92d0004 push {r2}
- 848: e92d0002 push {r1}
- 84c: e92d0001 push {r0}
- 850: e3a0000a mov r0, #10
- 854: ef000040 svc 0x00000040
- 858: e8bd0002 pop {r1}
- 85c: e8bd0002 pop {r1}
- 860: e8bd0004 pop {r2}
- 864: e8bd0008 pop {r3}
- 868: e8bd4000 pop {lr}
- 86c: e12fff1e bx lr
- 00000870 <getpid>:
- 870: e92d4000 push {lr}
- 874: e92d0008 push {r3}
- 878: e92d0004 push {r2}
- 87c: e92d0002 push {r1}
- 880: e92d0001 push {r0}
- 884: e3a0000b mov r0, #11
- 888: ef000040 svc 0x00000040
- 88c: e8bd0002 pop {r1}
- 890: e8bd0002 pop {r1}
- 894: e8bd0004 pop {r2}
- 898: e8bd0008 pop {r3}
- 89c: e8bd4000 pop {lr}
- 8a0: e12fff1e bx lr
- 000008a4 <sbrk>:
- 8a4: e92d4000 push {lr}
- 8a8: e92d0008 push {r3}
- 8ac: e92d0004 push {r2}
- 8b0: e92d0002 push {r1}
- 8b4: e92d0001 push {r0}
- 8b8: e3a0000c mov r0, #12
- 8bc: ef000040 svc 0x00000040
- 8c0: e8bd0002 pop {r1}
- 8c4: e8bd0002 pop {r1}
- 8c8: e8bd0004 pop {r2}
- 8cc: e8bd0008 pop {r3}
- 8d0: e8bd4000 pop {lr}
- 8d4: e12fff1e bx lr
- 000008d8 <sleep>:
- 8d8: e92d4000 push {lr}
- 8dc: e92d0008 push {r3}
- 8e0: e92d0004 push {r2}
- 8e4: e92d0002 push {r1}
- 8e8: e92d0001 push {r0}
- 8ec: e3a0000d mov r0, #13
- 8f0: ef000040 svc 0x00000040
- 8f4: e8bd0002 pop {r1}
- 8f8: e8bd0002 pop {r1}
- 8fc: e8bd0004 pop {r2}
- 900: e8bd0008 pop {r3}
- 904: e8bd4000 pop {lr}
- 908: e12fff1e bx lr
- 0000090c <uptime>:
- 90c: e92d4000 push {lr}
- 910: e92d0008 push {r3}
- 914: e92d0004 push {r2}
- 918: e92d0002 push {r1}
- 91c: e92d0001 push {r0}
- 920: e3a0000e mov r0, #14
- 924: ef000040 svc 0x00000040
- 928: e8bd0002 pop {r1}
- 92c: e8bd0002 pop {r1}
- 930: e8bd0004 pop {r2}
- 934: e8bd0008 pop {r3}
- 938: e8bd4000 pop {lr}
- 93c: e12fff1e bx lr
- 00000940 <putc>:
- #include "stat.h"
- #include "user.h"
- static void
- putc(int fd, char c)
- {
- 940: e92d4800 push {fp, lr}
- 944: e28db004 add fp, sp, #4
- 948: e24b3004 sub r3, fp, #4
- 94c: e24dd008 sub sp, sp, #8
- write(fd, &c, 1);
- 950: e3a02001 mov r2, #1
- #include "stat.h"
- #include "user.h"
- static void
- putc(int fd, char c)
- {
- 954: e5631001 strb r1, [r3, #-1]!
- write(fd, &c, 1);
- 958: e1a01003 mov r1, r3
- 95c: ebffff27 bl 600 <write>
- }
- 960: e24bd004 sub sp, fp, #4
- 964: e8bd8800 pop {fp, pc}
- 00000968 <printint>:
- return q;
- }
- static void
- printint(int fd, int xx, int base, int sgn)
- {
- 968: e92d4ff0 push {r4, r5, r6, r7, r8, r9, sl, fp, lr}
- 96c: e1a04000 mov r4, r0
- char buf[16];
- int i, neg;
- uint x, y, b;
- neg = 0;
- if(sgn && xx < 0){
- 970: e1a00fa1 lsr r0, r1, #31
- 974: e3530000 cmp r3, #0
- 978: 03a03000 moveq r3, #0
- 97c: 12003001 andne r3, r0, #1
- return q;
- }
- static void
- printint(int fd, int xx, int base, int sgn)
- {
- 980: e28db020 add fp, sp, #32
- char buf[16];
- int i, neg;
- uint x, y, b;
- neg = 0;
- if(sgn && xx < 0){
- 984: e3530000 cmp r3, #0
- return q;
- }
- static void
- printint(int fd, int xx, int base, int sgn)
- {
- 988: e24dd014 sub sp, sp, #20
- 98c: e59f909c ldr r9, [pc, #156] ; a30 <printint+0xc8>
- uint x, y, b;
- neg = 0;
- if(sgn && xx < 0){
- neg = 1;
- x = -xx;
- 990: 12611000 rsbne r1, r1, #0
- int i, neg;
- uint x, y, b;
- neg = 0;
- if(sgn && xx < 0){
- neg = 1;
- 994: 13a03001 movne r3, #1
- } else {
- x = xx;
- }
- b = base;
- i = 0;
- 998: e3a0a000 mov sl, #0
- 99c: e24b6034 sub r6, fp, #52 ; 0x34
- for(i=31;i>=0;i--){
- r = r << 1;
- r = r | ((n >> i) & 1);
- if(r >= d) {
- r = r - d;
- q = q | (1 << i);
- 9a0: e3a08001 mov r8, #1
- write(fd, &c, 1);
- }
- u32 div(u32 n, u32 d) // long division
- {
- u32 q=0, r=0;
- 9a4: e3a07000 mov r7, #0
- int i;
- for(i=31;i>=0;i--){
- 9a8: e3a0001f mov r0, #31
- write(fd, &c, 1);
- }
- u32 div(u32 n, u32 d) // long division
- {
- u32 q=0, r=0;
- 9ac: e1a0c007 mov ip, r7
- int i;
- for(i=31;i>=0;i--){
- r = r << 1;
- r = r | ((n >> i) & 1);
- 9b0: e1a0e031 lsr lr, r1, r0
- 9b4: e20ee001 and lr, lr, #1
- 9b8: e18ec08c orr ip, lr, ip, lsl #1
- if(r >= d) {
- 9bc: e152000c cmp r2, ip
- r = r - d;
- q = q | (1 << i);
- 9c0: 91877018 orrls r7, r7, r8, lsl r0
- for(i=31;i>=0;i--){
- r = r << 1;
- r = r | ((n >> i) & 1);
- if(r >= d) {
- r = r - d;
- 9c4: 9062c00c rsbls ip, r2, ip
- u32 div(u32 n, u32 d) // long division
- {
- u32 q=0, r=0;
- int i;
- for(i=31;i>=0;i--){
- 9c8: e2500001 subs r0, r0, #1
- 9cc: 2afffff7 bcs 9b0 <printint+0x48>
- b = base;
- i = 0;
- do{
- y = div(x, b);
- buf[i++] = digits[x - y * b];
- 9d0: e0000792 mul r0, r2, r7
- }while((x = y) != 0);
- 9d4: e3570000 cmp r7, #0
- b = base;
- i = 0;
- do{
- y = div(x, b);
- buf[i++] = digits[x - y * b];
- 9d8: e0601001 rsb r1, r0, r1
- 9dc: e28a5001 add r5, sl, #1
- 9e0: e7d91001 ldrb r1, [r9, r1]
- 9e4: e7c6100a strb r1, [r6, sl]
- }while((x = y) != 0);
- 9e8: 11a01007 movne r1, r7
- b = base;
- i = 0;
- do{
- y = div(x, b);
- buf[i++] = digits[x - y * b];
- 9ec: 11a0a005 movne sl, r5
- 9f0: 1affffeb bne 9a4 <printint+0x3c>
- }while((x = y) != 0);
- if(neg)
- 9f4: e3530000 cmp r3, #0
- buf[i++] = '-';
- 9f8: 124b2024 subne r2, fp, #36 ; 0x24
- 9fc: 10823005 addne r3, r2, r5
- a00: 128a5002 addne r5, sl, #2
- while(--i >= 0)
- a04: e2455001 sub r5, r5, #1
- do{
- y = div(x, b);
- buf[i++] = digits[x - y * b];
- }while((x = y) != 0);
- if(neg)
- buf[i++] = '-';
- a08: 13a0202d movne r2, #45 ; 0x2d
- a0c: 15432010 strbne r2, [r3, #-16]
- while(--i >= 0)
- putc(fd, buf[i]);
- a10: e7d61005 ldrb r1, [r6, r5]
- a14: e1a00004 mov r0, r4
- buf[i++] = digits[x - y * b];
- }while((x = y) != 0);
- if(neg)
- buf[i++] = '-';
- while(--i >= 0)
- a18: e2455001 sub r5, r5, #1
- putc(fd, buf[i]);
- a1c: ebffffc7 bl 940 <putc>
- buf[i++] = digits[x - y * b];
- }while((x = y) != 0);
- if(neg)
- buf[i++] = '-';
- while(--i >= 0)
- a20: e3750001 cmn r5, #1
- a24: 1afffff9 bne a10 <printint+0xa8>
- putc(fd, buf[i]);
- }
- a28: e24bd020 sub sp, fp, #32
- a2c: e8bd8ff0 pop {r4, r5, r6, r7, r8, r9, sl, fp, pc}
- a30: 00000db4 .word 0x00000db4
- 00000a34 <div>:
- write(fd, &c, 1);
- }
- u32 div(u32 n, u32 d) // long division
- {
- u32 q=0, r=0;
- a34: e3a03000 mov r3, #0
- {
- write(fd, &c, 1);
- }
- u32 div(u32 n, u32 d) // long division
- {
- a38: e92d0830 push {r4, r5, fp}
- a3c: e1a02000 mov r2, r0
- a40: e28db008 add fp, sp, #8
- u32 q=0, r=0;
- int i;
- for(i=31;i>=0;i--){
- a44: e3a0c01f mov ip, #31
- write(fd, &c, 1);
- }
- u32 div(u32 n, u32 d) // long division
- {
- u32 q=0, r=0;
- a48: e1a00003 mov r0, r3
- for(i=31;i>=0;i--){
- r = r << 1;
- r = r | ((n >> i) & 1);
- if(r >= d) {
- r = r - d;
- q = q | (1 << i);
- a4c: e3a05001 mov r5, #1
- u32 q=0, r=0;
- int i;
- for(i=31;i>=0;i--){
- r = r << 1;
- r = r | ((n >> i) & 1);
- a50: e1a04c32 lsr r4, r2, ip
- a54: e2044001 and r4, r4, #1
- a58: e1843083 orr r3, r4, r3, lsl #1
- if(r >= d) {
- a5c: e1530001 cmp r3, r1
- r = r - d;
- q = q | (1 << i);
- a60: 21800c15 orrcs r0, r0, r5, lsl ip
- for(i=31;i>=0;i--){
- r = r << 1;
- r = r | ((n >> i) & 1);
- if(r >= d) {
- r = r - d;
- a64: 20613003 rsbcs r3, r1, r3
- u32 div(u32 n, u32 d) // long division
- {
- u32 q=0, r=0;
- int i;
- for(i=31;i>=0;i--){
- a68: e25cc001 subs ip, ip, #1
- a6c: 2afffff7 bcs a50 <div+0x1c>
- r = r - d;
- q = q | (1 << i);
- }
- }
- return q;
- }
- a70: e24bd008 sub sp, fp, #8
- a74: e8bd0830 pop {r4, r5, fp}
- a78: e12fff1e bx lr
- 00000a7c <printf>:
- }
- // Print to the given fd. Only understands %d, %x, %p, %s.
- void
- printf(int fd, char *fmt, ...)
- {
- a7c: e92d000e push {r1, r2, r3}
- a80: e92d4ff0 push {r4, r5, r6, r7, r8, r9, sl, fp, lr}
- a84: e28db020 add fp, sp, #32
- a88: e1a05000 mov r5, r0
- int c, i, state;
- uint *ap;
- state = 0;
- ap = (uint*)(void*)&fmt + 1;
- for(i = 0; fmt[i]; i++){
- a8c: e59b4004 ldr r4, [fp, #4]
- a90: e5d48000 ldrb r8, [r4]
- a94: e3580000 cmp r8, #0
- a98: 0a000027 beq b3c <printf+0xc0>
- ap++;
- } else if(c == 's'){
- s = (char*)*ap;
- ap++;
- if(s == 0)
- s = "(null)";
- a9c: e59f712c ldr r7, [pc, #300] ; bd0 <printf+0x154>
- char *s;
- int c, i, state;
- uint *ap;
- state = 0;
- ap = (uint*)(void*)&fmt + 1;
- aa0: e28b6008 add r6, fp, #8
- {
- char *s;
- int c, i, state;
- uint *ap;
- state = 0;
- aa4: e3a0a000 mov sl, #0
- aa8: ea000008 b ad0 <printf+0x54>
- ap = (uint*)(void*)&fmt + 1;
- for(i = 0; fmt[i]; i++){
- c = fmt[i] & 0xff;
- if(state == 0){
- if(c == '%'){
- aac: e3580025 cmp r8, #37 ; 0x25
- state = '%';
- ab0: 01a0a008 moveq sl, r8
- state = 0;
- ap = (uint*)(void*)&fmt + 1;
- for(i = 0; fmt[i]; i++){
- c = fmt[i] & 0xff;
- if(state == 0){
- if(c == '%'){
- ab4: 0a000002 beq ac4 <printf+0x48>
- state = '%';
- } else {
- putc(fd, c);
- ab8: e1a00005 mov r0, r5
- abc: e1a01008 mov r1, r8
- ac0: ebffff9e bl 940 <putc>
- int c, i, state;
- uint *ap;
- state = 0;
- ap = (uint*)(void*)&fmt + 1;
- for(i = 0; fmt[i]; i++){
- ac4: e5f48001 ldrb r8, [r4, #1]!
- ac8: e3580000 cmp r8, #0
- acc: 0a00001a beq b3c <printf+0xc0>
- c = fmt[i] & 0xff;
- if(state == 0){
- ad0: e35a0000 cmp sl, #0
- ad4: 0afffff4 beq aac <printf+0x30>
- if(c == '%'){
- state = '%';
- } else {
- putc(fd, c);
- }
- } else if(state == '%'){
- ad8: e35a0025 cmp sl, #37 ; 0x25
- adc: 1afffff8 bne ac4 <printf+0x48>
- if(c == 'd'){
- ae0: e3580064 cmp r8, #100 ; 0x64
- ae4: 0a00002c beq b9c <printf+0x120>
- printint(fd, *ap, 10, 1);
- ap++;
- } else if(c == 'x' || c == 'p'){
- ae8: e3580078 cmp r8, #120 ; 0x78
- aec: 13580070 cmpne r8, #112 ; 0x70
- af0: 13a09000 movne r9, #0
- af4: 03a09001 moveq r9, #1
- af8: 0a000013 beq b4c <printf+0xd0>
- printint(fd, *ap, 16, 0);
- ap++;
- } else if(c == 's'){
- afc: e3580073 cmp r8, #115 ; 0x73
- b00: 0a000018 beq b68 <printf+0xec>
- s = "(null)";
- while(*s != 0){
- putc(fd, *s);
- s++;
- }
- } else if(c == 'c'){
- b04: e3580063 cmp r8, #99 ; 0x63
- b08: 0a00002a beq bb8 <printf+0x13c>
- putc(fd, *ap);
- ap++;
- } else if(c == '%'){
- b0c: e3580025 cmp r8, #37 ; 0x25
- putc(fd, c);
- b10: e1a0100a mov r1, sl
- b14: e1a00005 mov r0, r5
- s++;
- }
- } else if(c == 'c'){
- putc(fd, *ap);
- ap++;
- } else if(c == '%'){
- b18: 0a000002 beq b28 <printf+0xac>
- putc(fd, c);
- } else {
- // Unknown % sequence. Print it to draw attention.
- putc(fd, '%');
- b1c: ebffff87 bl 940 <putc>
- putc(fd, c);
- b20: e1a00005 mov r0, r5
- b24: e1a01008 mov r1, r8
- b28: ebffff84 bl 940 <putc>
- int c, i, state;
- uint *ap;
- state = 0;
- ap = (uint*)(void*)&fmt + 1;
- for(i = 0; fmt[i]; i++){
- b2c: e5f48001 ldrb r8, [r4, #1]!
- } else {
- // Unknown % sequence. Print it to draw attention.
- putc(fd, '%');
- putc(fd, c);
- }
- state = 0;
- b30: e1a0a009 mov sl, r9
- int c, i, state;
- uint *ap;
- state = 0;
- ap = (uint*)(void*)&fmt + 1;
- for(i = 0; fmt[i]; i++){
- b34: e3580000 cmp r8, #0
- b38: 1affffe4 bne ad0 <printf+0x54>
- putc(fd, c);
- }
- state = 0;
- }
- }
- }
- b3c: e24bd020 sub sp, fp, #32
- b40: e8bd4ff0 pop {r4, r5, r6, r7, r8, r9, sl, fp, lr}
- b44: e28dd00c add sp, sp, #12
- b48: e12fff1e bx lr
- } else if(state == '%'){
- if(c == 'd'){
- printint(fd, *ap, 10, 1);
- ap++;
- } else if(c == 'x' || c == 'p'){
- printint(fd, *ap, 16, 0);
- b4c: e1a00005 mov r0, r5
- b50: e4961004 ldr r1, [r6], #4
- b54: e3a02010 mov r2, #16
- b58: e3a03000 mov r3, #0
- b5c: ebffff81 bl 968 <printint>
- } else {
- // Unknown % sequence. Print it to draw attention.
- putc(fd, '%');
- putc(fd, c);
- }
- state = 0;
- b60: e3a0a000 mov sl, #0
- b64: eaffffd6 b ac4 <printf+0x48>
- ap++;
- } else if(c == 'x' || c == 'p'){
- printint(fd, *ap, 16, 0);
- ap++;
- } else if(c == 's'){
- s = (char*)*ap;
- b68: e4968004 ldr r8, [r6], #4
- ap++;
- if(s == 0)
- s = "(null)";
- b6c: e3580000 cmp r8, #0
- b70: 01a08007 moveq r8, r7
- while(*s != 0){
- b74: e5d81000 ldrb r1, [r8]
- b78: e3510000 cmp r1, #0
- b7c: 0a000004 beq b94 <printf+0x118>
- putc(fd, *s);
- b80: e1a00005 mov r0, r5
- b84: ebffff6d bl 940 <putc>
- } else if(c == 's'){
- s = (char*)*ap;
- ap++;
- if(s == 0)
- s = "(null)";
- while(*s != 0){
- b88: e5f81001 ldrb r1, [r8, #1]!
- b8c: e3510000 cmp r1, #0
- b90: 1afffffa bne b80 <printf+0x104>
- } else {
- // Unknown % sequence. Print it to draw attention.
- putc(fd, '%');
- putc(fd, c);
- }
- state = 0;
- b94: e1a0a001 mov sl, r1
- b98: eaffffc9 b ac4 <printf+0x48>
- } else {
- putc(fd, c);
- }
- } else if(state == '%'){
- if(c == 'd'){
- printint(fd, *ap, 10, 1);
- b9c: e1a00005 mov r0, r5
- ba0: e4961004 ldr r1, [r6], #4
- ba4: e3a0200a mov r2, #10
- ba8: e3a03001 mov r3, #1
- bac: ebffff6d bl 968 <printint>
- } else {
- // Unknown % sequence. Print it to draw attention.
- putc(fd, '%');
- putc(fd, c);
- }
- state = 0;
- bb0: e3a0a000 mov sl, #0
- bb4: eaffffc2 b ac4 <printf+0x48>
- while(*s != 0){
- putc(fd, *s);
- s++;
- }
- } else if(c == 'c'){
- putc(fd, *ap);
- bb8: e4961004 ldr r1, [r6], #4
- bbc: e1a00005 mov r0, r5
- } else {
- // Unknown % sequence. Print it to draw attention.
- putc(fd, '%');
- putc(fd, c);
- }
- state = 0;
- bc0: e1a0a009 mov sl, r9
- while(*s != 0){
- putc(fd, *s);
- s++;
- }
- } else if(c == 'c'){
- putc(fd, *ap);
- bc4: e6ef1071 uxtb r1, r1
- bc8: ebffff5c bl 940 <putc>
- bcc: eaffffbc b ac4 <printf+0x48>
- bd0: 00000dc8 .word 0x00000dc8
- 00000bd4 <free>:
- free(void *ap)
- {
- Header *bp, *p;
- bp = (Header*)ap - 1;
- for(p = freep; !(bp > p && bp < p->s.ptr); p = p->s.ptr)
- bd4: e59f3098 ldr r3, [pc, #152] ; c74 <free+0xa0>
- static Header base;
- static Header *freep;
- void
- free(void *ap)
- {
- bd8: e92d0830 push {r4, r5, fp}
- Header *bp, *p;
- bp = (Header*)ap - 1;
- bdc: e240c008 sub ip, r0, #8
- for(p = freep; !(bp > p && bp < p->s.ptr); p = p->s.ptr)
- be0: e5932000 ldr r2, [r3]
- static Header base;
- static Header *freep;
- void
- free(void *ap)
- {
- be4: e28db008 add fp, sp, #8
- Header *bp, *p;
- bp = (Header*)ap - 1;
- for(p = freep; !(bp > p && bp < p->s.ptr); p = p->s.ptr)
- be8: e152000c cmp r2, ip
- bec: e5921000 ldr r1, [r2]
- bf0: 2a000001 bcs bfc <free+0x28>
- bf4: e15c0001 cmp ip, r1
- bf8: 3a000007 bcc c1c <free+0x48>
- if(p >= p->s.ptr && (bp > p || bp < p->s.ptr))
- bfc: e1520001 cmp r2, r1
- c00: 3a000003 bcc c14 <free+0x40>
- c04: e152000c cmp r2, ip
- c08: 3a000003 bcc c1c <free+0x48>
- c0c: e15c0001 cmp ip, r1
- c10: 3a000001 bcc c1c <free+0x48>
- static Header base;
- static Header *freep;
- void
- free(void *ap)
- {
- c14: e1a02001 mov r2, r1
- c18: eafffff2 b be8 <free+0x14>
- bp = (Header*)ap - 1;
- for(p = freep; !(bp > p && bp < p->s.ptr); p = p->s.ptr)
- if(p >= p->s.ptr && (bp > p || bp < p->s.ptr))
- break;
- if(bp + bp->s.size == p->s.ptr){
- c1c: e5104004 ldr r4, [r0, #-4]
- if(p + p->s.size == bp){
- p->s.size += bp->s.size;
- p->s.ptr = bp->s.ptr;
- } else
- p->s.ptr = bp;
- freep = p;
- c20: e5832000 str r2, [r3]
- bp = (Header*)ap - 1;
- for(p = freep; !(bp > p && bp < p->s.ptr); p = p->s.ptr)
- if(p >= p->s.ptr && (bp > p || bp < p->s.ptr))
- break;
- if(bp + bp->s.size == p->s.ptr){
- c24: e08c5184 add r5, ip, r4, lsl #3
- c28: e1550001 cmp r5, r1
- bp->s.size += p->s.ptr->s.size;
- c2c: 05911004 ldreq r1, [r1, #4]
- c30: 00814004 addeq r4, r1, r4
- c34: 05004004 streq r4, [r0, #-4]
- bp->s.ptr = p->s.ptr->s.ptr;
- c38: 05921000 ldreq r1, [r2]
- c3c: 05911000 ldreq r1, [r1]
- } else
- bp->s.ptr = p->s.ptr;
- c40: e5001008 str r1, [r0, #-8]
- if(p + p->s.size == bp){
- c44: e5921004 ldr r1, [r2, #4]
- c48: e0824181 add r4, r2, r1, lsl #3
- c4c: e15c0004 cmp ip, r4
- p->s.size += bp->s.size;
- p->s.ptr = bp->s.ptr;
- } else
- p->s.ptr = bp;
- c50: 1582c000 strne ip, [r2]
- bp->s.size += p->s.ptr->s.size;
- bp->s.ptr = p->s.ptr->s.ptr;
- } else
- bp->s.ptr = p->s.ptr;
- if(p + p->s.size == bp){
- p->s.size += bp->s.size;
- c54: 0510c004 ldreq ip, [r0, #-4]
- c58: 008c1001 addeq r1, ip, r1
- c5c: 05821004 streq r1, [r2, #4]
- p->s.ptr = bp->s.ptr;
- c60: 05101008 ldreq r1, [r0, #-8]
- c64: 05821000 streq r1, [r2]
- } else
- p->s.ptr = bp;
- freep = p;
- }
- c68: e24bd008 sub sp, fp, #8
- c6c: e8bd0830 pop {r4, r5, fp}
- c70: e12fff1e bx lr
- c74: 00000de0 .word 0x00000de0
- 00000c78 <malloc>:
- return freep;
- }
- void*
- malloc(uint nbytes)
- {
- c78: e92d49f8 push {r3, r4, r5, r6, r7, r8, fp, lr}
- Header *p, *prevp;
- uint nunits;
- nunits = (nbytes + sizeof(Header) - 1)/sizeof(Header) + 1;
- c7c: e2804007 add r4, r0, #7
- if((prevp = freep) == 0){
- c80: e59f50d4 ldr r5, [pc, #212] ; d5c <malloc+0xe4>
- malloc(uint nbytes)
- {
- Header *p, *prevp;
- uint nunits;
- nunits = (nbytes + sizeof(Header) - 1)/sizeof(Header) + 1;
- c84: e1a041a4 lsr r4, r4, #3
- return freep;
- }
- void*
- malloc(uint nbytes)
- {
- c88: e28db01c add fp, sp, #28
- Header *p, *prevp;
- uint nunits;
- nunits = (nbytes + sizeof(Header) - 1)/sizeof(Header) + 1;
- if((prevp = freep) == 0){
- c8c: e5953000 ldr r3, [r5]
- malloc(uint nbytes)
- {
- Header *p, *prevp;
- uint nunits;
- nunits = (nbytes + sizeof(Header) - 1)/sizeof(Header) + 1;
- c90: e2844001 add r4, r4, #1
- if((prevp = freep) == 0){
- c94: e3530000 cmp r3, #0
- c98: 0a00002b beq d4c <malloc+0xd4>
- c9c: e5930000 ldr r0, [r3]
- ca0: e5902004 ldr r2, [r0, #4]
- base.s.ptr = freep = prevp = &base;
- base.s.size = 0;
- }
- for(p = prevp->s.ptr; ; prevp = p, p = p->s.ptr){
- if(p->s.size >= nunits){
- ca4: e1520004 cmp r2, r4
- ca8: 2a00001b bcs d1c <malloc+0xa4>
- morecore(uint nu)
- {
- char *p;
- Header *hp;
- if(nu < 4096)
- cac: e59f80ac ldr r8, [pc, #172] ; d60 <malloc+0xe8>
- p->s.size -= nunits;
- p += p->s.size;
- p->s.size = nunits;
- }
- freep = prevp;
- return (void*)(p + 1);
- cb0: e1a07184 lsl r7, r4, #3
- cb4: ea000003 b cc8 <malloc+0x50>
- nunits = (nbytes + sizeof(Header) - 1)/sizeof(Header) + 1;
- if((prevp = freep) == 0){
- base.s.ptr = freep = prevp = &base;
- base.s.size = 0;
- }
- for(p = prevp->s.ptr; ; prevp = p, p = p->s.ptr){
- cb8: e5930000 ldr r0, [r3]
- if(p->s.size >= nunits){
- cbc: e5902004 ldr r2, [r0, #4]
- cc0: e1540002 cmp r4, r2
- cc4: 9a000014 bls d1c <malloc+0xa4>
- p->s.size = nunits;
- }
- freep = prevp;
- return (void*)(p + 1);
- }
- if(p == freep)
- cc8: e5952000 ldr r2, [r5]
- ccc: e1a03000 mov r3, r0
- cd0: e1500002 cmp r0, r2
- cd4: 1afffff7 bne cb8 <malloc+0x40>
- morecore(uint nu)
- {
- char *p;
- Header *hp;
- if(nu < 4096)
- cd8: e1540008 cmp r4, r8
- nu = 4096;
- p = sbrk(nu * sizeof(Header));
- cdc: 81a00007 movhi r0, r7
- ce0: 93a00902 movls r0, #32768 ; 0x8000
- morecore(uint nu)
- {
- char *p;
- Header *hp;
- if(nu < 4096)
- ce4: 81a06004 movhi r6, r4
- ce8: 93a06a01 movls r6, #4096 ; 0x1000
- nu = 4096;
- p = sbrk(nu * sizeof(Header));
- cec: ebfffeec bl 8a4 <sbrk>
- cf0: e1a03000 mov r3, r0
- if(p == (char*)-1)
- cf4: e3730001 cmn r3, #1
- return 0;
- hp = (Header*)p;
- hp->s.size = nu;
- free((void*)(hp + 1));
- cf8: e2800008 add r0, r0, #8
- Header *hp;
- if(nu < 4096)
- nu = 4096;
- p = sbrk(nu * sizeof(Header));
- if(p == (char*)-1)
- cfc: 0a000010 beq d44 <malloc+0xcc>
- return 0;
- hp = (Header*)p;
- hp->s.size = nu;
- d00: e5836004 str r6, [r3, #4]
- free((void*)(hp + 1));
- d04: ebffffb2 bl bd4 <free>
- return freep;
- d08: e5953000 ldr r3, [r5]
- }
- freep = prevp;
- return (void*)(p + 1);
- }
- if(p == freep)
- if((p = morecore(nunits)) == 0)
- d0c: e3530000 cmp r3, #0
- d10: 1affffe8 bne cb8 <malloc+0x40>
- return 0;
- d14: e1a00003 mov r0, r3
- }
- }
- d18: e8bd89f8 pop {r3, r4, r5, r6, r7, r8, fp, pc}
- base.s.ptr = freep = prevp = &base;
- base.s.size = 0;
- }
- for(p = prevp->s.ptr; ; prevp = p, p = p->s.ptr){
- if(p->s.size >= nunits){
- if(p->s.size == nunits)
- d1c: e1540002 cmp r4, r2
- prevp->s.ptr = p->s.ptr;
- else {
- p->s.size -= nunits;
- d20: 10642002 rsbne r2, r4, r2
- d24: 15802004 strne r2, [r0, #4]
- base.s.size = 0;
- }
- for(p = prevp->s.ptr; ; prevp = p, p = p->s.ptr){
- if(p->s.size >= nunits){
- if(p->s.size == nunits)
- prevp->s.ptr = p->s.ptr;
- d28: 05902000 ldreq r2, [r0]
- else {
- p->s.size -= nunits;
- p += p->s.size;
- d2c: 10800182 addne r0, r0, r2, lsl #3
- base.s.size = 0;
- }
- for(p = prevp->s.ptr; ; prevp = p, p = p->s.ptr){
- if(p->s.size >= nunits){
- if(p->s.size == nunits)
- prevp->s.ptr = p->s.ptr;
- d30: 05832000 streq r2, [r3]
- else {
- p->s.size -= nunits;
- p += p->s.size;
- p->s.size = nunits;
- d34: 15804004 strne r4, [r0, #4]
- }
- freep = prevp;
- d38: e5853000 str r3, [r5]
- return (void*)(p + 1);
- d3c: e2800008 add r0, r0, #8
- d40: e8bd89f8 pop {r3, r4, r5, r6, r7, r8, fp, pc}
- }
- if(p == freep)
- if((p = morecore(nunits)) == 0)
- return 0;
- d44: e3a00000 mov r0, #0
- d48: e8bd89f8 pop {r3, r4, r5, r6, r7, r8, fp, pc}
- Header *p, *prevp;
- uint nunits;
- nunits = (nbytes + sizeof(Header) - 1)/sizeof(Header) + 1;
- if((prevp = freep) == 0){
- base.s.ptr = freep = prevp = &base;
- d4c: e2850004 add r0, r5, #4
- d50: e5850000 str r0, [r5]
- base.s.size = 0;
- d54: e9850009 stmib r5, {r0, r3}
- d58: eaffffd3 b cac <malloc+0x34>
- d5c: 00000de0 .word 0x00000de0
- d60: 00000fff .word 0x00000fff
|