; generated by ARM C/C++ Compiler, 4.1 [Build 894]
; commandline ArmCC [--list --split_sections --debug -c --asm --interleave -o.\obj\retarget.o --asm_dir=.\lst\ --list_dir=.\lst\ --depend=.\obj\retarget.d --cpu=Cortex-M0 --apcs=interwork -I..\..\..\..\Library\Device\Nuvoton\Nano1X2Series\Include -I..\..\..\..\Library\StdDriver\inc -I..\..\..\..\Library\CMSIS\Include -IC:\Keil\ARM\RV31\Inc -IC:\Keil\ARM\CMSIS\Include -D__MICROLIB --omf_browse=.\obj\retarget.crf ..\..\..\..\Library\StdDriver\src\retarget.c]
                          THUMB

                          AREA ||i.GetChar||, CODE, READONLY, ALIGN=2

                  GetChar PROC
;;;356    
;;;357    char GetChar(void)
000000  4803              LDR      r0,|L1.16|
                  |L1.2|
;;;358    {
;;;359    #if defined(DEBUG_ENABLE_SEMIHOST)
;;;360    # if defined ( __CC_ARM   )
;;;361        int nRet;
;;;362        while(SH_DoCommand(0x101, 0, &nRet) != 0) {
;;;363            if(nRet != 0) {
;;;364                SH_DoCommand(0x07, 0, &nRet);
;;;365                return (char)nRet;
;;;366            }
;;;367        }
;;;368    # else
;;;369        int nRet;
;;;370        while(SH_DoCommand(0x7, 0, &nRet) != 0) {
;;;371            if(nRet != 0)
;;;372                return (char)nRet;
;;;373        }
;;;374    # endif
;;;375    #endif
;;;376    #ifndef DISABLE_UART
;;;377        while (1) {
;;;378            if(!(UART0->FSR & UART_FSR_RX_EMPTY_F_Msk)) {
000002  6981              LDR      r1,[r0,#0x18]
000004  0789              LSLS     r1,r1,#30
000006  d4fc              BMI      |L1.2|
;;;379                return (UART0->RBR);
000008  6800              LDR      r0,[r0,#0]
00000a  b2c0              UXTB     r0,r0
;;;380    
;;;381            }
;;;382        }
;;;383    #else
;;;384        return(0);
;;;385    #endif
;;;386    }
00000c  4770              BX       lr
;;;387    
                          ENDP

00000e  0000              DCW      0x0000
                  |L1.16|
                          DCD      0x40050000

                          AREA ||i.Hard_Fault_Handler||, CODE, READONLY, ALIGN=2

                  Hard_Fault_Handler PROC
                  ||__tagsym$$used||
;;;50     
;;;51     void Hard_Fault_Handler(uint32_t stack[])
000000  4604              MOV      r4,r0
;;;52     {     
;;;53         printf("In Hard Fault Handler\n");
000002  a003              ADR      r0,|L2.16|
000004  f7fffffe          BL       __2printf
;;;54     
;;;55         stackDump(stack);
000008  4620              MOV      r0,r4
00000a  f7fffffe          BL       stackDump
                  |L2.14|
;;;56         
;;;57         //Chip Reset
;;;58         //SYS_UnlockReg();
;;;59     	//SYS->IPRST_CTL1 |= SYS_IPRST_CTL1_CHIP_RST_Msk;
;;;60     
;;;61         while(1);
00000e  e7fe              B        |L2.14|
;;;62     }
;;;63     
                          ENDP

                  |L2.16|
000010  496e2048          DCB      "In Hard Fault Handler\n",0
000014  61726420
000018  4661756c
00001c  74204861
000020  6e646c65
000024  720a00  
000027  00                DCB      0

                          AREA ||i.IsDebugFifoEmpty||, CODE, READONLY, ALIGN=2

                  IsDebugFifoEmpty PROC
;;;411      */
;;;412    int IsDebugFifoEmpty(void)
000000  4802              LDR      r0,|L3.12|
;;;413    {
;;;414    #ifndef DISABLE_UART
;;;415        return (UART0->FSR & UART_FSR_TE_F_Msk) ? 1 : 0;
000002  6980              LDR      r0,[r0,#0x18]
000004  0500              LSLS     r0,r0,#20
000006  0fc0              LSRS     r0,r0,#31
;;;416    #else
;;;417        return(1);
;;;418    #endif
;;;419    
;;;420    }
000008  4770              BX       lr
;;;421    
                          ENDP

00000a  0000              DCW      0x0000
                  |L3.12|
                          DCD      0x40050000

                          AREA ||i.SendChar||, CODE, READONLY, ALIGN=1

                  SendChar PROC
;;;323    
;;;324    void SendChar(int ch)
000000  b500              PUSH     {lr}
;;;325    {
;;;326    #if defined(DEBUG_ENABLE_SEMIHOST)
;;;327        g_buf[g_buf_len++] = ch;
;;;328        g_buf[g_buf_len] = '\0';
;;;329        if(g_buf_len + 1 >= sizeof(g_buf) || ch == '\n' || ch == '\0') {
;;;330    
;;;331            /* Send the char */
;;;332    
;;;333            if(SH_DoCommand(0x04, (int)g_buf, NULL) != 0) {
;;;334                g_buf_len = 0;
;;;335                return;
;;;336            } else {
;;;337                int i;
;;;338    
;;;339                for(i=0; i<g_buf_len; i++)
;;;340                    SendChar_ToUART(g_buf[i]);
;;;341                g_buf_len = 0;
;;;342            }
;;;343        }
;;;344    #else
;;;345        SendChar_ToUART(ch);
000002  f7fffffe          BL       SendChar_ToUART
;;;346    #endif
;;;347    }
000006  bd00              POP      {pc}
;;;348    
                          ENDP


                          AREA ||i.SendChar_ToUART||, CODE, READONLY, ALIGN=2

                  SendChar_ToUART PROC
;;;304    
;;;305    void SendChar_ToUART(int ch)
000000  4906              LDR      r1,|L5.28|
                  |L5.2|
;;;306    {
;;;307    #ifndef DISABLE_UART
;;;308        while(UART0->FSR & UART_FSR_TX_FULL_F_Msk);
000002  698a              LDR      r2,[r1,#0x18]
000004  0552              LSLS     r2,r2,#21
000006  d4fc              BMI      |L5.2|
;;;309        UART0->THR = ch;
000008  6008              STR      r0,[r1,#0]
;;;310        if(ch == '\n') {
00000a  280a              CMP      r0,#0xa
00000c  d104              BNE      |L5.24|
                  |L5.14|
;;;311            while(UART0->FSR & UART_FSR_TX_FULL_F_Msk);
00000e  6988              LDR      r0,[r1,#0x18]
000010  0540              LSLS     r0,r0,#21
000012  d4fc              BMI      |L5.14|
;;;312            UART0->THR = '\r';
000014  200d              MOVS     r0,#0xd
000016  6008              STR      r0,[r1,#0]
                  |L5.24|
;;;313        }
;;;314    #endif
;;;315    }
000018  4770              BX       lr
;;;316    
                          ENDP

00001a  0000              DCW      0x0000
                  |L5.28|
                          DCD      0x40050000

                          AREA ||i._ttywrch||, CODE, READONLY, ALIGN=1

                  _ttywrch PROC
;;;424    /*---------------------------------------------------------------------------------------------------------*/
;;;425    void _ttywrch(int ch)
000000  b500              PUSH     {lr}
000002  f7fffffe          BL       SendChar_ToUART
;;;426    {
;;;427        SendChar(ch);
;;;428        return;
;;;429    }
000006  bd00              POP      {pc}
;;;430    
                          ENDP


                          AREA ||i.ferror||, CODE, READONLY, ALIGN=1

                  ferror PROC
;;;442    
;;;443    int ferror(FILE *f)
000000  2000              MOVS     r0,#0
;;;444    {
;;;445        return EOF;
000002  43c0              MVNS     r0,r0
;;;446    }
000004  4770              BX       lr
;;;447    
                          ENDP


                          AREA ||i.fgetc||, CODE, READONLY, ALIGN=1

                  fgetc PROC
;;;436    
;;;437    int fgetc(FILE *f)
000000  b500              PUSH     {lr}
;;;438    {
;;;439        return (GetChar());
000002  f7fffffe          BL       GetChar
;;;440    }
000006  bd00              POP      {pc}
;;;441    
                          ENDP


                          AREA ||i.fputc||, CODE, READONLY, ALIGN=1

                  fputc PROC
;;;430    
;;;431    int fputc(int ch, FILE *f)
000000  b500              PUSH     {lr}
;;;432    {
000002  4603              MOV      r3,r0
000004  f7fffffe          BL       SendChar_ToUART
;;;433        SendChar(ch);
;;;434        return ch;
000008  4618              MOV      r0,r3
;;;435    }
00000a  bd00              POP      {pc}
;;;436    
                          ENDP


                          AREA ||i.kbhit||, CODE, READONLY, ALIGN=2

                  kbhit PROC
;;;395      */
;;;396    int kbhit(void)
000000  4802              LDR      r0,|L10.12|
;;;397    {
;;;398    #ifndef DISABLE_UART
;;;399        return !(UART0->FSR & UART_FSR_RX_EMPTY_F_Msk);
000002  6980              LDR      r0,[r0,#0x18]
000004  0780              LSLS     r0,r0,#30
000006  17c0              ASRS     r0,r0,#31
000008  1c40              ADDS     r0,r0,#1
;;;400    #else
;;;401        return(0);
;;;402    #endif
;;;403    }
00000a  4770              BX       lr
;;;404    
                          ENDP

                  |L10.12|
                          DCD      0x40050000

                          AREA ||i.stackDump||, CODE, READONLY, ALIGN=2

                          REQUIRE _printf_percent
                          REQUIRE _printf_x
                          REQUIRE _printf_longlong_hex
                  stackDump PROC
;;;38     
;;;39     void stackDump(uint32_t stack[])
000000  b510              PUSH     {r4,lr}
;;;40     {
000002  4604              MOV      r4,r0
;;;41     	printf("r0  = 0x%x\n", stack[r0]);
000004  6801              LDR      r1,[r0,#0]
000006  a010              ADR      r0,|L11.72|
000008  f7fffffe          BL       __2printf
;;;42     	printf("r1  = 0x%x\n", stack[r1]);
00000c  a011              ADR      r0,|L11.84|
00000e  6861              LDR      r1,[r4,#4]
000010  f7fffffe          BL       __2printf
;;;43     	printf("r2  = 0x%x\n", stack[r2]);
000014  a012              ADR      r0,|L11.96|
000016  68a1              LDR      r1,[r4,#8]
000018  f7fffffe          BL       __2printf
;;;44     	printf("r3  = 0x%x\n", stack[r3]);
00001c  a013              ADR      r0,|L11.108|
00001e  68e1              LDR      r1,[r4,#0xc]
000020  f7fffffe          BL       __2printf
;;;45     	printf("r12 = 0x%x\n", stack[r12]);
000024  a014              ADR      r0,|L11.120|
000026  6921              LDR      r1,[r4,#0x10]
000028  f7fffffe          BL       __2printf
;;;46     	printf("lr  = 0x%x\n", stack[lr]);
00002c  a015              ADR      r0,|L11.132|
00002e  6961              LDR      r1,[r4,#0x14]
000030  f7fffffe          BL       __2printf
;;;47     	printf("pc  = 0x%x\n", stack[pc]);
000034  a016              ADR      r0,|L11.144|
000036  69a1              LDR      r1,[r4,#0x18]
000038  f7fffffe          BL       __2printf
;;;48     	printf("psr = 0x%x\n", stack[psr]);
00003c  a017              ADR      r0,|L11.156|
00003e  69e1              LDR      r1,[r4,#0x1c]
000040  f7fffffe          BL       __2printf
;;;49     } 
000044  bd10              POP      {r4,pc}
;;;50     
                          ENDP

000046  0000              DCW      0x0000
                  |L11.72|
000048  72302020          DCB      "r0  = 0x%x\n",0
00004c  3d203078
000050  25780a00
                  |L11.84|
000054  72312020          DCB      "r1  = 0x%x\n",0
000058  3d203078
00005c  25780a00
                  |L11.96|
000060  72322020          DCB      "r2  = 0x%x\n",0
000064  3d203078
000068  25780a00
                  |L11.108|
00006c  72332020          DCB      "r3  = 0x%x\n",0
000070  3d203078
000074  25780a00
                  |L11.120|
000078  72313220          DCB      "r12 = 0x%x\n",0
00007c  3d203078
000080  25780a00
                  |L11.132|
000084  6c722020          DCB      "lr  = 0x%x\n",0
000088  3d203078
00008c  25780a00
                  |L11.144|
000090  70632020          DCB      "pc  = 0x%x\n",0
000094  3d203078
000098  25780a00
                  |L11.156|
00009c  70737220          DCB      "psr = 0x%x\n",0
0000a0  3d203078
0000a4  25780a00

                          AREA ||.data||, DATA, ALIGN=2

                  __stdout
                          DCD      0x00000000

                          AREA ||area_number.15||, DATA, ALIGN=2

                          EXPORTAS ||area_number.15||, ||.data||
                  __stdin
                          DCD      0x00000000

;*** Start embedded assembler ***

#line 1 "..\\..\\..\\..\\Library\\StdDriver\\src\\retarget.c"
	AREA ||.rev16_text||, CODE, READONLY
	THUMB
	EXPORT |__asm___10_retarget_c_8c64092a____REV16|
#line 118 "..\\..\\..\\..\\Library\\CMSIS\\Include\\core_cmInstr.h"
|__asm___10_retarget_c_8c64092a____REV16| PROC
#line 119

 rev16 r0, r0
 bx lr
	ENDP
	AREA ||.revsh_text||, CODE, READONLY
	THUMB
	EXPORT |__asm___10_retarget_c_8c64092a____REVSH|
#line 132
|__asm___10_retarget_c_8c64092a____REVSH| PROC
#line 133

 revsh r0, r0
 bx lr
	ENDP
	AREA ||.emb_text||, CODE, READONLY
	THUMB
	EXPORT |HardFault_Handler|
#line 278 "..\\..\\..\\..\\Library\\StdDriver\\src\\retarget.c"
|HardFault_Handler| PROC
#line 279

 MOVS r0, #4 
 MOV r1, LR 
 TST r0, r1 
 BEQ Stack_Use_MSP 
 MRS R0, PSP 
 B Get_LR_and_Branch 
Stack_Use_MSP 
 MRS R0, MSP 
Get_LR_and_Branch 
 MOV R1, LR 
 LDR R2,= |Hard_Fault_Handler| 
 BX R2 
	ENDP

;*** End   embedded assembler ***
