semihost server example program
Dependencies: SWD mbed USBLocalFileSystem BaseDAP USBDAP
LPCXpresso LPC11U68 | LPCXpresso LPC1549 | FRDM-KL46Z | EA LPC4088 QSB app-board | LPC1768 app-board | LPC810 | LPC1114FN28 | |
---|---|---|---|---|---|---|---|
server | server | server | server | server | client | client | |
SWDIO | D12 | D12 | D12 | p25 | p21 | p4(P0_2) | p12 |
SWCLK | D10 | D10 | D10 | p26 | p22 | p3(P0_3) | p3 |
nRESET *option | D6 | D6 | D6 | p34 | p30 | p1(P0_5) | p23 |
GND | GND | GND | GND | p1 | p1 | p7 | p22 |
3.3V | P3V3 | P3V3 | P3V3 | p44 | p40 | p6 | p21 |
flash write | SW2(P0_1) | SW3(P1_9) | SW1 | p14 joystick center | p14 joystick center |
client example:
Import programlpc810-semihost_helloworld
semihost client example program
Target2.h@2:32e9437348ad, 2013-09-05 (annotated)
- Committer:
- va009039
- Date:
- Thu Sep 05 09:34:12 2013 +0000
- Revision:
- 2:32e9437348ad
- Parent:
- 1:eb30547ba84d
- Child:
- 3:d7a7cde0bfb8
bug fix sys_writec,sys_exit not resume.
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
va009039 | 2:32e9437348ad | 1 | // Target2.h 2013/9/4 |
va009039 | 0:27d35fa263b5 | 2 | #pragma once |
va009039 | 0:27d35fa263b5 | 3 | #include "mbed.h" |
va009039 | 0:27d35fa263b5 | 4 | #include "SWD.h" |
va009039 | 0:27d35fa263b5 | 5 | |
va009039 | 0:27d35fa263b5 | 6 | #define TARGET_RUNNING (1<<0) |
va009039 | 0:27d35fa263b5 | 7 | #define TARGET_HALTED (1<<1) |
va009039 | 0:27d35fa263b5 | 8 | |
va009039 | 0:27d35fa263b5 | 9 | class Target2; |
va009039 | 0:27d35fa263b5 | 10 | class CoreReg { |
va009039 | 0:27d35fa263b5 | 11 | public: |
va009039 | 0:27d35fa263b5 | 12 | void setup(Target2* target, uint8_t reg); |
va009039 | 0:27d35fa263b5 | 13 | uint32_t read(); |
va009039 | 0:27d35fa263b5 | 14 | void write(uint32_t value); |
va009039 | 0:27d35fa263b5 | 15 | |
va009039 | 0:27d35fa263b5 | 16 | CoreReg& operator= (int value) { |
va009039 | 0:27d35fa263b5 | 17 | write(value); |
va009039 | 0:27d35fa263b5 | 18 | return *this; |
va009039 | 0:27d35fa263b5 | 19 | } |
va009039 | 0:27d35fa263b5 | 20 | |
va009039 | 0:27d35fa263b5 | 21 | CoreReg& operator= (CoreReg& rhs) { |
va009039 | 0:27d35fa263b5 | 22 | write(rhs.read()); |
va009039 | 0:27d35fa263b5 | 23 | return *this; |
va009039 | 0:27d35fa263b5 | 24 | } |
va009039 | 0:27d35fa263b5 | 25 | |
va009039 | 0:27d35fa263b5 | 26 | operator uint32_t() { |
va009039 | 0:27d35fa263b5 | 27 | return read(); |
va009039 | 0:27d35fa263b5 | 28 | } |
va009039 | 0:27d35fa263b5 | 29 | protected: |
va009039 | 0:27d35fa263b5 | 30 | Target2* _target; |
va009039 | 0:27d35fa263b5 | 31 | uint8_t _reg; |
va009039 | 0:27d35fa263b5 | 32 | }; |
va009039 | 0:27d35fa263b5 | 33 | |
va009039 | 0:27d35fa263b5 | 34 | class Target2 { |
va009039 | 0:27d35fa263b5 | 35 | public: |
va009039 | 0:27d35fa263b5 | 36 | Target2(PinName swdio, PinName swclk, PinName reset, Serial* usbpc); |
va009039 | 0:27d35fa263b5 | 37 | bool setup(); |
va009039 | 0:27d35fa263b5 | 38 | uint32_t readMemory(uint32_t addr); |
va009039 | 0:27d35fa263b5 | 39 | void readMemory(uint32_t addr, uint32_t* data, int count); |
va009039 | 0:27d35fa263b5 | 40 | void writeMemory(uint32_t addr, uint32_t data); |
va009039 | 0:27d35fa263b5 | 41 | void writeMemory(uint32_t addr, uint32_t* data, int count); |
va009039 | 1:eb30547ba84d | 42 | uint8_t readMemory8(uint32_t addr); |
va009039 | 1:eb30547ba84d | 43 | void writeMemory8(uint32_t addr, uint8_t data); |
va009039 | 0:27d35fa263b5 | 44 | void halt(); |
va009039 | 0:27d35fa263b5 | 45 | void resume(); |
va009039 | 1:eb30547ba84d | 46 | void step(); |
va009039 | 0:27d35fa263b5 | 47 | void Abort(); |
va009039 | 0:27d35fa263b5 | 48 | void Reset(); |
va009039 | 2:32e9437348ad | 49 | void SoftwareReset(); |
va009039 | 0:27d35fa263b5 | 50 | int getStatus(); |
va009039 | 0:27d35fa263b5 | 51 | bool wait_status(int status, int timeout_ms = 500); |
va009039 | 0:27d35fa263b5 | 52 | CoreReg r0; |
va009039 | 0:27d35fa263b5 | 53 | CoreReg r1; |
va009039 | 0:27d35fa263b5 | 54 | CoreReg r2; |
va009039 | 0:27d35fa263b5 | 55 | CoreReg r3; |
va009039 | 0:27d35fa263b5 | 56 | CoreReg r4; |
va009039 | 0:27d35fa263b5 | 57 | CoreReg r5; |
va009039 | 0:27d35fa263b5 | 58 | CoreReg r6; |
va009039 | 0:27d35fa263b5 | 59 | CoreReg r7; |
va009039 | 0:27d35fa263b5 | 60 | CoreReg r8; |
va009039 | 0:27d35fa263b5 | 61 | CoreReg r9; |
va009039 | 0:27d35fa263b5 | 62 | CoreReg r10; |
va009039 | 0:27d35fa263b5 | 63 | CoreReg r11; |
va009039 | 0:27d35fa263b5 | 64 | CoreReg r12; |
va009039 | 0:27d35fa263b5 | 65 | CoreReg sp; |
va009039 | 0:27d35fa263b5 | 66 | CoreReg lr; |
va009039 | 0:27d35fa263b5 | 67 | CoreReg pc; |
va009039 | 0:27d35fa263b5 | 68 | CoreReg xpsr; |
va009039 | 0:27d35fa263b5 | 69 | private: |
va009039 | 0:27d35fa263b5 | 70 | void _setaddr(uint32_t addr); |
va009039 | 1:eb30547ba84d | 71 | void _setaddr8(uint32_t addr); |
va009039 | 0:27d35fa263b5 | 72 | protected: |
va009039 | 0:27d35fa263b5 | 73 | SWD _swd; |
va009039 | 0:27d35fa263b5 | 74 | Serial* _pc; |
va009039 | 0:27d35fa263b5 | 75 | }; |