Mercurial > hg > Members > innparusu > xv6_rpi_port
diff uprogs/ls.asm @ 0:c450faca55f4
Init
author | Tatsuki IHA <innparusu@cr.ie.u-ryukyu.ac.jp> |
---|---|
date | Sun, 22 Oct 2017 18:25:39 +0900 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/uprogs/ls.asm Sun Oct 22 18:25:39 2017 +0900 @@ -0,0 +1,1997 @@ + +_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