Debugging tool for mbed enabled microcontrollers, especially for NUCLEO-F303RE and STM32F042F6P6.
debug_register.cpp@11:90164cad21ed, 2019-05-09 (annotated)
- Committer:
- bieleluk
- Date:
- Thu May 09 21:24:31 2019 +0000
- Revision:
- 11:90164cad21ed
- Parent:
- 9:59344a584e18
- Child:
- 12:a8ab6e018422
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
bieleluk | 0:e36b454cc2e6 | 1 | #include "Debug.h" |
bieleluk | 0:e36b454cc2e6 | 2 | |
bieleluk | 3:3d7837ae4a37 | 3 | |
bieleluk | 0:e36b454cc2e6 | 4 | // create object of class Debug_register |
bieleluk | 0:e36b454cc2e6 | 5 | //------------------------------------------------------------------------------------------------------------------ |
bieleluk | 0:e36b454cc2e6 | 6 | Debug_register::Debug_register(PinName tx_pin, PinName rx_pin, int baudrate) : pc(tx_pin,rx_pin, baudrate) { |
bieleluk | 0:e36b454cc2e6 | 7 | init(); |
bieleluk | 0:e36b454cc2e6 | 8 | } |
bieleluk | 0:e36b454cc2e6 | 9 | |
bieleluk | 0:e36b454cc2e6 | 10 | // init function |
bieleluk | 0:e36b454cc2e6 | 11 | //------------------------------------------------------------------------------------------------------------------ |
bieleluk | 0:e36b454cc2e6 | 12 | void Debug_register::init() { |
bieleluk | 0:e36b454cc2e6 | 13 | pc.printf("\ec"); |
bieleluk | 0:e36b454cc2e6 | 14 | wait_ms(50); |
bieleluk | 0:e36b454cc2e6 | 15 | pc.printf("-----------------\n\r|\e[1m\e[97;40m\e[93;40mBREAKPOINT AREA\e[22m\e[97;40m|\n\r-----------------\n\r\033[s"); |
bieleluk | 0:e36b454cc2e6 | 16 | pc.printf("serial successfully initialised\n\r\e[32;40mto start program press any button\e[97;40m"); |
bieleluk | 0:e36b454cc2e6 | 17 | breakpoint_count=0; |
bieleluk | 0:e36b454cc2e6 | 18 | pc.getc(); |
bieleluk | 0:e36b454cc2e6 | 19 | pc.printf("\r\e[2K\e[31;40mprogram is running\e[97;40m\r"); |
bieleluk | 0:e36b454cc2e6 | 20 | |
bieleluk | 0:e36b454cc2e6 | 21 | pc.printf("\033[14;0H------------------\n\r|\e[1m\e[93;40mSERIAL PORT AREA\e[22m\e[97;40m|\n\r------------------\n\r\033[s"); |
bieleluk | 0:e36b454cc2e6 | 22 | } |
bieleluk | 0:e36b454cc2e6 | 23 | |
bieleluk | 0:e36b454cc2e6 | 24 | |
bieleluk | 0:e36b454cc2e6 | 25 | |
bieleluk | 0:e36b454cc2e6 | 26 | |
bieleluk | 0:e36b454cc2e6 | 27 | // perform one breakpoint and print one register |
bieleluk | 0:e36b454cc2e6 | 28 | //------------------------------------------------------------------------------------------------------------------ |
bieleluk | 6:1ee26b7b9c2f | 29 | void Debug_register::breakpoint(int line_number, uint32_t address){ |
bieleluk | 3:3d7837ae4a37 | 30 | |
bieleluk | 3:3d7837ae4a37 | 31 | uint32_t reg; |
bieleluk | 3:3d7837ae4a37 | 32 | |
bieleluk | 3:3d7837ae4a37 | 33 | address -= address%4; |
bieleluk | 3:3d7837ae4a37 | 34 | //int horizontal_location = 46; |
bieleluk | 3:3d7837ae4a37 | 35 | |
bieleluk | 0:e36b454cc2e6 | 36 | |
bieleluk | 3:3d7837ae4a37 | 37 | |
bieleluk | 3:3d7837ae4a37 | 38 | |
bieleluk | 3:3d7837ae4a37 | 39 | char sign; |
bieleluk | 0:e36b454cc2e6 | 40 | pc.printf("\e[s"); |
bieleluk | 0:e36b454cc2e6 | 41 | wait_ms(50); |
bieleluk | 0:e36b454cc2e6 | 42 | breakpoint_count++; |
bieleluk | 3:3d7837ae4a37 | 43 | |
bieleluk | 3:3d7837ae4a37 | 44 | while(1){ |
bieleluk | 3:3d7837ae4a37 | 45 | address -= address%4; |
bieleluk | 3:3d7837ae4a37 | 46 | clear_from_n_up_to_m(13,3); |
bieleluk | 3:3d7837ae4a37 | 47 | |
bieleluk | 3:3d7837ae4a37 | 48 | if (line_number < 0){ |
bieleluk | 3:3d7837ae4a37 | 49 | pc.printf(" Breakpoint number %d\t unknown line number\n\r",breakpoint_count); |
bieleluk | 3:3d7837ae4a37 | 50 | }else{ |
bieleluk | 3:3d7837ae4a37 | 51 | pc.printf("| Breakpoint number %d\tline number %d\n\r",breakpoint_count, line_number); |
bieleluk | 3:3d7837ae4a37 | 52 | } |
bieleluk | 3:3d7837ae4a37 | 53 | |
bieleluk | 3:3d7837ae4a37 | 54 | reg = read_word(address, 0); |
bieleluk | 3:3d7837ae4a37 | 55 | //reg = *((volatile unsigned int *)address); |
bieleluk | 3:3d7837ae4a37 | 56 | |
bieleluk | 3:3d7837ae4a37 | 57 | pc.printf("---------------------------------------------------------------------------------------------------------\n\r"); |
bieleluk | 11:90164cad21ed | 58 | pc.printf("| address hex 0x%8x | value hex 0x%8x | address decimal %10u | value decimal %10u |\n\r", address, reg, address, reg); |
bieleluk | 3:3d7837ae4a37 | 59 | pc.printf("---------------------------------------------------------------------------------------------------------\n\r"); |
bieleluk | 3:3d7837ae4a37 | 60 | pc.printf("|bit_num|31|30|29|28|27|26|25|24|23|22|21|20|19|18|17|16|15|14|13|12|11|10| 9| 8| 7| 6| 5| 4| 3| 2| 1| 0|\n\r"); |
bieleluk | 3:3d7837ae4a37 | 61 | pc.printf("---------------------------------------------------------------------------------------------------------\n\r|bit_val|"); |
bieleluk | 3:3d7837ae4a37 | 62 | for (int i = 0; i < 32; i++){ |
bieleluk | 3:3d7837ae4a37 | 63 | pc.printf("%2d|",reg >> (31 - i)); |
bieleluk | 3:3d7837ae4a37 | 64 | reg -= ((reg >> (31 - i)) << (31 - i)); |
bieleluk | 3:3d7837ae4a37 | 65 | } |
bieleluk | 3:3d7837ae4a37 | 66 | pc.printf("\n\r---------------------------------------------------------------------------------------------------------\n\r"); |
bieleluk | 3:3d7837ae4a37 | 67 | |
bieleluk | 3:3d7837ae4a37 | 68 | |
bieleluk | 3:3d7837ae4a37 | 69 | pc.printf("\e[32;40mto continue press enter, to see higher press i, to see lower press j\n\rto read register press r, to write to register press w\e[97;40m"); |
bieleluk | 3:3d7837ae4a37 | 70 | sign = pc.getc(); |
bieleluk | 3:3d7837ae4a37 | 71 | if (sign == 13 || sign == 'P' || sign == 'p'){ |
bieleluk | 3:3d7837ae4a37 | 72 | pc.printf("\r\e[2K\e[31;40mprogram is running\e[97;40m\n\r"); |
bieleluk | 3:3d7837ae4a37 | 73 | pc.printf("\e[u"); |
bieleluk | 3:3d7837ae4a37 | 74 | break; |
bieleluk | 3:3d7837ae4a37 | 75 | }else if (sign == 'i' || sign == 'I'){ |
bieleluk | 3:3d7837ae4a37 | 76 | pc.printf("\e[u"); |
bieleluk | 3:3d7837ae4a37 | 77 | address += 0x4; |
bieleluk | 3:3d7837ae4a37 | 78 | continue; |
bieleluk | 3:3d7837ae4a37 | 79 | }else if (sign == 'k' || sign == 'K'){ |
bieleluk | 3:3d7837ae4a37 | 80 | pc.printf("\e[u"); |
bieleluk | 3:3d7837ae4a37 | 81 | address -= 0x4; |
bieleluk | 3:3d7837ae4a37 | 82 | continue; |
bieleluk | 3:3d7837ae4a37 | 83 | }else if (sign == 'r' || sign == 'R'){ |
bieleluk | 3:3d7837ae4a37 | 84 | pc.printf("\r\e[K\e[12;0H\r\e[K\e[32;40m use l or j to xyzzzzzzzzx\e[97;40m"); |
bieleluk | 3:3d7837ae4a37 | 85 | pc.printf("\e[6;46H"); |
bieleluk | 11:90164cad21ed | 86 | address = modify_value(address, 17); |
bieleluk | 3:3d7837ae4a37 | 87 | continue; |
bieleluk | 3:3d7837ae4a37 | 88 | }else if (sign == 'w' || sign == 'W'){ |
bieleluk | 3:3d7837ae4a37 | 89 | pc.printf("\r\e[K\e[12;0H\r\e[K\e[32;40m use l or j to xxxxxxxxxxx\e[97;40m"); |
bieleluk | 3:3d7837ae4a37 | 90 | pc.printf("\e[6;46H"); |
bieleluk | 11:90164cad21ed | 91 | address = modify_value(address, 17); |
bieleluk | 3:3d7837ae4a37 | 92 | pc.printf("\e[12;0H\r\e[K\e[32;40m use l or j to yyyyyyyx\e[97;40m"); |
bieleluk | 3:3d7837ae4a37 | 93 | pc.printf("\e[6;96H"); |
bieleluk | 9:59344a584e18 | 94 | reg = *((volatile unsigned int *)address); |
bieleluk | 11:90164cad21ed | 95 | reg = modify_value(reg, 40); |
bieleluk | 3:3d7837ae4a37 | 96 | *((volatile unsigned int *)address) = reg; |
bieleluk | 3:3d7837ae4a37 | 97 | continue; |
bieleluk | 3:3d7837ae4a37 | 98 | }else{ |
bieleluk | 3:3d7837ae4a37 | 99 | } |
bieleluk | 0:e36b454cc2e6 | 100 | } |
bieleluk | 0:e36b454cc2e6 | 101 | } |
bieleluk | 0:e36b454cc2e6 | 102 | |
bieleluk | 0:e36b454cc2e6 | 103 | |
bieleluk | 0:e36b454cc2e6 | 104 | |
bieleluk | 0:e36b454cc2e6 | 105 | // print formatted string to debug serial port |
bieleluk | 0:e36b454cc2e6 | 106 | //------------------------------------------------------------------------------------------------------------------ |
bieleluk | 0:e36b454cc2e6 | 107 | int Debug_register::printf(const char* format, ...){ |
bieleluk | 0:e36b454cc2e6 | 108 | |
bieleluk | 0:e36b454cc2e6 | 109 | int ret = pc.printf(format); |
bieleluk | 0:e36b454cc2e6 | 110 | return ret; |
bieleluk | 0:e36b454cc2e6 | 111 | } |
bieleluk | 0:e36b454cc2e6 | 112 | |
bieleluk | 0:e36b454cc2e6 | 113 | // print character to debug serial port |
bieleluk | 0:e36b454cc2e6 | 114 | //------------------------------------------------------------------------------------------------------------------ |
bieleluk | 0:e36b454cc2e6 | 115 | int Debug_register::putc(int character){ |
bieleluk | 0:e36b454cc2e6 | 116 | |
bieleluk | 0:e36b454cc2e6 | 117 | return pc.putc(character); |
bieleluk | 0:e36b454cc2e6 | 118 | } |
bieleluk | 0:e36b454cc2e6 | 119 | |
bieleluk | 0:e36b454cc2e6 | 120 | // read character from debug serial port |
bieleluk | 0:e36b454cc2e6 | 121 | //------------------------------------------------------------------------------------------------------------------ |
bieleluk | 0:e36b454cc2e6 | 122 | int Debug_register::getc(){ |
bieleluk | 0:e36b454cc2e6 | 123 | return pc.getc(); |
bieleluk | 0:e36b454cc2e6 | 124 | } |
bieleluk | 0:e36b454cc2e6 | 125 | |
bieleluk | 0:e36b454cc2e6 | 126 | bool Debug_register::readable(){ |
bieleluk | 0:e36b454cc2e6 | 127 | return pc.readable(); |
bieleluk | 0:e36b454cc2e6 | 128 | } |
bieleluk | 0:e36b454cc2e6 | 129 | |
bieleluk | 2:478ba8b83e3f | 130 | bool Debug_register::writable(){ |
bieleluk | 2:478ba8b83e3f | 131 | return pc.writable(); |
bieleluk | 2:478ba8b83e3f | 132 | } |
bieleluk | 2:478ba8b83e3f | 133 | |
bieleluk | 0:e36b454cc2e6 | 134 | // clear screen from m line up to n line |
bieleluk | 0:e36b454cc2e6 | 135 | //------------------------------------------------------------------------------------------------------------------ |
bieleluk | 0:e36b454cc2e6 | 136 | void Debug_register::clear_from_n_up_to_m(int m, int n){ |
bieleluk | 0:e36b454cc2e6 | 137 | pc.printf("\033[%d;0H",m); |
bieleluk | 0:e36b454cc2e6 | 138 | wait(0.1); |
bieleluk | 0:e36b454cc2e6 | 139 | while (m > n){ |
bieleluk | 0:e36b454cc2e6 | 140 | m--; |
bieleluk | 0:e36b454cc2e6 | 141 | pc.printf("\033[K\033[%d;0H",m); |
bieleluk | 0:e36b454cc2e6 | 142 | } |
bieleluk | 0:e36b454cc2e6 | 143 | pc.printf("\n\r"); |
bieleluk | 0:e36b454cc2e6 | 144 | |
bieleluk | 0:e36b454cc2e6 | 145 | } |
bieleluk | 0:e36b454cc2e6 | 146 | |
bieleluk | 3:3d7837ae4a37 | 147 | uint32_t Debug_register::modify_value(uint32_t value, int horizontal){ |
bieleluk | 3:3d7837ae4a37 | 148 | |
bieleluk | 3:3d7837ae4a37 | 149 | uint32_t tmp = value; |
bieleluk | 3:3d7837ae4a37 | 150 | char val_str[8]; |
bieleluk | 3:3d7837ae4a37 | 151 | int horizontal_min = horizontal; |
bieleluk | 3:3d7837ae4a37 | 152 | char sign; |
bieleluk | 3:3d7837ae4a37 | 153 | |
bieleluk | 9:59344a584e18 | 154 | ONCE_AGAIN: |
bieleluk | 9:59344a584e18 | 155 | pc.printf("\e[6;%dH", horizontal); |
bieleluk | 3:3d7837ae4a37 | 156 | for (int i = 0; i < 8; i++){ |
bieleluk | 3:3d7837ae4a37 | 157 | if ((tmp >> (28 - 4*i)) > 9){ |
bieleluk | 3:3d7837ae4a37 | 158 | val_str[i] = ((tmp >> (28 - 4*i)) + 87); |
bieleluk | 3:3d7837ae4a37 | 159 | }else{ |
bieleluk | 3:3d7837ae4a37 | 160 | val_str[i] = ((tmp >> (28 - 4*i)) + 48); |
bieleluk | 3:3d7837ae4a37 | 161 | } |
bieleluk | 9:59344a584e18 | 162 | pc.putc(val_str[i]); |
bieleluk | 3:3d7837ae4a37 | 163 | tmp -= ((tmp >> (28 - 4*i)) << (28 - 4*i)) ; |
bieleluk | 3:3d7837ae4a37 | 164 | } |
bieleluk | 9:59344a584e18 | 165 | pc.printf("\e[6;%dH", horizontal); |
bieleluk | 9:59344a584e18 | 166 | |
bieleluk | 3:3d7837ae4a37 | 167 | |
bieleluk | 3:3d7837ae4a37 | 168 | |
bieleluk | 3:3d7837ae4a37 | 169 | |
bieleluk | 3:3d7837ae4a37 | 170 | while(1){ |
bieleluk | 3:3d7837ae4a37 | 171 | sign = pc.getc(); |
bieleluk | 3:3d7837ae4a37 | 172 | if (sign == 13){ |
bieleluk | 3:3d7837ae4a37 | 173 | value = (uint32_t)strtol(val_str, NULL, 16); |
bieleluk | 3:3d7837ae4a37 | 174 | break; |
bieleluk | 3:3d7837ae4a37 | 175 | }else if(sign == 'l' || sign == 'L'){ |
bieleluk | 3:3d7837ae4a37 | 176 | horizontal = min(horizontal+1,horizontal_min+7); |
bieleluk | 3:3d7837ae4a37 | 177 | pc.printf("\e[6;%dH",horizontal ); |
bieleluk | 3:3d7837ae4a37 | 178 | continue; |
bieleluk | 3:3d7837ae4a37 | 179 | }else if(sign == 'j' || sign == 'J'){ |
bieleluk | 3:3d7837ae4a37 | 180 | horizontal = max(horizontal-1,horizontal_min); |
bieleluk | 3:3d7837ae4a37 | 181 | pc.printf("\e[6;%dH", horizontal); |
bieleluk | 3:3d7837ae4a37 | 182 | continue; |
bieleluk | 3:3d7837ae4a37 | 183 | }else if ( ((sign >= 48 && sign <= 57) || (sign >= 65 && sign <= 70) || (sign >= 97 && sign <= 102)) && horizontal <= horizontal_min + 7 ){ |
bieleluk | 3:3d7837ae4a37 | 184 | if (sign >= 65 && sign <= 70){ |
bieleluk | 3:3d7837ae4a37 | 185 | val_str[horizontal - horizontal_min] = sign+32; |
bieleluk | 3:3d7837ae4a37 | 186 | pc.putc(sign+32); |
bieleluk | 3:3d7837ae4a37 | 187 | }else{ |
bieleluk | 3:3d7837ae4a37 | 188 | val_str[horizontal - horizontal_min] = sign; |
bieleluk | 3:3d7837ae4a37 | 189 | pc.putc(sign); |
bieleluk | 3:3d7837ae4a37 | 190 | } |
bieleluk | 3:3d7837ae4a37 | 191 | if (horizontal == (horizontal_min+7)){ |
bieleluk | 3:3d7837ae4a37 | 192 | pc.putc('\b'); |
bieleluk | 3:3d7837ae4a37 | 193 | }else{ |
bieleluk | 3:3d7837ae4a37 | 194 | horizontal++; |
bieleluk | 3:3d7837ae4a37 | 195 | } |
bieleluk | 3:3d7837ae4a37 | 196 | continue; |
bieleluk | 9:59344a584e18 | 197 | }else if(sign == 27){ |
bieleluk | 9:59344a584e18 | 198 | horizontal = horizontal_min; |
bieleluk | 9:59344a584e18 | 199 | tmp = value; |
bieleluk | 9:59344a584e18 | 200 | goto ONCE_AGAIN; |
bieleluk | 3:3d7837ae4a37 | 201 | } |
bieleluk | 3:3d7837ae4a37 | 202 | } |
bieleluk | 3:3d7837ae4a37 | 203 | return value; |
bieleluk | 3:3d7837ae4a37 | 204 | } |