Details | Last modification | View Log | RSS feed
| Rev | Author | Line No. | Line |
|---|---|---|---|
| 1 | mjames | 1 | ;-------------------------------------------------------- |
| 2 | ; File Created by SDCC : FreeWare ANSI-C Compiler |
||
| 3 | ; Version 2.4.4 #831 (Sep 8 2004) |
||
| 4 | ; This file generated Sat Sep 18 08:25:04 2004 |
||
| 5 | ;-------------------------------------------------------- |
||
| 6 | .module rt_task |
||
| 7 | .optsdcc -mmcs51 --model-large |
||
| 8 | |||
| 9 | ;-------------------------------------------------------- |
||
| 10 | ; Public variables in this module |
||
| 11 | ;-------------------------------------------------------- |
||
| 12 | .globl _priotab |
||
| 13 | .globl _TF1 |
||
| 14 | .globl _TR1 |
||
| 15 | .globl _TF0 |
||
| 16 | .globl _TR0 |
||
| 17 | .globl _IE1 |
||
| 18 | .globl _IT1 |
||
| 19 | .globl _IE0 |
||
| 20 | .globl _IT0 |
||
| 21 | .globl _T2CON_7 |
||
| 22 | .globl _T2CON_6 |
||
| 23 | .globl _T2CON_5 |
||
| 24 | .globl _T2CON_4 |
||
| 25 | .globl _T2CON_3 |
||
| 26 | .globl _T2CON_2 |
||
| 27 | .globl _T2CON_1 |
||
| 28 | .globl _T2CON_0 |
||
| 29 | .globl _TF2 |
||
| 30 | .globl _EXF2 |
||
| 31 | .globl _RCLK |
||
| 32 | .globl _TCLK |
||
| 33 | .globl _EXEN2 |
||
| 34 | .globl _TR2 |
||
| 35 | .globl _C_T2 |
||
| 36 | .globl _CP_RL2 |
||
| 37 | .globl _SM0 |
||
| 38 | .globl _SM1 |
||
| 39 | .globl _SM2 |
||
| 40 | .globl _REN |
||
| 41 | .globl _TB8 |
||
| 42 | .globl _RB8 |
||
| 43 | .globl _TI |
||
| 44 | .globl _RI |
||
| 45 | .globl _CY |
||
| 46 | .globl _AC |
||
| 47 | .globl _F0 |
||
| 48 | .globl _RS1 |
||
| 49 | .globl _RS0 |
||
| 50 | .globl _OV |
||
| 51 | .globl _F1 |
||
| 52 | .globl _P |
||
| 53 | .globl _P5_7 |
||
| 54 | .globl _P5_6 |
||
| 55 | .globl _P5_5 |
||
| 56 | .globl _P5_4 |
||
| 57 | .globl _P5_3 |
||
| 58 | .globl _P5_2 |
||
| 59 | .globl _P5_1 |
||
| 60 | .globl _P5_0 |
||
| 61 | .globl _P4_7 |
||
| 62 | .globl _P4_6 |
||
| 63 | .globl _P4_5 |
||
| 64 | .globl _P4_4 |
||
| 65 | .globl _P4_3 |
||
| 66 | .globl _P4_2 |
||
| 67 | .globl _P4_1 |
||
| 68 | .globl _P4_0 |
||
| 69 | .globl _RD |
||
| 70 | .globl _WR |
||
| 71 | .globl _T1 |
||
| 72 | .globl _T0 |
||
| 73 | .globl _INT1 |
||
| 74 | .globl _INT0 |
||
| 75 | .globl _TXD0 |
||
| 76 | .globl _TXD |
||
| 77 | .globl _RXD0 |
||
| 78 | .globl _RXD |
||
| 79 | .globl _P3_7 |
||
| 80 | .globl _P3_6 |
||
| 81 | .globl _P3_5 |
||
| 82 | .globl _P3_4 |
||
| 83 | .globl _P3_3 |
||
| 84 | .globl _P3_2 |
||
| 85 | .globl _P3_1 |
||
| 86 | .globl _P3_0 |
||
| 87 | .globl _P2_7 |
||
| 88 | .globl _P2_6 |
||
| 89 | .globl _P2_5 |
||
| 90 | .globl _P2_4 |
||
| 91 | .globl _P2_3 |
||
| 92 | .globl _P2_2 |
||
| 93 | .globl _P2_1 |
||
| 94 | .globl _P2_0 |
||
| 95 | .globl _P1_7 |
||
| 96 | .globl _P1_6 |
||
| 97 | .globl _P1_5 |
||
| 98 | .globl _P1_4 |
||
| 99 | .globl _P1_3 |
||
| 100 | .globl _P1_2 |
||
| 101 | .globl _P1_1 |
||
| 102 | .globl _P1_0 |
||
| 103 | .globl _P0_7 |
||
| 104 | .globl _P0_6 |
||
| 105 | .globl _P0_5 |
||
| 106 | .globl _P0_4 |
||
| 107 | .globl _P0_3 |
||
| 108 | .globl _P0_2 |
||
| 109 | .globl _P0_1 |
||
| 110 | .globl _P0_0 |
||
| 111 | .globl _PPC |
||
| 112 | .globl _PT2 |
||
| 113 | .globl _PS |
||
| 114 | .globl _PT1 |
||
| 115 | .globl _PX1 |
||
| 116 | .globl _PT0 |
||
| 117 | .globl _PX0 |
||
| 118 | .globl _EA |
||
| 119 | .globl _EC |
||
| 120 | .globl _ET2 |
||
| 121 | .globl _ES |
||
| 122 | .globl _ET1 |
||
| 123 | .globl _EX1 |
||
| 124 | .globl _ET0 |
||
| 125 | .globl _EX0 |
||
| 126 | .globl _CF |
||
| 127 | .globl _CR |
||
| 128 | .globl _CCF4 |
||
| 129 | .globl _CCF3 |
||
| 130 | .globl _CCF2 |
||
| 131 | .globl _CCF1 |
||
| 132 | .globl _CCF0 |
||
| 133 | .globl _BREG_F7 |
||
| 134 | .globl _BREG_F6 |
||
| 135 | .globl _BREG_F5 |
||
| 136 | .globl _BREG_F4 |
||
| 137 | .globl _BREG_F3 |
||
| 138 | .globl _BREG_F2 |
||
| 139 | .globl _BREG_F1 |
||
| 140 | .globl _BREG_F0 |
||
| 141 | .globl _WDTRST |
||
| 142 | .globl _WDTPRG |
||
| 143 | .globl _TMOD |
||
| 144 | .globl _TL2 |
||
| 145 | .globl _TL1 |
||
| 146 | .globl _TL0 |
||
| 147 | .globl _TH2 |
||
| 148 | .globl _TH1 |
||
| 149 | .globl _TH0 |
||
| 150 | .globl _TCON |
||
| 151 | .globl _T2CON |
||
| 152 | .globl _SP |
||
| 153 | .globl _SCON |
||
| 154 | .globl _SBUF0 |
||
| 155 | .globl _SBUF |
||
| 156 | .globl _SADEN0 |
||
| 157 | .globl _RCAP2L |
||
| 158 | .globl _RCAP2H |
||
| 159 | .globl _PSW |
||
| 160 | .globl _PCON |
||
| 161 | .globl _P5 |
||
| 162 | .globl _P4 |
||
| 163 | .globl _P3 |
||
| 164 | .globl _P2 |
||
| 165 | .globl _P1 |
||
| 166 | .globl _P0 |
||
| 167 | .globl _IPH |
||
| 168 | .globl _IP |
||
| 169 | .globl _IE |
||
| 170 | .globl _FCON |
||
| 171 | .globl _EETIM |
||
| 172 | .globl _EECON |
||
| 173 | .globl _DP0L |
||
| 174 | .globl _DPL |
||
| 175 | .globl _DP0H |
||
| 176 | .globl _DPH |
||
| 177 | .globl _CMOD |
||
| 178 | .globl _CL |
||
| 179 | .globl _CKCON |
||
| 180 | .globl _CH |
||
| 181 | .globl _CCON |
||
| 182 | .globl _CCAPM4 |
||
| 183 | .globl _CCAPM3 |
||
| 184 | .globl _CCAPM2 |
||
| 185 | .globl _CCAPM1 |
||
| 186 | .globl _CCAPM0 |
||
| 187 | .globl _CCAP4L |
||
| 188 | .globl _CCAP3L |
||
| 189 | .globl _CCAP2L |
||
| 190 | .globl _CCAP1L |
||
| 191 | .globl _CCAP0L |
||
| 192 | .globl _CCAP4H |
||
| 193 | .globl _CCAP3H |
||
| 194 | .globl _CCAP2H |
||
| 195 | .globl _CCAP1H |
||
| 196 | .globl _CCAP0H |
||
| 197 | .globl _AUXR1 |
||
| 198 | .globl _B |
||
| 199 | .globl _AUXR |
||
| 200 | .globl _ACC |
||
| 201 | .globl _signal_PARM_2 |
||
| 202 | .globl _wait_timed_PARM_2 |
||
| 203 | .globl _start_task_PARM_2 |
||
| 204 | .globl _T10sec |
||
| 205 | .globl _T100ms |
||
| 206 | .globl _T0ctr |
||
| 207 | .globl _reschedule_ea |
||
| 208 | .globl _T0_interrupt_ea |
||
| 209 | .globl _start_stack |
||
| 210 | .globl _task_timer |
||
| 211 | .globl _task_masks |
||
| 212 | .globl _task_signals |
||
| 213 | .globl _stack_save |
||
| 214 | .globl _stack2 |
||
| 215 | .globl _stack1 |
||
| 216 | .globl _stack0 |
||
| 217 | .globl _run |
||
| 218 | .globl _ready |
||
| 219 | .globl _rt_tasks_init |
||
| 220 | .globl _T0Interrupt |
||
| 221 | .globl _reschedule |
||
| 222 | .globl _start_task |
||
| 223 | .globl _end_run_task |
||
| 224 | .globl _wait_timed |
||
| 225 | .globl _sleep |
||
| 226 | .globl _clear_signal |
||
| 227 | .globl _signal |
||
| 228 | .globl _rt_system_init |
||
| 229 | ;-------------------------------------------------------- |
||
| 230 | ; special function registers |
||
| 231 | ;-------------------------------------------------------- |
||
| 232 | .area RSEG (DATA) |
||
| 233 | G$ACC$0$0 == 0x00e0 |
||
| 234 | _ACC = 0x00e0 |
||
| 235 | G$AUXR$0$0 == 0x008e |
||
| 236 | _AUXR = 0x008e |
||
| 237 | G$B$0$0 == 0x00f0 |
||
| 238 | _B = 0x00f0 |
||
| 239 | G$AUXR1$0$0 == 0x00a2 |
||
| 240 | _AUXR1 = 0x00a2 |
||
| 241 | G$CCAP0H$0$0 == 0x00fa |
||
| 242 | _CCAP0H = 0x00fa |
||
| 243 | G$CCAP1H$0$0 == 0x00fb |
||
| 244 | _CCAP1H = 0x00fb |
||
| 245 | G$CCAP2H$0$0 == 0x00fc |
||
| 246 | _CCAP2H = 0x00fc |
||
| 247 | G$CCAP3H$0$0 == 0x00fd |
||
| 248 | _CCAP3H = 0x00fd |
||
| 249 | G$CCAP4H$0$0 == 0x00fe |
||
| 250 | _CCAP4H = 0x00fe |
||
| 251 | G$CCAP0L$0$0 == 0x00ea |
||
| 252 | _CCAP0L = 0x00ea |
||
| 253 | G$CCAP1L$0$0 == 0x00eb |
||
| 254 | _CCAP1L = 0x00eb |
||
| 255 | G$CCAP2L$0$0 == 0x00ec |
||
| 256 | _CCAP2L = 0x00ec |
||
| 257 | G$CCAP3L$0$0 == 0x00ed |
||
| 258 | _CCAP3L = 0x00ed |
||
| 259 | G$CCAP4L$0$0 == 0x00ee |
||
| 260 | _CCAP4L = 0x00ee |
||
| 261 | G$CCAPM0$0$0 == 0x00da |
||
| 262 | _CCAPM0 = 0x00da |
||
| 263 | G$CCAPM1$0$0 == 0x00db |
||
| 264 | _CCAPM1 = 0x00db |
||
| 265 | G$CCAPM2$0$0 == 0x00dc |
||
| 266 | _CCAPM2 = 0x00dc |
||
| 267 | G$CCAPM3$0$0 == 0x00dd |
||
| 268 | _CCAPM3 = 0x00dd |
||
| 269 | G$CCAPM4$0$0 == 0x00de |
||
| 270 | _CCAPM4 = 0x00de |
||
| 271 | G$CCON$0$0 == 0x00d8 |
||
| 272 | _CCON = 0x00d8 |
||
| 273 | G$CH$0$0 == 0x00f9 |
||
| 274 | _CH = 0x00f9 |
||
| 275 | G$CKCON$0$0 == 0x008f |
||
| 276 | _CKCON = 0x008f |
||
| 277 | G$CL$0$0 == 0x00e9 |
||
| 278 | _CL = 0x00e9 |
||
| 279 | G$CMOD$0$0 == 0x00d9 |
||
| 280 | _CMOD = 0x00d9 |
||
| 281 | G$DPH$0$0 == 0x0083 |
||
| 282 | _DPH = 0x0083 |
||
| 283 | G$DP0H$0$0 == 0x0083 |
||
| 284 | _DP0H = 0x0083 |
||
| 285 | G$DPL$0$0 == 0x0082 |
||
| 286 | _DPL = 0x0082 |
||
| 287 | G$DP0L$0$0 == 0x0082 |
||
| 288 | _DP0L = 0x0082 |
||
| 289 | G$EECON$0$0 == 0x00d2 |
||
| 290 | _EECON = 0x00d2 |
||
| 291 | G$EETIM$0$0 == 0x00d3 |
||
| 292 | _EETIM = 0x00d3 |
||
| 293 | G$FCON$0$0 == 0x00d1 |
||
| 294 | _FCON = 0x00d1 |
||
| 295 | G$IE$0$0 == 0x00a8 |
||
| 296 | _IE = 0x00a8 |
||
| 297 | G$IP$0$0 == 0x00b8 |
||
| 298 | _IP = 0x00b8 |
||
| 299 | G$IPH$0$0 == 0x00b7 |
||
| 300 | _IPH = 0x00b7 |
||
| 301 | G$P0$0$0 == 0x0080 |
||
| 302 | _P0 = 0x0080 |
||
| 303 | G$P1$0$0 == 0x0090 |
||
| 304 | _P1 = 0x0090 |
||
| 305 | G$P2$0$0 == 0x00a0 |
||
| 306 | _P2 = 0x00a0 |
||
| 307 | G$P3$0$0 == 0x00b0 |
||
| 308 | _P3 = 0x00b0 |
||
| 309 | G$P4$0$0 == 0x00c0 |
||
| 310 | _P4 = 0x00c0 |
||
| 311 | G$P5$0$0 == 0x00e8 |
||
| 312 | _P5 = 0x00e8 |
||
| 313 | G$PCON$0$0 == 0x0087 |
||
| 314 | _PCON = 0x0087 |
||
| 315 | G$PSW$0$0 == 0x00d0 |
||
| 316 | _PSW = 0x00d0 |
||
| 317 | G$RCAP2H$0$0 == 0x00cb |
||
| 318 | _RCAP2H = 0x00cb |
||
| 319 | G$RCAP2L$0$0 == 0x00ca |
||
| 320 | _RCAP2L = 0x00ca |
||
| 321 | G$SADEN0$0$0 == 0x00b9 |
||
| 322 | _SADEN0 = 0x00b9 |
||
| 323 | G$SBUF$0$0 == 0x0099 |
||
| 324 | _SBUF = 0x0099 |
||
| 325 | G$SBUF0$0$0 == 0x0099 |
||
| 326 | _SBUF0 = 0x0099 |
||
| 327 | G$SCON$0$0 == 0x0098 |
||
| 328 | _SCON = 0x0098 |
||
| 329 | G$SP$0$0 == 0x0081 |
||
| 330 | _SP = 0x0081 |
||
| 331 | G$T2CON$0$0 == 0x00c8 |
||
| 332 | _T2CON = 0x00c8 |
||
| 333 | G$TCON$0$0 == 0x0088 |
||
| 334 | _TCON = 0x0088 |
||
| 335 | G$TH0$0$0 == 0x008c |
||
| 336 | _TH0 = 0x008c |
||
| 337 | G$TH1$0$0 == 0x008d |
||
| 338 | _TH1 = 0x008d |
||
| 339 | G$TH2$0$0 == 0x00cd |
||
| 340 | _TH2 = 0x00cd |
||
| 341 | G$TL0$0$0 == 0x008a |
||
| 342 | _TL0 = 0x008a |
||
| 343 | G$TL1$0$0 == 0x008b |
||
| 344 | _TL1 = 0x008b |
||
| 345 | G$TL2$0$0 == 0x00cc |
||
| 346 | _TL2 = 0x00cc |
||
| 347 | G$TMOD$0$0 == 0x0089 |
||
| 348 | _TMOD = 0x0089 |
||
| 349 | G$WDTPRG$0$0 == 0x00a7 |
||
| 350 | _WDTPRG = 0x00a7 |
||
| 351 | G$WDTRST$0$0 == 0x00a6 |
||
| 352 | _WDTRST = 0x00a6 |
||
| 353 | ;-------------------------------------------------------- |
||
| 354 | ; special function bits |
||
| 355 | ;-------------------------------------------------------- |
||
| 356 | .area RSEG (DATA) |
||
| 357 | G$BREG_F0$0$0 == 0x00f0 |
||
| 358 | _BREG_F0 = 0x00f0 |
||
| 359 | G$BREG_F1$0$0 == 0x00f1 |
||
| 360 | _BREG_F1 = 0x00f1 |
||
| 361 | G$BREG_F2$0$0 == 0x00f2 |
||
| 362 | _BREG_F2 = 0x00f2 |
||
| 363 | G$BREG_F3$0$0 == 0x00f3 |
||
| 364 | _BREG_F3 = 0x00f3 |
||
| 365 | G$BREG_F4$0$0 == 0x00f4 |
||
| 366 | _BREG_F4 = 0x00f4 |
||
| 367 | G$BREG_F5$0$0 == 0x00f5 |
||
| 368 | _BREG_F5 = 0x00f5 |
||
| 369 | G$BREG_F6$0$0 == 0x00f6 |
||
| 370 | _BREG_F6 = 0x00f6 |
||
| 371 | G$BREG_F7$0$0 == 0x00f7 |
||
| 372 | _BREG_F7 = 0x00f7 |
||
| 373 | G$CCF0$0$0 == 0x00d8 |
||
| 374 | _CCF0 = 0x00d8 |
||
| 375 | G$CCF1$0$0 == 0x00d9 |
||
| 376 | _CCF1 = 0x00d9 |
||
| 377 | G$CCF2$0$0 == 0x00da |
||
| 378 | _CCF2 = 0x00da |
||
| 379 | G$CCF3$0$0 == 0x00db |
||
| 380 | _CCF3 = 0x00db |
||
| 381 | G$CCF4$0$0 == 0x00dc |
||
| 382 | _CCF4 = 0x00dc |
||
| 383 | G$CR$0$0 == 0x00de |
||
| 384 | _CR = 0x00de |
||
| 385 | G$CF$0$0 == 0x00df |
||
| 386 | _CF = 0x00df |
||
| 387 | G$EX0$0$0 == 0x00a8 |
||
| 388 | _EX0 = 0x00a8 |
||
| 389 | G$ET0$0$0 == 0x00a9 |
||
| 390 | _ET0 = 0x00a9 |
||
| 391 | G$EX1$0$0 == 0x00aa |
||
| 392 | _EX1 = 0x00aa |
||
| 393 | G$ET1$0$0 == 0x00ab |
||
| 394 | _ET1 = 0x00ab |
||
| 395 | G$ES$0$0 == 0x00ac |
||
| 396 | _ES = 0x00ac |
||
| 397 | G$ET2$0$0 == 0x00ad |
||
| 398 | _ET2 = 0x00ad |
||
| 399 | G$EC$0$0 == 0x00ae |
||
| 400 | _EC = 0x00ae |
||
| 401 | G$EA$0$0 == 0x00af |
||
| 402 | _EA = 0x00af |
||
| 403 | G$PX0$0$0 == 0x00b8 |
||
| 404 | _PX0 = 0x00b8 |
||
| 405 | G$PT0$0$0 == 0x00b9 |
||
| 406 | _PT0 = 0x00b9 |
||
| 407 | G$PX1$0$0 == 0x00ba |
||
| 408 | _PX1 = 0x00ba |
||
| 409 | G$PT1$0$0 == 0x00bb |
||
| 410 | _PT1 = 0x00bb |
||
| 411 | G$PS$0$0 == 0x00bc |
||
| 412 | _PS = 0x00bc |
||
| 413 | G$PT2$0$0 == 0x00bd |
||
| 414 | _PT2 = 0x00bd |
||
| 415 | G$PPC$0$0 == 0x00be |
||
| 416 | _PPC = 0x00be |
||
| 417 | G$P0_0$0$0 == 0x0080 |
||
| 418 | _P0_0 = 0x0080 |
||
| 419 | G$P0_1$0$0 == 0x0081 |
||
| 420 | _P0_1 = 0x0081 |
||
| 421 | G$P0_2$0$0 == 0x0082 |
||
| 422 | _P0_2 = 0x0082 |
||
| 423 | G$P0_3$0$0 == 0x0083 |
||
| 424 | _P0_3 = 0x0083 |
||
| 425 | G$P0_4$0$0 == 0x0084 |
||
| 426 | _P0_4 = 0x0084 |
||
| 427 | G$P0_5$0$0 == 0x0085 |
||
| 428 | _P0_5 = 0x0085 |
||
| 429 | G$P0_6$0$0 == 0x0086 |
||
| 430 | _P0_6 = 0x0086 |
||
| 431 | G$P0_7$0$0 == 0x0087 |
||
| 432 | _P0_7 = 0x0087 |
||
| 433 | G$P1_0$0$0 == 0x0090 |
||
| 434 | _P1_0 = 0x0090 |
||
| 435 | G$P1_1$0$0 == 0x0091 |
||
| 436 | _P1_1 = 0x0091 |
||
| 437 | G$P1_2$0$0 == 0x0092 |
||
| 438 | _P1_2 = 0x0092 |
||
| 439 | G$P1_3$0$0 == 0x0093 |
||
| 440 | _P1_3 = 0x0093 |
||
| 441 | G$P1_4$0$0 == 0x0094 |
||
| 442 | _P1_4 = 0x0094 |
||
| 443 | G$P1_5$0$0 == 0x0095 |
||
| 444 | _P1_5 = 0x0095 |
||
| 445 | G$P1_6$0$0 == 0x0096 |
||
| 446 | _P1_6 = 0x0096 |
||
| 447 | G$P1_7$0$0 == 0x0097 |
||
| 448 | _P1_7 = 0x0097 |
||
| 449 | G$P2_0$0$0 == 0x00a0 |
||
| 450 | _P2_0 = 0x00a0 |
||
| 451 | G$P2_1$0$0 == 0x00a1 |
||
| 452 | _P2_1 = 0x00a1 |
||
| 453 | G$P2_2$0$0 == 0x00a2 |
||
| 454 | _P2_2 = 0x00a2 |
||
| 455 | G$P2_3$0$0 == 0x00a3 |
||
| 456 | _P2_3 = 0x00a3 |
||
| 457 | G$P2_4$0$0 == 0x00a4 |
||
| 458 | _P2_4 = 0x00a4 |
||
| 459 | G$P2_5$0$0 == 0x00a5 |
||
| 460 | _P2_5 = 0x00a5 |
||
| 461 | G$P2_6$0$0 == 0x00a6 |
||
| 462 | _P2_6 = 0x00a6 |
||
| 463 | G$P2_7$0$0 == 0x00a7 |
||
| 464 | _P2_7 = 0x00a7 |
||
| 465 | G$P3_0$0$0 == 0x00b0 |
||
| 466 | _P3_0 = 0x00b0 |
||
| 467 | G$P3_1$0$0 == 0x00b1 |
||
| 468 | _P3_1 = 0x00b1 |
||
| 469 | G$P3_2$0$0 == 0x00b2 |
||
| 470 | _P3_2 = 0x00b2 |
||
| 471 | G$P3_3$0$0 == 0x00b3 |
||
| 472 | _P3_3 = 0x00b3 |
||
| 473 | G$P3_4$0$0 == 0x00b4 |
||
| 474 | _P3_4 = 0x00b4 |
||
| 475 | G$P3_5$0$0 == 0x00b5 |
||
| 476 | _P3_5 = 0x00b5 |
||
| 477 | G$P3_6$0$0 == 0x00b6 |
||
| 478 | _P3_6 = 0x00b6 |
||
| 479 | G$P3_7$0$0 == 0x00b7 |
||
| 480 | _P3_7 = 0x00b7 |
||
| 481 | G$RXD$0$0 == 0x00b0 |
||
| 482 | _RXD = 0x00b0 |
||
| 483 | G$RXD0$0$0 == 0x00b0 |
||
| 484 | _RXD0 = 0x00b0 |
||
| 485 | G$TXD$0$0 == 0x00b1 |
||
| 486 | _TXD = 0x00b1 |
||
| 487 | G$TXD0$0$0 == 0x00b1 |
||
| 488 | _TXD0 = 0x00b1 |
||
| 489 | G$INT0$0$0 == 0x00b2 |
||
| 490 | _INT0 = 0x00b2 |
||
| 491 | G$INT1$0$0 == 0x00b3 |
||
| 492 | _INT1 = 0x00b3 |
||
| 493 | G$T0$0$0 == 0x00b4 |
||
| 494 | _T0 = 0x00b4 |
||
| 495 | G$T1$0$0 == 0x00b5 |
||
| 496 | _T1 = 0x00b5 |
||
| 497 | G$WR$0$0 == 0x00b6 |
||
| 498 | _WR = 0x00b6 |
||
| 499 | G$RD$0$0 == 0x00b7 |
||
| 500 | _RD = 0x00b7 |
||
| 501 | G$P4_0$0$0 == 0x00c0 |
||
| 502 | _P4_0 = 0x00c0 |
||
| 503 | G$P4_1$0$0 == 0x00c1 |
||
| 504 | _P4_1 = 0x00c1 |
||
| 505 | G$P4_2$0$0 == 0x00c2 |
||
| 506 | _P4_2 = 0x00c2 |
||
| 507 | G$P4_3$0$0 == 0x00c3 |
||
| 508 | _P4_3 = 0x00c3 |
||
| 509 | G$P4_4$0$0 == 0x00c4 |
||
| 510 | _P4_4 = 0x00c4 |
||
| 511 | G$P4_5$0$0 == 0x00c5 |
||
| 512 | _P4_5 = 0x00c5 |
||
| 513 | G$P4_6$0$0 == 0x00c6 |
||
| 514 | _P4_6 = 0x00c6 |
||
| 515 | G$P4_7$0$0 == 0x00c7 |
||
| 516 | _P4_7 = 0x00c7 |
||
| 517 | G$P5_0$0$0 == 0x00e8 |
||
| 518 | _P5_0 = 0x00e8 |
||
| 519 | G$P5_1$0$0 == 0x00e9 |
||
| 520 | _P5_1 = 0x00e9 |
||
| 521 | G$P5_2$0$0 == 0x00ea |
||
| 522 | _P5_2 = 0x00ea |
||
| 523 | G$P5_3$0$0 == 0x00eb |
||
| 524 | _P5_3 = 0x00eb |
||
| 525 | G$P5_4$0$0 == 0x00ec |
||
| 526 | _P5_4 = 0x00ec |
||
| 527 | G$P5_5$0$0 == 0x00ed |
||
| 528 | _P5_5 = 0x00ed |
||
| 529 | G$P5_6$0$0 == 0x00ee |
||
| 530 | _P5_6 = 0x00ee |
||
| 531 | G$P5_7$0$0 == 0x00ef |
||
| 532 | _P5_7 = 0x00ef |
||
| 533 | G$P$0$0 == 0x00d0 |
||
| 534 | _P = 0x00d0 |
||
| 535 | G$F1$0$0 == 0x00d1 |
||
| 536 | _F1 = 0x00d1 |
||
| 537 | G$OV$0$0 == 0x00d2 |
||
| 538 | _OV = 0x00d2 |
||
| 539 | G$RS0$0$0 == 0x00d3 |
||
| 540 | _RS0 = 0x00d3 |
||
| 541 | G$RS1$0$0 == 0x00d4 |
||
| 542 | _RS1 = 0x00d4 |
||
| 543 | G$F0$0$0 == 0x00d5 |
||
| 544 | _F0 = 0x00d5 |
||
| 545 | G$AC$0$0 == 0x00d6 |
||
| 546 | _AC = 0x00d6 |
||
| 547 | G$CY$0$0 == 0x00d7 |
||
| 548 | _CY = 0x00d7 |
||
| 549 | G$RI$0$0 == 0x0098 |
||
| 550 | _RI = 0x0098 |
||
| 551 | G$TI$0$0 == 0x0099 |
||
| 552 | _TI = 0x0099 |
||
| 553 | G$RB8$0$0 == 0x009a |
||
| 554 | _RB8 = 0x009a |
||
| 555 | G$TB8$0$0 == 0x009b |
||
| 556 | _TB8 = 0x009b |
||
| 557 | G$REN$0$0 == 0x009c |
||
| 558 | _REN = 0x009c |
||
| 559 | G$SM2$0$0 == 0x009d |
||
| 560 | _SM2 = 0x009d |
||
| 561 | G$SM1$0$0 == 0x009e |
||
| 562 | _SM1 = 0x009e |
||
| 563 | G$SM0$0$0 == 0x009f |
||
| 564 | _SM0 = 0x009f |
||
| 565 | G$CP_RL2$0$0 == 0x00c8 |
||
| 566 | _CP_RL2 = 0x00c8 |
||
| 567 | G$C_T2$0$0 == 0x00c9 |
||
| 568 | _C_T2 = 0x00c9 |
||
| 569 | G$TR2$0$0 == 0x00ca |
||
| 570 | _TR2 = 0x00ca |
||
| 571 | G$EXEN2$0$0 == 0x00cb |
||
| 572 | _EXEN2 = 0x00cb |
||
| 573 | G$TCLK$0$0 == 0x00cc |
||
| 574 | _TCLK = 0x00cc |
||
| 575 | G$RCLK$0$0 == 0x00cd |
||
| 576 | _RCLK = 0x00cd |
||
| 577 | G$EXF2$0$0 == 0x00ce |
||
| 578 | _EXF2 = 0x00ce |
||
| 579 | G$TF2$0$0 == 0x00cf |
||
| 580 | _TF2 = 0x00cf |
||
| 581 | G$T2CON_0$0$0 == 0x00c8 |
||
| 582 | _T2CON_0 = 0x00c8 |
||
| 583 | G$T2CON_1$0$0 == 0x00c9 |
||
| 584 | _T2CON_1 = 0x00c9 |
||
| 585 | G$T2CON_2$0$0 == 0x00ca |
||
| 586 | _T2CON_2 = 0x00ca |
||
| 587 | G$T2CON_3$0$0 == 0x00cb |
||
| 588 | _T2CON_3 = 0x00cb |
||
| 589 | G$T2CON_4$0$0 == 0x00cc |
||
| 590 | _T2CON_4 = 0x00cc |
||
| 591 | G$T2CON_5$0$0 == 0x00cd |
||
| 592 | _T2CON_5 = 0x00cd |
||
| 593 | G$T2CON_6$0$0 == 0x00ce |
||
| 594 | _T2CON_6 = 0x00ce |
||
| 595 | G$T2CON_7$0$0 == 0x00cf |
||
| 596 | _T2CON_7 = 0x00cf |
||
| 597 | G$IT0$0$0 == 0x0088 |
||
| 598 | _IT0 = 0x0088 |
||
| 599 | G$IE0$0$0 == 0x0089 |
||
| 600 | _IE0 = 0x0089 |
||
| 601 | G$IT1$0$0 == 0x008a |
||
| 602 | _IT1 = 0x008a |
||
| 603 | G$IE1$0$0 == 0x008b |
||
| 604 | _IE1 = 0x008b |
||
| 605 | G$TR0$0$0 == 0x008c |
||
| 606 | _TR0 = 0x008c |
||
| 607 | G$TF0$0$0 == 0x008d |
||
| 608 | _TF0 = 0x008d |
||
| 609 | G$TR1$0$0 == 0x008e |
||
| 610 | _TR1 = 0x008e |
||
| 611 | G$TF1$0$0 == 0x008f |
||
| 612 | _TF1 = 0x008f |
||
| 613 | ;-------------------------------------------------------- |
||
| 614 | ; overlayable register banks |
||
| 615 | ;-------------------------------------------------------- |
||
| 616 | .area REG_BANK_0 (REL,OVR,DATA) |
||
| 617 | .ds 8 |
||
| 618 | .area REG_BANK_1 (REL,OVR,DATA) |
||
| 619 | .ds 8 |
||
| 620 | .area REG_BANK_2 (REL,OVR,DATA) |
||
| 621 | .ds 8 |
||
| 622 | .area REG_BANK_3 (REL,OVR,DATA) |
||
| 623 | .ds 8 |
||
| 624 | ;-------------------------------------------------------- |
||
| 625 | ; internal ram data |
||
| 626 | ;-------------------------------------------------------- |
||
| 627 | .area DSEG (DATA) |
||
| 628 | G$ready$0$0==. |
||
| 629 | _ready:: |
||
| 630 | .ds 1 |
||
| 631 | G$run$0$0==. |
||
| 632 | _run:: |
||
| 633 | .ds 1 |
||
| 634 | ;-------------------------------------------------------- |
||
| 635 | ; overlayable items in internal ram |
||
| 636 | ;-------------------------------------------------------- |
||
| 637 | .area OSEG (OVR,DATA) |
||
| 638 | ;-------------------------------------------------------- |
||
| 639 | ; indirectly addressable internal ram data |
||
| 640 | ;-------------------------------------------------------- |
||
| 641 | .area ISEG (DATA) |
||
| 642 | G$stack0$0$0==. |
||
| 643 | _stack0:: |
||
| 644 | .ds 41 |
||
| 645 | G$stack1$0$0==. |
||
| 646 | _stack1:: |
||
| 647 | .ds 46 |
||
| 648 | G$stack2$0$0==. |
||
| 649 | _stack2:: |
||
| 650 | .ds 46 |
||
| 651 | G$stack_save$0$0==. |
||
| 652 | _stack_save:: |
||
| 653 | .ds 3 |
||
| 654 | G$task_signals$0$0==. |
||
| 655 | _task_signals:: |
||
| 656 | .ds 3 |
||
| 657 | G$task_masks$0$0==. |
||
| 658 | _task_masks:: |
||
| 659 | .ds 3 |
||
| 660 | G$task_timer$0$0==. |
||
| 661 | _task_timer:: |
||
| 662 | .ds 3 |
||
| 663 | G$start_stack$0$0==. |
||
| 664 | _start_stack:: |
||
| 665 | .ds 3 |
||
| 666 | ;-------------------------------------------------------- |
||
| 667 | ; bit data |
||
| 668 | ;-------------------------------------------------------- |
||
| 669 | .area BSEG (BIT) |
||
| 670 | G$T0_interrupt_ea$0$0==. |
||
| 671 | _T0_interrupt_ea:: |
||
| 672 | .ds 1 |
||
| 673 | G$reschedule_ea$0$0==. |
||
| 674 | _reschedule_ea:: |
||
| 675 | .ds 1 |
||
| 676 | Lstart_task$EA_local$1$1==. |
||
| 677 | _start_task_EA_local_1_1: |
||
| 678 | .ds 1 |
||
| 679 | Lend_run_task$EA_local$1$1==. |
||
| 680 | _end_run_task_EA_local_1_1: |
||
| 681 | .ds 1 |
||
| 682 | Lwait_timed$EA_local$1$1==. |
||
| 683 | _wait_timed_EA_local_1_1: |
||
| 684 | .ds 1 |
||
| 685 | Lsleep$EA_local$1$1==. |
||
| 686 | _sleep_EA_local_1_1: |
||
| 687 | .ds 1 |
||
| 688 | Lclear_signal$EA_local$1$1==. |
||
| 689 | _clear_signal_EA_local_1_1: |
||
| 690 | .ds 1 |
||
| 691 | Lsignal$EA_local$1$1==. |
||
| 692 | _signal_EA_local_1_1: |
||
| 693 | .ds 1 |
||
| 694 | ;-------------------------------------------------------- |
||
| 695 | ; external ram data |
||
| 696 | ;-------------------------------------------------------- |
||
| 697 | .area XSEG (XDATA) |
||
| 698 | G$T0ctr$0$0==. |
||
| 699 | _T0ctr:: |
||
| 700 | .ds 1 |
||
| 701 | G$T100ms$0$0==. |
||
| 702 | _T100ms:: |
||
| 703 | .ds 1 |
||
| 704 | G$T10sec$0$0==. |
||
| 705 | _T10sec:: |
||
| 706 | .ds 1 |
||
| 707 | Lstart_task$tasknum$1$1==. |
||
| 708 | _start_task_PARM_2:: |
||
| 709 | .ds 1 |
||
| 710 | Lstart_task$f$1$1==. |
||
| 711 | _start_task_f_1_1:: |
||
| 712 | .ds 2 |
||
| 713 | Lwait_timed$ticks$1$1==. |
||
| 714 | _wait_timed_PARM_2:: |
||
| 715 | .ds 1 |
||
| 716 | Lwait_timed$signal$1$1==. |
||
| 717 | _wait_timed_signal_1_1:: |
||
| 718 | .ds 1 |
||
| 719 | Lsleep$ticks$1$1==. |
||
| 720 | _sleep_ticks_1_1:: |
||
| 721 | .ds 1 |
||
| 722 | Lclear_signal$pattern$1$1==. |
||
| 723 | _clear_signal_pattern_1_1:: |
||
| 724 | .ds 1 |
||
| 725 | Lsignal$pattern$1$1==. |
||
| 726 | _signal_PARM_2:: |
||
| 727 | .ds 1 |
||
| 728 | Lsignal$task$1$1==. |
||
| 729 | _signal_task_1_1:: |
||
| 730 | .ds 1 |
||
| 731 | ;-------------------------------------------------------- |
||
| 732 | ; external initialized ram data |
||
| 733 | ;-------------------------------------------------------- |
||
| 734 | .area XISEG (XDATA) |
||
| 735 | .area CSEG (CODE) |
||
| 736 | .area GSINIT0 (CODE) |
||
| 737 | .area GSINIT1 (CODE) |
||
| 738 | .area GSINIT2 (CODE) |
||
| 739 | .area GSINIT3 (CODE) |
||
| 740 | .area GSINIT4 (CODE) |
||
| 741 | .area GSINIT5 (CODE) |
||
| 742 | ;-------------------------------------------------------- |
||
| 743 | ; global & static initialisations |
||
| 744 | ;-------------------------------------------------------- |
||
| 745 | .area GSINIT (CODE) |
||
| 746 | .area GSFINAL (CODE) |
||
| 747 | .area GSINIT (CODE) |
||
| 748 | G$rt_system_init$0$0 ==. |
||
| 749 | C$rt_task.c$80$1$1 ==. |
||
| 750 | ;rt_task.c:80: const STACK_PTR_TYPE start_stack[]={ |
||
| 751 | ; genPointerSet |
||
| 752 | ; genNearPointerSet |
||
| 753 | mov r0,#_start_stack |
||
| 754 | mov @r0,#_stack0 |
||
| 755 | ; genPointerSet |
||
| 756 | ; genNearPointerSet |
||
| 757 | mov r0,#(_start_stack + 0x0001) |
||
| 758 | mov @r0,#_stack1 |
||
| 759 | ; genPointerSet |
||
| 760 | ; genNearPointerSet |
||
| 761 | mov r0,#(_start_stack + 0x0002) |
||
| 762 | mov @r0,#_stack2 |
||
| 763 | ;-------------------------------------------------------- |
||
| 764 | ; Home |
||
| 765 | ;-------------------------------------------------------- |
||
| 766 | .area HOME (CODE) |
||
| 767 | .area CSEG (CODE) |
||
| 768 | ;-------------------------------------------------------- |
||
| 769 | ; code |
||
| 770 | ;-------------------------------------------------------- |
||
| 771 | .area CSEG (CODE) |
||
| 772 | ;------------------------------------------------------------ |
||
| 773 | ;Allocation info for local variables in function 'rt_tasks_init' |
||
| 774 | ;------------------------------------------------------------ |
||
| 775 | ;i Allocated with name '_rt_tasks_init_i_1_1' |
||
| 776 | ;------------------------------------------------------------ |
||
| 777 | G$rt_tasks_init$0$0 ==. |
||
| 778 | C$rt_task.c$143$0$0 ==. |
||
| 779 | ;rt_task.c:143: void rt_tasks_init (void) |
||
| 780 | ; ----------------------------------------- |
||
| 781 | ; function rt_tasks_init |
||
| 782 | ; ----------------------------------------- |
||
| 783 | _rt_tasks_init: |
||
| 784 | ar2 = 0x02 |
||
| 785 | ar3 = 0x03 |
||
| 786 | ar4 = 0x04 |
||
| 787 | ar5 = 0x05 |
||
| 788 | ar6 = 0x06 |
||
| 789 | ar7 = 0x07 |
||
| 790 | ar0 = 0x00 |
||
| 791 | ar1 = 0x01 |
||
| 792 | C$rt_task.c$146$1$1 ==. |
||
| 793 | ;rt_task.c:146: run = MAIN_TASK_ID; |
||
| 794 | ; genAssign |
||
| 795 | mov _run,#0x00 |
||
| 796 | C$rt_task.c$147$1$1 ==. |
||
| 797 | ;rt_task.c:147: ready = TASK_BIT(MAIN_TASK_ID); |
||
| 798 | ; genAssign |
||
| 799 | mov _ready,#0x01 |
||
| 800 | C$rt_task.c$149$1$1 ==. |
||
| 801 | ;rt_task.c:149: for(i=0;i<TASKS;i++) |
||
| 802 | ; genAssign |
||
| 803 | mov r2,#0x00 |
||
| 804 | 00101$: |
||
| 805 | ; genCmpLt |
||
| 806 | ; genCmp |
||
| 807 | clr c |
||
| 808 | mov a,r2 |
||
| 809 | xrl a,#0x80 |
||
| 810 | subb a,#0x83 |
||
| 811 | ; genIfxJump |
||
| 812 | ; Peephole 108 removed ljmp by inverse jump logic |
||
| 813 | jnc 00105$ |
||
| 814 | 00109$: |
||
| 815 | C$rt_task.c$151$2$2 ==. |
||
| 816 | ;rt_task.c:151: stack_save[i] = 0; |
||
| 817 | ; genPlus |
||
| 818 | ; Peephole 236.g used r2 instead of ar2 |
||
| 819 | mov a,r2 |
||
| 820 | add a,#_stack_save |
||
| 821 | mov r0,a |
||
| 822 | ; genAssign |
||
| 823 | mov r3,#0x00 |
||
| 824 | ; genPointerSet |
||
| 825 | ; genNearPointerSet |
||
| 826 | mov @r0,ar3 |
||
| 827 | C$rt_task.c$152$2$2 ==. |
||
| 828 | ;rt_task.c:152: task_signals[i]=0; |
||
| 829 | ; genPlus |
||
| 830 | ; Peephole 236.g used r2 instead of ar2 |
||
| 831 | mov a,r2 |
||
| 832 | add a,#_task_signals |
||
| 833 | ; genPointerSet |
||
| 834 | ; genNearPointerSet |
||
| 835 | ; Peephole 239 used a instead of acc |
||
| 836 | mov r0,a |
||
| 837 | mov @r0,#0x00 |
||
| 838 | C$rt_task.c$153$2$2 ==. |
||
| 839 | ;rt_task.c:153: task_masks[i] =0; |
||
| 840 | ; genPlus |
||
| 841 | ; Peephole 236.g used r2 instead of ar2 |
||
| 842 | mov a,r2 |
||
| 843 | add a,#_task_masks |
||
| 844 | ; genPointerSet |
||
| 845 | ; genNearPointerSet |
||
| 846 | ; Peephole 239 used a instead of acc |
||
| 847 | mov r0,a |
||
| 848 | mov @r0,#0x00 |
||
| 849 | C$rt_task.c$154$2$2 ==. |
||
| 850 | ;rt_task.c:154: task_timer[i] =0; |
||
| 851 | ; genPlus |
||
| 852 | ; Peephole 236.g used r2 instead of ar2 |
||
| 853 | mov a,r2 |
||
| 854 | add a,#_task_timer |
||
| 855 | ; genPointerSet |
||
| 856 | ; genNearPointerSet |
||
| 857 | ; Peephole 239 used a instead of acc |
||
| 858 | mov r0,a |
||
| 859 | mov @r0,#0x00 |
||
| 860 | C$rt_task.c$149$1$1 ==. |
||
| 861 | ;rt_task.c:149: for(i=0;i<TASKS;i++) |
||
| 862 | ; genPlus |
||
| 863 | ; genPlusIncr |
||
| 864 | inc r2 |
||
| 865 | ; Peephole 112.b changed ljmp to sjmp |
||
| 866 | sjmp 00101$ |
||
| 867 | 00105$: |
||
| 868 | C$rt_task.c$157$1$1 ==. |
||
| 869 | XG$rt_tasks_init$0$0 ==. |
||
| 870 | ret |
||
| 871 | ;------------------------------------------------------------ |
||
| 872 | ;Allocation info for local variables in function 'T0Interrupt' |
||
| 873 | ;------------------------------------------------------------ |
||
| 874 | ;i Allocated with name '_T0Interrupt_i_2_2' |
||
| 875 | ;------------------------------------------------------------ |
||
| 876 | G$T0Interrupt$0$0 ==. |
||
| 877 | C$rt_task.c$170$1$1 ==. |
||
| 878 | ;rt_task.c:170: void T0Interrupt(void) interrupt T0_INTVEC using T0_INTERRUPT_BANK |
||
| 879 | ; ----------------------------------------- |
||
| 880 | ; function T0Interrupt |
||
| 881 | ; ----------------------------------------- |
||
| 882 | _T0Interrupt: |
||
| 883 | ar2 = 0x12 |
||
| 884 | ar3 = 0x13 |
||
| 885 | ar4 = 0x14 |
||
| 886 | ar5 = 0x15 |
||
| 887 | ar6 = 0x16 |
||
| 888 | ar7 = 0x17 |
||
| 889 | ar0 = 0x10 |
||
| 890 | ar1 = 0x11 |
||
| 891 | push acc |
||
| 892 | push b |
||
| 893 | push dpl |
||
| 894 | push dph |
||
| 895 | push psw |
||
| 896 | mov psw,#0x10 |
||
| 897 | C$rt_task.c$173$1$1 ==. |
||
| 898 | ;rt_task.c:173: T0ctr--; |
||
| 899 | ; genMinus |
||
| 900 | mov dptr,#_T0ctr |
||
| 901 | ; genMinusDec |
||
| 902 | movx a,@dptr |
||
| 903 | dec a |
||
| 904 | ; genAssign |
||
| 905 | mov dptr,#_T0ctr |
||
| 906 | movx @dptr,a |
||
| 907 | C$rt_task.c$174$1$1 ==. |
||
| 908 | ;rt_task.c:174: if(T0ctr==0) |
||
| 909 | ; genAssign |
||
| 910 | mov dptr,#_T0ctr |
||
| 911 | movx a,@dptr |
||
| 912 | mov r2,a |
||
| 913 | ; genCmpEq |
||
| 914 | cjne r2,#0x00,00135$ |
||
| 915 | sjmp 00136$ |
||
| 916 | 00135$: |
||
| 917 | ljmp 00113$ |
||
| 918 | 00136$: |
||
| 919 | C$rt_task.c$177$2$2 ==. |
||
| 920 | ;rt_task.c:177: T100ms++; |
||
| 921 | ; genPlus |
||
| 922 | mov dptr,#_T100ms |
||
| 923 | movx a,@dptr |
||
| 924 | add a,#0x01 |
||
| 925 | movx @dptr,a |
||
| 926 | C$rt_task.c$178$2$2 ==. |
||
| 927 | ;rt_task.c:178: if(T100ms & 3) |
||
| 928 | ; genAssign |
||
| 929 | mov dptr,#_T100ms |
||
| 930 | movx a,@dptr |
||
| 931 | ; genAnd |
||
| 932 | ; Peephole 105 removed redundant mov |
||
| 933 | mov r2,a |
||
| 934 | anl a,#0x03 |
||
| 935 | ; Peephole 110 removed ljmp by inverse jump logic |
||
| 936 | jz 00102$ |
||
| 937 | 00137$: |
||
| 938 | C$rt_task.c$179$2$2 ==. |
||
| 939 | ;rt_task.c:179: T0ctr= 11;/* 01,10,11 */ |
||
| 940 | ; genAssign |
||
| 941 | mov dptr,#_T0ctr |
||
| 942 | mov a,#0x0B |
||
| 943 | movx @dptr,a |
||
| 944 | ; Peephole 112.b changed ljmp to sjmp |
||
| 945 | sjmp 00130$ |
||
| 946 | 00102$: |
||
| 947 | C$rt_task.c$181$2$2 ==. |
||
| 948 | ;rt_task.c:181: T0ctr= 12;/* 00 */ |
||
| 949 | ; genAssign |
||
| 950 | mov dptr,#_T0ctr |
||
| 951 | mov a,#0x0C |
||
| 952 | movx @dptr,a |
||
| 953 | C$rt_task.c$183$1$1 ==. |
||
| 954 | ;rt_task.c:183: for (i=0;i<TASKS;i++) |
||
| 955 | 00130$: |
||
| 956 | ; genAssign |
||
| 957 | mov r2,#0x00 |
||
| 958 | mov r3,#0x00 |
||
| 959 | 00118$: |
||
| 960 | ; genCmpLt |
||
| 961 | ; genCmp |
||
| 962 | clr c |
||
| 963 | mov a,r2 |
||
| 964 | subb a,#0x03 |
||
| 965 | mov a,r3 |
||
| 966 | xrl a,#0x80 |
||
| 967 | subb a,#0x80 |
||
| 968 | ; genIfxJump |
||
| 969 | ; Peephole 108 removed ljmp by inverse jump logic |
||
| 970 | jnc 00121$ |
||
| 971 | 00138$: |
||
| 972 | C$rt_task.c$185$3$3 ==. |
||
| 973 | ;rt_task.c:185: if (task_timer[i] != 0) |
||
| 974 | ; genPlus |
||
| 975 | ; Peephole 236.g used r2 instead of ar2 |
||
| 976 | mov a,r2 |
||
| 977 | add a,#_task_timer |
||
| 978 | mov r0,a |
||
| 979 | ; genPointerGet |
||
| 980 | ; genNearPointerGet |
||
| 981 | mov ar4,@r0 |
||
| 982 | ; genCmpEq |
||
| 983 | cjne r4,#0x00,00139$ |
||
| 984 | ; Peephole 112.b changed ljmp to sjmp |
||
| 985 | sjmp 00120$ |
||
| 986 | 00139$: |
||
| 987 | C$rt_task.c$187$4$4 ==. |
||
| 988 | ;rt_task.c:187: task_timer[i]--; |
||
| 989 | ; genPlus |
||
| 990 | ; Peephole 236.g used r2 instead of ar2 |
||
| 991 | mov a,r2 |
||
| 992 | add a,#_task_timer |
||
| 993 | mov r0,a |
||
| 994 | ; genPointerGet |
||
| 995 | ; genNearPointerGet |
||
| 996 | mov ar4,@r0 |
||
| 997 | ; genMinus |
||
| 998 | ; genMinusDec |
||
| 999 | mov a,r4 |
||
| 1000 | dec a |
||
| 1001 | ; genPointerSet |
||
| 1002 | ; genNearPointerSet |
||
| 1003 | mov @r0,acc |
||
| 1004 | C$rt_task.c$188$4$4 ==. |
||
| 1005 | ;rt_task.c:188: if (task_timer[i] == 0) |
||
| 1006 | ; genPlus |
||
| 1007 | ; Peephole 236.g used r2 instead of ar2 |
||
| 1008 | mov a,r2 |
||
| 1009 | add a,#_task_timer |
||
| 1010 | mov r0,a |
||
| 1011 | ; genPointerGet |
||
| 1012 | ; genNearPointerGet |
||
| 1013 | mov ar4,@r0 |
||
| 1014 | ; genCmpEq |
||
| 1015 | ; Peephole 112.b changed ljmp to sjmp |
||
| 1016 | ; Peephole 199 optimized misc jump sequence |
||
| 1017 | cjne r4,#0x00,00120$ |
||
| 1018 | ;00140$: |
||
| 1019 | ; Peephole 200 removed redundant sjmp |
||
| 1020 | 00141$: |
||
| 1021 | C$rt_task.c$190$5$5 ==. |
||
| 1022 | ;rt_task.c:190: task_signals[i] |= TIMER_SIG; |
||
| 1023 | ; genPlus |
||
| 1024 | ; Peephole 236.g used r2 instead of ar2 |
||
| 1025 | mov a,r2 |
||
| 1026 | add a,#_task_signals |
||
| 1027 | mov r0,a |
||
| 1028 | ; genPlus |
||
| 1029 | ; Peephole 236.g used r2 instead of ar2 |
||
| 1030 | mov a,r2 |
||
| 1031 | add a,#_task_signals |
||
| 1032 | mov r1,a |
||
| 1033 | ; genPointerGet |
||
| 1034 | ; genNearPointerGet |
||
| 1035 | mov ar4,@r1 |
||
| 1036 | ; genOr |
||
| 1037 | mov a,#0x80 |
||
| 1038 | orl a,r4 |
||
| 1039 | ; genPointerSet |
||
| 1040 | ; genNearPointerSet |
||
| 1041 | mov @r0,acc |
||
| 1042 | C$rt_task.c$191$5$5 ==. |
||
| 1043 | ;rt_task.c:191: if(task_signals[i] & task_masks[i]) |
||
| 1044 | ; genPlus |
||
| 1045 | ; Peephole 236.g used r2 instead of ar2 |
||
| 1046 | mov a,r2 |
||
| 1047 | add a,#_task_signals |
||
| 1048 | mov r0,a |
||
| 1049 | ; genPointerGet |
||
| 1050 | ; genNearPointerGet |
||
| 1051 | mov ar4,@r0 |
||
| 1052 | ; genPlus |
||
| 1053 | ; Peephole 236.g used r2 instead of ar2 |
||
| 1054 | mov a,r2 |
||
| 1055 | add a,#_task_masks |
||
| 1056 | mov r0,a |
||
| 1057 | ; genPointerGet |
||
| 1058 | ; genNearPointerGet |
||
| 1059 | mov ar5,@r0 |
||
| 1060 | ; genAnd |
||
| 1061 | mov a,r5 |
||
| 1062 | anl a,r4 |
||
| 1063 | ; genIfx |
||
| 1064 | ; genIfxJump |
||
| 1065 | ; Peephole 110 removed ljmp by inverse jump logic |
||
| 1066 | jz 00120$ |
||
| 1067 | 00142$: |
||
| 1068 | C$rt_task.c$193$6$6 ==. |
||
| 1069 | ;rt_task.c:193: ready |= TASK_BIT(i); /* Mapping here */ |
||
| 1070 | ; genLeftShift |
||
| 1071 | mov b,r2 |
||
| 1072 | inc b |
||
| 1073 | mov r4,#0x01 |
||
| 1074 | mov r5,#0x00 |
||
| 1075 | sjmp 00144$ |
||
| 1076 | 00143$: |
||
| 1077 | ; Peephole 254 optimized left shift |
||
| 1078 | mov a,r4 |
||
| 1079 | add a,r4 |
||
| 1080 | mov r4,a |
||
| 1081 | mov a,r5 |
||
| 1082 | rlc a |
||
| 1083 | mov r5,a |
||
| 1084 | 00144$: |
||
| 1085 | djnz b,00143$ |
||
| 1086 | ; genCast |
||
| 1087 | ; genOr |
||
| 1088 | mov a,r4 |
||
| 1089 | orl _ready,a |
||
| 1090 | 00120$: |
||
| 1091 | C$rt_task.c$183$2$2 ==. |
||
| 1092 | ;rt_task.c:183: for (i=0;i<TASKS;i++) |
||
| 1093 | ; genPlus |
||
| 1094 | ; genPlusIncr |
||
| 1095 | inc r2 |
||
| 1096 | ; Peephole 112.b changed ljmp to sjmp |
||
| 1097 | ; Peephole 243 avoided branch to sjmp |
||
| 1098 | cjne r2,#0x00,00118$ |
||
| 1099 | inc r3 |
||
| 1100 | 00145$: |
||
| 1101 | sjmp 00118$ |
||
| 1102 | 00121$: |
||
| 1103 | C$rt_task.c$201$2$2 ==. |
||
| 1104 | ;rt_task.c:201: if(T100ms>=MAXT100ms) |
||
| 1105 | ; genAssign |
||
| 1106 | mov dptr,#_T100ms |
||
| 1107 | movx a,@dptr |
||
| 1108 | mov r2,a |
||
| 1109 | ; genCmpLt |
||
| 1110 | ; genCmp |
||
| 1111 | cjne r2,#0x64,00146$ |
||
| 1112 | 00146$: |
||
| 1113 | ; genIfxJump |
||
| 1114 | ; Peephole 112.b changed ljmp to sjmp |
||
| 1115 | ; Peephole 160 removed sjmp by inverse jump logic |
||
| 1116 | jc 00113$ |
||
| 1117 | 00147$: |
||
| 1118 | C$rt_task.c$203$3$7 ==. |
||
| 1119 | ;rt_task.c:203: T10sec++; |
||
| 1120 | ; genPlus |
||
| 1121 | mov dptr,#_T10sec |
||
| 1122 | movx a,@dptr |
||
| 1123 | add a,#0x01 |
||
| 1124 | movx @dptr,a |
||
| 1125 | C$rt_task.c$204$3$7 ==. |
||
| 1126 | ;rt_task.c:204: T100ms=0; |
||
| 1127 | ; genAssign |
||
| 1128 | mov dptr,#_T100ms |
||
| 1129 | ; Peephole 181 changed mov to clr |
||
| 1130 | clr a |
||
| 1131 | movx @dptr,a |
||
| 1132 | 00113$: |
||
| 1133 | C$rt_task.c$211$1$1 ==. |
||
| 1134 | ;rt_task.c:211: if(!SIO1_CTS && !SIO1_TxBusy && SIO1_TxCount) |
||
| 1135 | ; genIfx |
||
| 1136 | ; genIfxJump |
||
| 1137 | ; Peephole 112.a removed ljmp by inverse jump logic |
||
| 1138 | jb _P1_5,00115$ |
||
| 1139 | 00148$: |
||
| 1140 | ; genIfx |
||
| 1141 | ; genIfxJump |
||
| 1142 | ; Peephole 112.a removed ljmp by inverse jump logic |
||
| 1143 | jb _SIO1_TxBusy,00115$ |
||
| 1144 | 00149$: |
||
| 1145 | ; genAssign |
||
| 1146 | mov dptr,#_SIO1_TxCount |
||
| 1147 | movx a,@dptr |
||
| 1148 | ; genIfx |
||
| 1149 | ; Peephole 105 removed redundant mov |
||
| 1150 | mov r2,a |
||
| 1151 | ; genIfxJump |
||
| 1152 | ; Peephole 110 removed ljmp by inverse jump logic |
||
| 1153 | jz 00115$ |
||
| 1154 | 00150$: |
||
| 1155 | C$rt_task.c$213$2$8 ==. |
||
| 1156 | ;rt_task.c:213: TI=1; |
||
| 1157 | ; genAssign |
||
| 1158 | setb _TI |
||
| 1159 | 00115$: |
||
| 1160 | C$rt_task.c$297$1$1 ==. |
||
| 1161 | ;rt_task.c:297: _endasm; |
||
| 1162 | ; genInline |
||
| 1163 | ; use assembler form of atomic operation for keeping ea |
||
| 1164 | jbc ea,0001$ |
||
| 1165 | clr _T0_interrupt_ea |
||
| 1166 | sjmp 0002$ |
||
| 1167 | 0001$: |
||
| 1168 | setb _T0_interrupt_ea |
||
| 1169 | 0002$: |
||
| 1170 | ; These are in bank 0 |
||
| 1171 | push 7 |
||
| 1172 | push 6 |
||
| 1173 | push 5 |
||
| 1174 | push 4 |
||
| 1175 | push 3 |
||
| 1176 | push 2 |
||
| 1177 | push 1 |
||
| 1178 | push 0 |
||
| 1179 | ; |
||
| 1180 | ; |
||
| 1181 | ; Determine which task was running |
||
| 1182 | ; and save the task SP |
||
| 1183 | ; |
||
| 1184 | mov a,_run |
||
| 1185 | add a,#_stack_save |
||
| 1186 | mov r0,a |
||
| 1187 | mov a,sp |
||
| 1188 | mov @r0,a |
||
| 1189 | ; *********** SCHEDULE CODE HERE |
||
| 1190 | ; |
||
| 1191 | ; look at the task ready flags |
||
| 1192 | mov a,_ready |
||
| 1193 | add a,#0x10 |
||
| 1194 | anl a,#0x3F |
||
| 1195 | mov _ready,a |
||
| 1196 | ; |
||
| 1197 | ; get new running task ID |
||
| 1198 | ; |
||
| 1199 | mov dptr,#_priotab |
||
| 1200 | movc a,@a+dptr |
||
| 1201 | ; |
||
| 1202 | mov _run,a |
||
| 1203 | ; |
||
| 1204 | add a,#_stack_save |
||
| 1205 | mov r0,a |
||
| 1206 | mov a,@r0 |
||
| 1207 | mov sp,a |
||
| 1208 | ; |
||
| 1209 | ; |
||
| 1210 | ; Bank 0 registers in use here |
||
| 1211 | ; |
||
| 1212 | pop 0 |
||
| 1213 | pop 1 |
||
| 1214 | pop 2 |
||
| 1215 | pop 3 |
||
| 1216 | pop 4 |
||
| 1217 | pop 5 |
||
| 1218 | pop 6 |
||
| 1219 | pop 7 |
||
| 1220 | ; |
||
| 1221 | ; this is done in the ISR |
||
| 1222 | ; pop psw |
||
| 1223 | ; pop dph |
||
| 1224 | ; pop dpl |
||
| 1225 | ; pop b |
||
| 1226 | ; pop acc |
||
| 1227 | ; |
||
| 1228 | ; |
||
| 1229 | ; |
||
| 1230 | jnb _T0_interrupt_ea,0010$ |
||
| 1231 | setb ea |
||
| 1232 | 0010$: |
||
| 1233 | 00122$: |
||
| 1234 | pop psw |
||
| 1235 | pop dph |
||
| 1236 | pop dpl |
||
| 1237 | pop b |
||
| 1238 | pop acc |
||
| 1239 | C$rt_task.c$301$1$1 ==. |
||
| 1240 | XG$T0Interrupt$0$0 ==. |
||
| 1241 | reti |
||
| 1242 | ;------------------------------------------------------------ |
||
| 1243 | ;Allocation info for local variables in function 'reschedule' |
||
| 1244 | ;------------------------------------------------------------ |
||
| 1245 | ;------------------------------------------------------------ |
||
| 1246 | G$reschedule$0$0 ==. |
||
| 1247 | C$rt_task.c$328$1$1 ==. |
||
| 1248 | ;rt_task.c:328: void reschedule(void) |
||
| 1249 | ; ----------------------------------------- |
||
| 1250 | ; function reschedule |
||
| 1251 | ; ----------------------------------------- |
||
| 1252 | _reschedule: |
||
| 1253 | ar2 = 0x02 |
||
| 1254 | ar3 = 0x03 |
||
| 1255 | ar4 = 0x04 |
||
| 1256 | ar5 = 0x05 |
||
| 1257 | ar6 = 0x06 |
||
| 1258 | ar7 = 0x07 |
||
| 1259 | ar0 = 0x00 |
||
| 1260 | ar1 = 0x01 |
||
| 1261 | C$rt_task.c$413$1$1 ==. |
||
| 1262 | ;rt_task.c:413: _endasm; |
||
| 1263 | ; genInline |
||
| 1264 | ; use assembler form of atomic operation for keeping ea |
||
| 1265 | jbc ea,0001$ |
||
| 1266 | clr _reschedule_ea |
||
| 1267 | sjmp 0002$ |
||
| 1268 | 0001$: |
||
| 1269 | setb _reschedule_ea |
||
| 1270 | 0002$: |
||
| 1271 | ; this is done in any ISR |
||
| 1272 | push acc |
||
| 1273 | push b |
||
| 1274 | push dpl |
||
| 1275 | push dph |
||
| 1276 | push psw |
||
| 1277 | ; |
||
| 1278 | ; These are in bank 0 |
||
| 1279 | ; |
||
| 1280 | push 7 |
||
| 1281 | push 6 |
||
| 1282 | push 5 |
||
| 1283 | push 4 |
||
| 1284 | push 3 |
||
| 1285 | push 2 |
||
| 1286 | push 1 |
||
| 1287 | push 0 |
||
| 1288 | ; |
||
| 1289 | ; |
||
| 1290 | ; |
||
| 1291 | ; Determine which task was running |
||
| 1292 | ; and save the task SP |
||
| 1293 | ; |
||
| 1294 | mov a,_run |
||
| 1295 | add a,#_stack_save |
||
| 1296 | mov r0,a |
||
| 1297 | mov a,sp |
||
| 1298 | mov @r0,a |
||
| 1299 | ; *********** SCHEDULE CODE HERE |
||
| 1300 | ; |
||
| 1301 | ; look at the task ready flags |
||
| 1302 | mov a,_ready |
||
| 1303 | add a,#0x10 |
||
| 1304 | anl a,#0x3F |
||
| 1305 | mov _ready,a |
||
| 1306 | ; |
||
| 1307 | ; get new running task ID |
||
| 1308 | ; |
||
| 1309 | mov dptr,#_priotab |
||
| 1310 | movc a,@a+dptr |
||
| 1311 | ; |
||
| 1312 | mov _run,a |
||
| 1313 | ; |
||
| 1314 | add a,#_stack_save |
||
| 1315 | mov r0,a |
||
| 1316 | mov a,@r0 |
||
| 1317 | mov sp,a |
||
| 1318 | ; |
||
| 1319 | ; |
||
| 1320 | ; Bank 0 registers in use here |
||
| 1321 | ; |
||
| 1322 | pop 0 |
||
| 1323 | pop 1 |
||
| 1324 | pop 2 |
||
| 1325 | pop 3 |
||
| 1326 | pop 4 |
||
| 1327 | pop 5 |
||
| 1328 | pop 6 |
||
| 1329 | pop 7 |
||
| 1330 | ; |
||
| 1331 | ; this is done in the ISR |
||
| 1332 | pop psw |
||
| 1333 | pop dph |
||
| 1334 | pop dpl |
||
| 1335 | pop b |
||
| 1336 | pop acc |
||
| 1337 | ; |
||
| 1338 | jnb _reschedule_ea,0010$ |
||
| 1339 | setb ea |
||
| 1340 | 0010$: |
||
| 1341 | ; |
||
| 1342 | 00101$: |
||
| 1343 | C$rt_task.c$415$1$1 ==. |
||
| 1344 | XG$reschedule$0$0 ==. |
||
| 1345 | ret |
||
| 1346 | ;------------------------------------------------------------ |
||
| 1347 | ;Allocation info for local variables in function 'start_task' |
||
| 1348 | ;------------------------------------------------------------ |
||
| 1349 | ;tasknum Allocated with name '_start_task_PARM_2' |
||
| 1350 | ;f Allocated with name '_start_task_f_1_1' |
||
| 1351 | ;fp Allocated with name '_start_task_fp_1_1' |
||
| 1352 | ;csp Allocated to registers r0 |
||
| 1353 | ;------------------------------------------------------------ |
||
| 1354 | G$start_task$0$0 ==. |
||
| 1355 | C$rt_task.c$424$1$1 ==. |
||
| 1356 | ;rt_task.c:424: start_rc start_task(task_p f,char tasknum) |
||
| 1357 | ; ----------------------------------------- |
||
| 1358 | ; function start_task |
||
| 1359 | ; ----------------------------------------- |
||
| 1360 | _start_task: |
||
| 1361 | ; genReceive |
||
| 1362 | mov r2,dph |
||
| 1363 | mov a,dpl |
||
| 1364 | mov dptr,#_start_task_f_1_1 |
||
| 1365 | movx @dptr,a |
||
| 1366 | inc dptr |
||
| 1367 | mov a,r2 |
||
| 1368 | movx @dptr,a |
||
| 1369 | C$rt_task.c$429$1$1 ==. |
||
| 1370 | ;rt_task.c:429: if (tasknum >= TASKS) |
||
| 1371 | ; genAssign |
||
| 1372 | mov dptr,#_start_task_PARM_2 |
||
| 1373 | movx a,@dptr |
||
| 1374 | ; genCmpLt |
||
| 1375 | ; genCmp |
||
| 1376 | ; Peephole 106 removed redundant mov |
||
| 1377 | mov r2,a |
||
| 1378 | clr c |
||
| 1379 | xrl a,#0x80 |
||
| 1380 | subb a,#0x83 |
||
| 1381 | ; genIfxJump |
||
| 1382 | ; Peephole 112.b changed ljmp to sjmp |
||
| 1383 | ; Peephole 160 removed sjmp by inverse jump logic |
||
| 1384 | jc 00102$ |
||
| 1385 | 00110$: |
||
| 1386 | C$rt_task.c$430$1$1 ==. |
||
| 1387 | ;rt_task.c:430: return FAILED; |
||
| 1388 | ; genRet |
||
| 1389 | mov dpl,#0x01 |
||
| 1390 | ; Peephole 251.a replaced ljmp to ret with ret |
||
| 1391 | ret |
||
| 1392 | 00102$: |
||
| 1393 | C$rt_task.c$432$2$2 ==. |
||
| 1394 | ;rt_task.c:432: BEGIN_CRITICAL; |
||
| 1395 | ; genIfx |
||
| 1396 | ; genIfxJump |
||
| 1397 | ; Peephole 111 removed ljmp by inverse jump logic |
||
| 1398 | ; genAssign |
||
| 1399 | ; Peephole 250.a using atomic test and clear |
||
| 1400 | jbc _EA,00111$ |
||
| 1401 | sjmp 00104$ |
||
| 1402 | 00111$: |
||
| 1403 | ; genAssign |
||
| 1404 | setb _start_task_EA_local_1_1 |
||
| 1405 | ; Peephole 112.b changed ljmp to sjmp |
||
| 1406 | sjmp 00105$ |
||
| 1407 | 00104$: |
||
| 1408 | ; genAssign |
||
| 1409 | clr _start_task_EA_local_1_1 |
||
| 1410 | 00105$: |
||
| 1411 | C$rt_task.c$433$1$1 ==. |
||
| 1412 | ;rt_task.c:433: csp = start_stack[tasknum]; |
||
| 1413 | ; genPlus |
||
| 1414 | ; Peephole 236.g used r2 instead of ar2 |
||
| 1415 | mov a,r2 |
||
| 1416 | add a,#_start_stack |
||
| 1417 | mov r0,a |
||
| 1418 | ; genPointerGet |
||
| 1419 | ; genNearPointerGet |
||
| 1420 | mov ar0,@r0 |
||
| 1421 | C$rt_task.c$434$1$1 ==. |
||
| 1422 | ;rt_task.c:434: stack_save[tasknum] = (STACK_PTR_TYPE)csp+16 ; |
||
| 1423 | ; genPlus |
||
| 1424 | ; Peephole 236.g used r2 instead of ar2 |
||
| 1425 | mov a,r2 |
||
| 1426 | add a,#_stack_save |
||
| 1427 | mov r1,a |
||
| 1428 | ; genPlus |
||
| 1429 | mov a,#0x10 |
||
| 1430 | ; Peephole 236.a used r0 instead of ar0 |
||
| 1431 | add a,r0 |
||
| 1432 | ; genPointerSet |
||
| 1433 | ; genNearPointerSet |
||
| 1434 | mov @r1,acc |
||
| 1435 | C$rt_task.c$436$1$1 ==. |
||
| 1436 | ;rt_task.c:436: fp = (int)&end_run_task; |
||
| 1437 | ; genCast |
||
| 1438 | mov r3,#_end_run_task |
||
| 1439 | mov r4,#(_end_run_task >> 8) |
||
| 1440 | C$rt_task.c$437$1$1 ==. |
||
| 1441 | ;rt_task.c:437: *csp++ = (char)(fp & 0xff); |
||
| 1442 | ; genAnd |
||
| 1443 | mov ar5,r3 |
||
| 1444 | mov r6,#0x00 |
||
| 1445 | ; genCast |
||
| 1446 | ; genPointerSet |
||
| 1447 | ; genNearPointerSet |
||
| 1448 | mov @r0,ar5 |
||
| 1449 | inc r0 |
||
| 1450 | C$rt_task.c$438$1$1 ==. |
||
| 1451 | ;rt_task.c:438: *csp++ = (char)(fp >> 8) ; |
||
| 1452 | ; genRightShift |
||
| 1453 | ; genSignedRightShift |
||
| 1454 | ; genRightShiftLiteral |
||
| 1455 | ; genrshTwo |
||
| 1456 | mov a,r4 |
||
| 1457 | mov r3,a |
||
| 1458 | rlc a |
||
| 1459 | subb a,acc |
||
| 1460 | mov r4,a |
||
| 1461 | ; genCast |
||
| 1462 | ; genPointerSet |
||
| 1463 | ; genNearPointerSet |
||
| 1464 | mov @r0,ar3 |
||
| 1465 | inc r0 |
||
| 1466 | C$rt_task.c$440$1$1 ==. |
||
| 1467 | ;rt_task.c:440: fp = (int)f; |
||
| 1468 | ; genAssign |
||
| 1469 | mov dptr,#_start_task_f_1_1 |
||
| 1470 | movx a,@dptr |
||
| 1471 | mov r3,a |
||
| 1472 | inc dptr |
||
| 1473 | movx a,@dptr |
||
| 1474 | mov r4,a |
||
| 1475 | ; genCast |
||
| 1476 | C$rt_task.c$441$1$1 ==. |
||
| 1477 | ;rt_task.c:441: *csp++ = (char)(fp &0xff); |
||
| 1478 | ; genAnd |
||
| 1479 | mov ar5,r3 |
||
| 1480 | mov r6,#0x00 |
||
| 1481 | ; genCast |
||
| 1482 | ; genPointerSet |
||
| 1483 | ; genNearPointerSet |
||
| 1484 | mov @r0,ar5 |
||
| 1485 | inc r0 |
||
| 1486 | C$rt_task.c$442$1$1 ==. |
||
| 1487 | ;rt_task.c:442: *csp++ = (char)(fp >> 8) ; |
||
| 1488 | ; genRightShift |
||
| 1489 | ; genSignedRightShift |
||
| 1490 | ; genRightShiftLiteral |
||
| 1491 | ; genrshTwo |
||
| 1492 | mov a,r4 |
||
| 1493 | mov r3,a |
||
| 1494 | rlc a |
||
| 1495 | subb a,acc |
||
| 1496 | mov r4,a |
||
| 1497 | ; genCast |
||
| 1498 | ; genPointerSet |
||
| 1499 | ; genNearPointerSet |
||
| 1500 | mov @r0,ar3 |
||
| 1501 | inc r0 |
||
| 1502 | C$rt_task.c$446$1$1 ==. |
||
| 1503 | ;rt_task.c:446: *csp++ = 0; /* csp[4] = acc could pass argument here */ |
||
| 1504 | ; genPointerSet |
||
| 1505 | ; genNearPointerSet |
||
| 1506 | mov @r0,#0x00 |
||
| 1507 | inc r0 |
||
| 1508 | C$rt_task.c$447$1$1 ==. |
||
| 1509 | ;rt_task.c:447: *csp++ = 0; /* csp[5] = b */ |
||
| 1510 | ; genPointerSet |
||
| 1511 | ; genNearPointerSet |
||
| 1512 | mov @r0,#0x00 |
||
| 1513 | inc r0 |
||
| 1514 | C$rt_task.c$448$1$1 ==. |
||
| 1515 | ;rt_task.c:448: *csp++ = 0; /* csp[6] = dpl */ |
||
| 1516 | ; genPointerSet |
||
| 1517 | ; genNearPointerSet |
||
| 1518 | mov @r0,#0x00 |
||
| 1519 | inc r0 |
||
| 1520 | C$rt_task.c$449$1$1 ==. |
||
| 1521 | ;rt_task.c:449: *csp++ = 0; /* csp[7] = dph */ |
||
| 1522 | ; genPointerSet |
||
| 1523 | ; genNearPointerSet |
||
| 1524 | mov @r0,#0x00 |
||
| 1525 | inc r0 |
||
| 1526 | C$rt_task.c$450$1$1 ==. |
||
| 1527 | ;rt_task.c:450: *csp++ = 0; /* psw VITAL */ |
||
| 1528 | ; genPointerSet |
||
| 1529 | ; genNearPointerSet |
||
| 1530 | mov @r0,#0x00 |
||
| 1531 | inc r0 |
||
| 1532 | C$rt_task.c$451$1$1 ==. |
||
| 1533 | ;rt_task.c:451: *csp++ = 0; /* csp [9] = r7 */ |
||
| 1534 | ; genPointerSet |
||
| 1535 | ; genNearPointerSet |
||
| 1536 | mov @r0,#0x00 |
||
| 1537 | inc r0 |
||
| 1538 | C$rt_task.c$452$1$1 ==. |
||
| 1539 | ;rt_task.c:452: *csp++ = 0; /* csp [10] = r6 */ |
||
| 1540 | ; genPointerSet |
||
| 1541 | ; genNearPointerSet |
||
| 1542 | mov @r0,#0x00 |
||
| 1543 | inc r0 |
||
| 1544 | C$rt_task.c$453$1$1 ==. |
||
| 1545 | ;rt_task.c:453: *csp++ = 0; /* csp [11] = r5 */ |
||
| 1546 | ; genPointerSet |
||
| 1547 | ; genNearPointerSet |
||
| 1548 | mov @r0,#0x00 |
||
| 1549 | inc r0 |
||
| 1550 | C$rt_task.c$454$1$1 ==. |
||
| 1551 | ;rt_task.c:454: *csp++ = 0; /* csp [12] = r4 */ |
||
| 1552 | ; genPointerSet |
||
| 1553 | ; genNearPointerSet |
||
| 1554 | mov @r0,#0x00 |
||
| 1555 | inc r0 |
||
| 1556 | C$rt_task.c$455$1$1 ==. |
||
| 1557 | ;rt_task.c:455: *csp++ = 0; /* csp [13] = r3 */ |
||
| 1558 | ; genPointerSet |
||
| 1559 | ; genNearPointerSet |
||
| 1560 | mov @r0,#0x00 |
||
| 1561 | inc r0 |
||
| 1562 | C$rt_task.c$456$1$1 ==. |
||
| 1563 | ;rt_task.c:456: *csp++ = 0; /* csp [14] = r2 */ |
||
| 1564 | ; genPointerSet |
||
| 1565 | ; genNearPointerSet |
||
| 1566 | mov @r0,#0x00 |
||
| 1567 | inc r0 |
||
| 1568 | C$rt_task.c$457$1$1 ==. |
||
| 1569 | ;rt_task.c:457: *csp++ = 0; /* csp [15] = r1 */ |
||
| 1570 | ; genPointerSet |
||
| 1571 | ; genNearPointerSet |
||
| 1572 | mov @r0,#0x00 |
||
| 1573 | inc r0 |
||
| 1574 | C$rt_task.c$458$1$1 ==. |
||
| 1575 | ;rt_task.c:458: *csp = 0; /* csp [16] = r0 */ |
||
| 1576 | ; genPointerSet |
||
| 1577 | ; genNearPointerSet |
||
| 1578 | mov @r0,#0x00 |
||
| 1579 | C$rt_task.c$462$1$1 ==. |
||
| 1580 | ;rt_task.c:462: ready |= TASK_BIT(tasknum); |
||
| 1581 | ; genLeftShift |
||
| 1582 | mov b,r2 |
||
| 1583 | inc b |
||
| 1584 | mov a,#0x01 |
||
| 1585 | sjmp 00114$ |
||
| 1586 | 00112$: |
||
| 1587 | add a,acc |
||
| 1588 | 00114$: |
||
| 1589 | djnz b,00112$ |
||
| 1590 | ; genOr |
||
| 1591 | ; Peephole 105 removed redundant mov |
||
| 1592 | mov r2,a |
||
| 1593 | orl _ready,a |
||
| 1594 | C$rt_task.c$463$2$5 ==. |
||
| 1595 | ;rt_task.c:463: END_CRITICAL; |
||
| 1596 | ; genAssign |
||
| 1597 | mov c,_start_task_EA_local_1_1 |
||
| 1598 | mov _EA,c |
||
| 1599 | C$rt_task.c$464$1$1 ==. |
||
| 1600 | ;rt_task.c:464: return STARTED; |
||
| 1601 | ; genRet |
||
| 1602 | mov dpl,#0x02 |
||
| 1603 | 00106$: |
||
| 1604 | C$rt_task.c$465$1$1 ==. |
||
| 1605 | XG$start_task$0$0 ==. |
||
| 1606 | ret |
||
| 1607 | ;------------------------------------------------------------ |
||
| 1608 | ;Allocation info for local variables in function 'end_run_task' |
||
| 1609 | ;------------------------------------------------------------ |
||
| 1610 | ;------------------------------------------------------------ |
||
| 1611 | G$end_run_task$0$0 ==. |
||
| 1612 | C$rt_task.c$471$1$1 ==. |
||
| 1613 | ;rt_task.c:471: void end_run_task(void) |
||
| 1614 | ; ----------------------------------------- |
||
| 1615 | ; function end_run_task |
||
| 1616 | ; ----------------------------------------- |
||
| 1617 | _end_run_task: |
||
| 1618 | C$rt_task.c$475$2$2 ==. |
||
| 1619 | ;rt_task.c:475: BEGIN_CRITICAL; |
||
| 1620 | ; genIfx |
||
| 1621 | ; genIfxJump |
||
| 1622 | ; Peephole 111 removed ljmp by inverse jump logic |
||
| 1623 | ; genAssign |
||
| 1624 | ; Peephole 250.a using atomic test and clear |
||
| 1625 | jbc _EA,00111$ |
||
| 1626 | sjmp 00102$ |
||
| 1627 | 00111$: |
||
| 1628 | ; genAssign |
||
| 1629 | setb _end_run_task_EA_local_1_1 |
||
| 1630 | ; Peephole 112.b changed ljmp to sjmp |
||
| 1631 | sjmp 00103$ |
||
| 1632 | 00102$: |
||
| 1633 | ; genAssign |
||
| 1634 | clr _end_run_task_EA_local_1_1 |
||
| 1635 | 00103$: |
||
| 1636 | C$rt_task.c$476$1$1 ==. |
||
| 1637 | ;rt_task.c:476: ready &= ~TASK_BIT(run); |
||
| 1638 | ; genLeftShift |
||
| 1639 | mov b,_run |
||
| 1640 | inc b |
||
| 1641 | mov a,#0x01 |
||
| 1642 | sjmp 00114$ |
||
| 1643 | 00112$: |
||
| 1644 | add a,acc |
||
| 1645 | 00114$: |
||
| 1646 | djnz b,00112$ |
||
| 1647 | ; genCpl |
||
| 1648 | ; Peephole 105 removed redundant mov |
||
| 1649 | ; genAnd |
||
| 1650 | ; Peephole 105 removed redundant mov |
||
| 1651 | ; Peephole 184 removed redundant mov |
||
| 1652 | cpl a |
||
| 1653 | mov r2,a |
||
| 1654 | anl _ready,a |
||
| 1655 | C$rt_task.c$477$1$1 ==. |
||
| 1656 | ;rt_task.c:477: task_masks[run] = 0; /* Stop any further signals making task ready to run */ |
||
| 1657 | ; genPlus |
||
| 1658 | mov a,_run |
||
| 1659 | add a,#_task_masks |
||
| 1660 | ; genPointerSet |
||
| 1661 | ; genNearPointerSet |
||
| 1662 | ; Peephole 239 used a instead of acc |
||
| 1663 | mov r0,a |
||
| 1664 | mov @r0,#0x00 |
||
| 1665 | C$rt_task.c$478$1$1 ==. |
||
| 1666 | ;rt_task.c:478: task_timer[run] = 0; /* kill off pending task timeout */ |
||
| 1667 | ; genPlus |
||
| 1668 | mov a,_run |
||
| 1669 | add a,#_task_timer |
||
| 1670 | ; genPointerSet |
||
| 1671 | ; genNearPointerSet |
||
| 1672 | ; Peephole 239 used a instead of acc |
||
| 1673 | mov r0,a |
||
| 1674 | mov @r0,#0x00 |
||
| 1675 | C$rt_task.c$479$2$5 ==. |
||
| 1676 | ;rt_task.c:479: END_CRITICAL; |
||
| 1677 | ; genAssign |
||
| 1678 | mov c,_end_run_task_EA_local_1_1 |
||
| 1679 | mov _EA,c |
||
| 1680 | C$rt_task.c$480$1$1 ==. |
||
| 1681 | ;rt_task.c:480: reschedule(); |
||
| 1682 | ; genCall |
||
| 1683 | lcall _reschedule |
||
| 1684 | C$rt_task.c$482$1$1 ==. |
||
| 1685 | ;rt_task.c:482: while(1); |
||
| 1686 | 00105$: |
||
| 1687 | ; Peephole 112.b changed ljmp to sjmp |
||
| 1688 | sjmp 00105$ |
||
| 1689 | 00107$: |
||
| 1690 | C$rt_task.c$484$1$1 ==. |
||
| 1691 | XG$end_run_task$0$0 ==. |
||
| 1692 | ret |
||
| 1693 | ;------------------------------------------------------------ |
||
| 1694 | ;Allocation info for local variables in function 'wait_timed' |
||
| 1695 | ;------------------------------------------------------------ |
||
| 1696 | ;ticks Allocated with name '_wait_timed_PARM_2' |
||
| 1697 | ;signal Allocated with name '_wait_timed_signal_1_1' |
||
| 1698 | ;------------------------------------------------------------ |
||
| 1699 | G$wait_timed$0$0 ==. |
||
| 1700 | C$rt_task.c$489$1$1 ==. |
||
| 1701 | ;rt_task.c:489: char wait_timed(char signal,char ticks) |
||
| 1702 | ; ----------------------------------------- |
||
| 1703 | ; function wait_timed |
||
| 1704 | ; ----------------------------------------- |
||
| 1705 | _wait_timed: |
||
| 1706 | ; genReceive |
||
| 1707 | mov a,dpl |
||
| 1708 | mov dptr,#_wait_timed_signal_1_1 |
||
| 1709 | movx @dptr,a |
||
| 1710 | C$rt_task.c$492$2$2 ==. |
||
| 1711 | ;rt_task.c:492: BEGIN_CRITICAL; |
||
| 1712 | ; genIfx |
||
| 1713 | ; genIfxJump |
||
| 1714 | ; Peephole 111 removed ljmp by inverse jump logic |
||
| 1715 | ; genAssign |
||
| 1716 | ; Peephole 250.a using atomic test and clear |
||
| 1717 | jbc _EA,00107$ |
||
| 1718 | sjmp 00102$ |
||
| 1719 | 00107$: |
||
| 1720 | ; genAssign |
||
| 1721 | setb _wait_timed_EA_local_1_1 |
||
| 1722 | ; Peephole 112.b changed ljmp to sjmp |
||
| 1723 | sjmp 00103$ |
||
| 1724 | 00102$: |
||
| 1725 | ; genAssign |
||
| 1726 | clr _wait_timed_EA_local_1_1 |
||
| 1727 | 00103$: |
||
| 1728 | C$rt_task.c$493$1$1 ==. |
||
| 1729 | ;rt_task.c:493: ready &= ~TASK_BIT(run); /* this task is going to sleep */ |
||
| 1730 | ; genLeftShift |
||
| 1731 | mov b,_run |
||
| 1732 | inc b |
||
| 1733 | mov a,#0x01 |
||
| 1734 | sjmp 00110$ |
||
| 1735 | 00108$: |
||
| 1736 | add a,acc |
||
| 1737 | 00110$: |
||
| 1738 | djnz b,00108$ |
||
| 1739 | ; genCpl |
||
| 1740 | ; Peephole 105 removed redundant mov |
||
| 1741 | ; genAnd |
||
| 1742 | ; Peephole 105 removed redundant mov |
||
| 1743 | ; Peephole 184 removed redundant mov |
||
| 1744 | cpl a |
||
| 1745 | mov r2,a |
||
| 1746 | anl _ready,a |
||
| 1747 | C$rt_task.c$494$1$1 ==. |
||
| 1748 | ;rt_task.c:494: task_timer[run] = ticks; |
||
| 1749 | ; genPlus |
||
| 1750 | mov a,_run |
||
| 1751 | add a,#_task_timer |
||
| 1752 | mov r0,a |
||
| 1753 | ; genAssign |
||
| 1754 | mov dptr,#_wait_timed_PARM_2 |
||
| 1755 | movx a,@dptr |
||
| 1756 | ; genPointerSet |
||
| 1757 | ; genNearPointerSet |
||
| 1758 | ; Peephole 192 used a instead of ar2 as source |
||
| 1759 | mov r2,a |
||
| 1760 | mov @r0,a |
||
| 1761 | C$rt_task.c$495$1$1 ==. |
||
| 1762 | ;rt_task.c:495: task_masks[run] = signal; /* accept these signals as a validto wait on */ |
||
| 1763 | ; genPlus |
||
| 1764 | mov a,_run |
||
| 1765 | add a,#_task_masks |
||
| 1766 | mov r0,a |
||
| 1767 | ; genAssign |
||
| 1768 | mov dptr,#_wait_timed_signal_1_1 |
||
| 1769 | movx a,@dptr |
||
| 1770 | ; genPointerSet |
||
| 1771 | ; genNearPointerSet |
||
| 1772 | ; Peephole 192 used a instead of ar2 as source |
||
| 1773 | mov r2,a |
||
| 1774 | mov @r0,a |
||
| 1775 | C$rt_task.c$496$2$5 ==. |
||
| 1776 | ;rt_task.c:496: END_CRITICAL; |
||
| 1777 | ; genAssign |
||
| 1778 | mov c,_wait_timed_EA_local_1_1 |
||
| 1779 | mov _EA,c |
||
| 1780 | C$rt_task.c$497$1$1 ==. |
||
| 1781 | ;rt_task.c:497: reschedule(); |
||
| 1782 | ; genCall |
||
| 1783 | lcall _reschedule |
||
| 1784 | C$rt_task.c$498$1$1 ==. |
||
| 1785 | ;rt_task.c:498: return task_signals[run]; |
||
| 1786 | ; genPlus |
||
| 1787 | mov a,_run |
||
| 1788 | add a,#_task_signals |
||
| 1789 | mov r0,a |
||
| 1790 | ; genPointerGet |
||
| 1791 | ; genNearPointerGet |
||
| 1792 | mov ar2,@r0 |
||
| 1793 | ; genRet |
||
| 1794 | mov dpl,r2 |
||
| 1795 | 00104$: |
||
| 1796 | C$rt_task.c$499$1$1 ==. |
||
| 1797 | XG$wait_timed$0$0 ==. |
||
| 1798 | ret |
||
| 1799 | ;------------------------------------------------------------ |
||
| 1800 | ;Allocation info for local variables in function 'sleep' |
||
| 1801 | ;------------------------------------------------------------ |
||
| 1802 | ;ticks Allocated with name '_sleep_ticks_1_1' |
||
| 1803 | ;------------------------------------------------------------ |
||
| 1804 | G$sleep$0$0 ==. |
||
| 1805 | C$rt_task.c$502$1$1 ==. |
||
| 1806 | ;rt_task.c:502: void sleep(char ticks) |
||
| 1807 | ; ----------------------------------------- |
||
| 1808 | ; function sleep |
||
| 1809 | ; ----------------------------------------- |
||
| 1810 | _sleep: |
||
| 1811 | ; genReceive |
||
| 1812 | mov a,dpl |
||
| 1813 | mov dptr,#_sleep_ticks_1_1 |
||
| 1814 | movx @dptr,a |
||
| 1815 | C$rt_task.c$507$1$1 ==. |
||
| 1816 | ;rt_task.c:507: if (ticks) |
||
| 1817 | ; genAssign |
||
| 1818 | mov dptr,#_sleep_ticks_1_1 |
||
| 1819 | movx a,@dptr |
||
| 1820 | ; genIfx |
||
| 1821 | ; Peephole 105 removed redundant mov |
||
| 1822 | mov r2,a |
||
| 1823 | ; genIfxJump |
||
| 1824 | jnz 00120$ |
||
| 1825 | ljmp 00111$ |
||
| 1826 | 00120$: |
||
| 1827 | C$rt_task.c$509$3$3 ==. |
||
| 1828 | ;rt_task.c:509: BEGIN_CRITICAL; |
||
| 1829 | ; genIfx |
||
| 1830 | ; genIfxJump |
||
| 1831 | ; Peephole 111 removed ljmp by inverse jump logic |
||
| 1832 | ; genAssign |
||
| 1833 | ; Peephole 250.a using atomic test and clear |
||
| 1834 | jbc _EA,00121$ |
||
| 1835 | sjmp 00102$ |
||
| 1836 | 00121$: |
||
| 1837 | ; genAssign |
||
| 1838 | setb _sleep_EA_local_1_1 |
||
| 1839 | ; Peephole 112.b changed ljmp to sjmp |
||
| 1840 | sjmp 00103$ |
||
| 1841 | 00102$: |
||
| 1842 | ; genAssign |
||
| 1843 | clr _sleep_EA_local_1_1 |
||
| 1844 | 00103$: |
||
| 1845 | C$rt_task.c$510$2$2 ==. |
||
| 1846 | ;rt_task.c:510: ready &= ~TASK_BIT(run); /* this task is going to sleep */ |
||
| 1847 | ; genLeftShift |
||
| 1848 | mov b,_run |
||
| 1849 | inc b |
||
| 1850 | mov a,#0x01 |
||
| 1851 | sjmp 00124$ |
||
| 1852 | 00122$: |
||
| 1853 | add a,acc |
||
| 1854 | 00124$: |
||
| 1855 | djnz b,00122$ |
||
| 1856 | ; genCpl |
||
| 1857 | ; Peephole 105 removed redundant mov |
||
| 1858 | ; genAnd |
||
| 1859 | ; Peephole 105 removed redundant mov |
||
| 1860 | ; Peephole 184 removed redundant mov |
||
| 1861 | cpl a |
||
| 1862 | mov r2,a |
||
| 1863 | anl _ready,a |
||
| 1864 | C$rt_task.c$511$2$2 ==. |
||
| 1865 | ;rt_task.c:511: task_timer[run] = ticks; |
||
| 1866 | ; genPlus |
||
| 1867 | mov a,_run |
||
| 1868 | add a,#_task_timer |
||
| 1869 | mov r0,a |
||
| 1870 | ; genAssign |
||
| 1871 | mov dptr,#_sleep_ticks_1_1 |
||
| 1872 | movx a,@dptr |
||
| 1873 | ; genPointerSet |
||
| 1874 | ; genNearPointerSet |
||
| 1875 | ; Peephole 192 used a instead of ar2 as source |
||
| 1876 | mov r2,a |
||
| 1877 | mov @r0,a |
||
| 1878 | C$rt_task.c$512$2$2 ==. |
||
| 1879 | ;rt_task.c:512: task_masks[run] = TIMER_SIG; /* accept this signal as a valid one to wait on */ |
||
| 1880 | ; genPlus |
||
| 1881 | mov a,_run |
||
| 1882 | add a,#_task_masks |
||
| 1883 | ; genPointerSet |
||
| 1884 | ; genNearPointerSet |
||
| 1885 | ; Peephole 239 used a instead of acc |
||
| 1886 | mov r0,a |
||
| 1887 | mov @r0,#0x80 |
||
| 1888 | C$rt_task.c$513$2$2 ==. |
||
| 1889 | ;rt_task.c:513: task_signals[run] &=~TIMER_SIG; |
||
| 1890 | ; genPlus |
||
| 1891 | mov a,_run |
||
| 1892 | add a,#_task_signals |
||
| 1893 | mov r0,a |
||
| 1894 | ; genPlus |
||
| 1895 | mov a,_run |
||
| 1896 | add a,#_task_signals |
||
| 1897 | mov r1,a |
||
| 1898 | ; genPointerGet |
||
| 1899 | ; genNearPointerGet |
||
| 1900 | mov ar2,@r1 |
||
| 1901 | ; genAnd |
||
| 1902 | mov a,#0x7F |
||
| 1903 | anl a,r2 |
||
| 1904 | ; genPointerSet |
||
| 1905 | ; genNearPointerSet |
||
| 1906 | mov @r0,acc |
||
| 1907 | C$rt_task.c$515$2$2 ==. |
||
| 1908 | ;rt_task.c:515: do { |
||
| 1909 | 00107$: |
||
| 1910 | C$rt_task.c$516$4$7 ==. |
||
| 1911 | ;rt_task.c:516: END_CRITICAL; |
||
| 1912 | ; genAssign |
||
| 1913 | mov c,_sleep_EA_local_1_1 |
||
| 1914 | mov _EA,c |
||
| 1915 | C$rt_task.c$517$3$6 ==. |
||
| 1916 | ;rt_task.c:517: reschedule(); |
||
| 1917 | ; genCall |
||
| 1918 | lcall _reschedule |
||
| 1919 | C$rt_task.c$518$4$8 ==. |
||
| 1920 | ;rt_task.c:518: BEGIN_CRITICAL; |
||
| 1921 | ; genIfx |
||
| 1922 | ; genIfxJump |
||
| 1923 | ; Peephole 111 removed ljmp by inverse jump logic |
||
| 1924 | ; genAssign |
||
| 1925 | ; Peephole 250.a using atomic test and clear |
||
| 1926 | jbc _EA,00125$ |
||
| 1927 | sjmp 00105$ |
||
| 1928 | 00125$: |
||
| 1929 | ; genAssign |
||
| 1930 | setb _sleep_EA_local_1_1 |
||
| 1931 | ; Peephole 112.b changed ljmp to sjmp |
||
| 1932 | sjmp 00108$ |
||
| 1933 | 00105$: |
||
| 1934 | ; genAssign |
||
| 1935 | clr _sleep_EA_local_1_1 |
||
| 1936 | 00108$: |
||
| 1937 | C$rt_task.c$520$2$2 ==. |
||
| 1938 | ;rt_task.c:520: while((task_signals[run] & TIMER_SIG) == 0); |
||
| 1939 | ; genPlus |
||
| 1940 | mov a,_run |
||
| 1941 | add a,#_task_signals |
||
| 1942 | mov r0,a |
||
| 1943 | ; genPointerGet |
||
| 1944 | ; genNearPointerGet |
||
| 1945 | mov ar2,@r0 |
||
| 1946 | ; genAnd |
||
| 1947 | anl ar2,#0x80 |
||
| 1948 | ; genCmpEq |
||
| 1949 | cjne r2,#0x00,00126$ |
||
| 1950 | ; Peephole 112.b changed ljmp to sjmp |
||
| 1951 | sjmp 00107$ |
||
| 1952 | 00126$: |
||
| 1953 | C$rt_task.c$521$2$2 ==. |
||
| 1954 | ;rt_task.c:521: task_signals[run] &= ~(TIMER_SIG); |
||
| 1955 | ; genPlus |
||
| 1956 | mov a,_run |
||
| 1957 | add a,#_task_signals |
||
| 1958 | mov r0,a |
||
| 1959 | ; genPlus |
||
| 1960 | mov a,_run |
||
| 1961 | add a,#_task_signals |
||
| 1962 | mov r1,a |
||
| 1963 | ; genPointerGet |
||
| 1964 | ; genNearPointerGet |
||
| 1965 | mov ar2,@r1 |
||
| 1966 | ; genAnd |
||
| 1967 | mov a,#0x7F |
||
| 1968 | anl a,r2 |
||
| 1969 | ; genPointerSet |
||
| 1970 | ; genNearPointerSet |
||
| 1971 | mov @r0,acc |
||
| 1972 | C$rt_task.c$522$2$2 ==. |
||
| 1973 | ;rt_task.c:522: task_masks[run] &= ~TIMER_SIG; /* accept this signal as a valid one to wait on */ |
||
| 1974 | ; genPlus |
||
| 1975 | mov a,_run |
||
| 1976 | add a,#_task_masks |
||
| 1977 | mov r0,a |
||
| 1978 | ; genPlus |
||
| 1979 | mov a,_run |
||
| 1980 | add a,#_task_masks |
||
| 1981 | mov r1,a |
||
| 1982 | ; genPointerGet |
||
| 1983 | ; genNearPointerGet |
||
| 1984 | mov ar2,@r1 |
||
| 1985 | ; genAnd |
||
| 1986 | mov a,#0x7F |
||
| 1987 | anl a,r2 |
||
| 1988 | ; genPointerSet |
||
| 1989 | ; genNearPointerSet |
||
| 1990 | mov @r0,acc |
||
| 1991 | C$rt_task.c$523$3$11 ==. |
||
| 1992 | ;rt_task.c:523: END_CRITICAL; |
||
| 1993 | ; genAssign |
||
| 1994 | mov c,_sleep_EA_local_1_1 |
||
| 1995 | mov _EA,c |
||
| 1996 | ; Peephole 112.b changed ljmp to sjmp |
||
| 1997 | ; Peephole 251.b replaced sjmp to ret with ret |
||
| 1998 | ret |
||
| 1999 | 00111$: |
||
| 2000 | C$rt_task.c$527$2$12 ==. |
||
| 2001 | ;rt_task.c:527: reschedule(); |
||
| 2002 | ; genCall |
||
| 2003 | C$rt_task.c$530$1$1 ==. |
||
| 2004 | XG$sleep$0$0 ==. |
||
| 2005 | ; Peephole 253.c replaced lcall with ljmp |
||
| 2006 | ljmp _reschedule |
||
| 2007 | 00113$: |
||
| 2008 | ret |
||
| 2009 | ;------------------------------------------------------------ |
||
| 2010 | ;Allocation info for local variables in function 'clear_signal' |
||
| 2011 | ;------------------------------------------------------------ |
||
| 2012 | ;pattern Allocated with name '_clear_signal_pattern_1_1' |
||
| 2013 | ;------------------------------------------------------------ |
||
| 2014 | G$clear_signal$0$0 ==. |
||
| 2015 | C$rt_task.c$533$1$1 ==. |
||
| 2016 | ;rt_task.c:533: void clear_signal(char pattern) |
||
| 2017 | ; ----------------------------------------- |
||
| 2018 | ; function clear_signal |
||
| 2019 | ; ----------------------------------------- |
||
| 2020 | _clear_signal: |
||
| 2021 | ; genReceive |
||
| 2022 | mov a,dpl |
||
| 2023 | mov dptr,#_clear_signal_pattern_1_1 |
||
| 2024 | movx @dptr,a |
||
| 2025 | C$rt_task.c$536$2$2 ==. |
||
| 2026 | ;rt_task.c:536: BEGIN_CRITICAL; |
||
| 2027 | ; genIfx |
||
| 2028 | ; genIfxJump |
||
| 2029 | ; Peephole 111 removed ljmp by inverse jump logic |
||
| 2030 | ; genAssign |
||
| 2031 | ; Peephole 250.a using atomic test and clear |
||
| 2032 | jbc _EA,00107$ |
||
| 2033 | sjmp 00102$ |
||
| 2034 | 00107$: |
||
| 2035 | ; genAssign |
||
| 2036 | setb _clear_signal_EA_local_1_1 |
||
| 2037 | ; Peephole 112.b changed ljmp to sjmp |
||
| 2038 | sjmp 00103$ |
||
| 2039 | 00102$: |
||
| 2040 | ; genAssign |
||
| 2041 | clr _clear_signal_EA_local_1_1 |
||
| 2042 | 00103$: |
||
| 2043 | C$rt_task.c$537$1$1 ==. |
||
| 2044 | ;rt_task.c:537: task_signals[run] &= ~(pattern); |
||
| 2045 | ; genPlus |
||
| 2046 | mov a,_run |
||
| 2047 | add a,#_task_signals |
||
| 2048 | mov r0,a |
||
| 2049 | ; genPlus |
||
| 2050 | mov a,_run |
||
| 2051 | add a,#_task_signals |
||
| 2052 | mov r1,a |
||
| 2053 | ; genPointerGet |
||
| 2054 | ; genNearPointerGet |
||
| 2055 | mov ar2,@r1 |
||
| 2056 | ; genAssign |
||
| 2057 | mov dptr,#_clear_signal_pattern_1_1 |
||
| 2058 | movx a,@dptr |
||
| 2059 | ; genCpl |
||
| 2060 | ; Peephole 105 removed redundant mov |
||
| 2061 | ; genAnd |
||
| 2062 | ; Peephole 105 removed redundant mov |
||
| 2063 | ; Peephole 184 removed redundant mov |
||
| 2064 | cpl a |
||
| 2065 | mov r3,a |
||
| 2066 | anl a,r2 |
||
| 2067 | ; genPointerSet |
||
| 2068 | ; genNearPointerSet |
||
| 2069 | mov @r0,acc |
||
| 2070 | C$rt_task.c$538$2$5 ==. |
||
| 2071 | ;rt_task.c:538: END_CRITICAL; |
||
| 2072 | ; genAssign |
||
| 2073 | mov c,_clear_signal_EA_local_1_1 |
||
| 2074 | mov _EA,c |
||
| 2075 | 00104$: |
||
| 2076 | C$rt_task.c$539$2$5 ==. |
||
| 2077 | XG$clear_signal$0$0 ==. |
||
| 2078 | ret |
||
| 2079 | ;------------------------------------------------------------ |
||
| 2080 | ;Allocation info for local variables in function 'signal' |
||
| 2081 | ;------------------------------------------------------------ |
||
| 2082 | ;pattern Allocated with name '_signal_PARM_2' |
||
| 2083 | ;task Allocated with name '_signal_task_1_1' |
||
| 2084 | ;------------------------------------------------------------ |
||
| 2085 | G$signal$0$0 ==. |
||
| 2086 | C$rt_task.c$544$2$5 ==. |
||
| 2087 | ;rt_task.c:544: void signal(char task,char pattern) |
||
| 2088 | ; ----------------------------------------- |
||
| 2089 | ; function signal |
||
| 2090 | ; ----------------------------------------- |
||
| 2091 | _signal: |
||
| 2092 | ; genReceive |
||
| 2093 | mov a,dpl |
||
| 2094 | mov dptr,#_signal_task_1_1 |
||
| 2095 | movx @dptr,a |
||
| 2096 | C$rt_task.c$547$2$2 ==. |
||
| 2097 | ;rt_task.c:547: BEGIN_CRITICAL; |
||
| 2098 | ; genIfx |
||
| 2099 | ; genIfxJump |
||
| 2100 | ; Peephole 111 removed ljmp by inverse jump logic |
||
| 2101 | ; genAssign |
||
| 2102 | ; Peephole 250.a using atomic test and clear |
||
| 2103 | jbc _EA,00110$ |
||
| 2104 | sjmp 00102$ |
||
| 2105 | 00110$: |
||
| 2106 | ; genAssign |
||
| 2107 | setb _signal_EA_local_1_1 |
||
| 2108 | ; Peephole 112.b changed ljmp to sjmp |
||
| 2109 | sjmp 00103$ |
||
| 2110 | 00102$: |
||
| 2111 | ; genAssign |
||
| 2112 | clr _signal_EA_local_1_1 |
||
| 2113 | 00103$: |
||
| 2114 | C$rt_task.c$549$1$1 ==. |
||
| 2115 | ;rt_task.c:549: INT_SIGNAL(task,pattern); |
||
| 2116 | ; genAssign |
||
| 2117 | mov dptr,#_signal_task_1_1 |
||
| 2118 | movx a,@dptr |
||
| 2119 | ; genPlus |
||
| 2120 | ; Peephole 177.b removed redundant mov |
||
| 2121 | mov r2,a |
||
| 2122 | add a,#_task_signals |
||
| 2123 | mov r0,a |
||
| 2124 | ; genPlus |
||
| 2125 | ; Peephole 236.g used r2 instead of ar2 |
||
| 2126 | mov a,r2 |
||
| 2127 | add a,#_task_signals |
||
| 2128 | mov r1,a |
||
| 2129 | ; genPointerGet |
||
| 2130 | ; genNearPointerGet |
||
| 2131 | mov ar3,@r1 |
||
| 2132 | ; genAssign |
||
| 2133 | mov dptr,#_signal_PARM_2 |
||
| 2134 | movx a,@dptr |
||
| 2135 | ; genOr |
||
| 2136 | ; Peephole 105 removed redundant mov |
||
| 2137 | mov r4,a |
||
| 2138 | orl a,r3 |
||
| 2139 | ; genPointerSet |
||
| 2140 | ; genNearPointerSet |
||
| 2141 | mov @r0,acc |
||
| 2142 | ; genPlus |
||
| 2143 | ; Peephole 236.g used r2 instead of ar2 |
||
| 2144 | mov a,r2 |
||
| 2145 | add a,#_task_signals |
||
| 2146 | mov r0,a |
||
| 2147 | ; genPointerGet |
||
| 2148 | ; genNearPointerGet |
||
| 2149 | mov ar3,@r0 |
||
| 2150 | ; genPlus |
||
| 2151 | ; Peephole 236.g used r2 instead of ar2 |
||
| 2152 | mov a,r2 |
||
| 2153 | add a,#_task_masks |
||
| 2154 | mov r0,a |
||
| 2155 | ; genPointerGet |
||
| 2156 | ; genNearPointerGet |
||
| 2157 | mov ar4,@r0 |
||
| 2158 | ; genAnd |
||
| 2159 | mov a,r4 |
||
| 2160 | anl a,r3 |
||
| 2161 | ; genIfx |
||
| 2162 | ; genIfxJump |
||
| 2163 | ; Peephole 110 removed ljmp by inverse jump logic |
||
| 2164 | jz 00105$ |
||
| 2165 | 00111$: |
||
| 2166 | ; genLeftShift |
||
| 2167 | mov b,r2 |
||
| 2168 | inc b |
||
| 2169 | mov a,#0x01 |
||
| 2170 | sjmp 00114$ |
||
| 2171 | 00112$: |
||
| 2172 | add a,acc |
||
| 2173 | 00114$: |
||
| 2174 | djnz b,00112$ |
||
| 2175 | ; genOr |
||
| 2176 | ; Peephole 105 removed redundant mov |
||
| 2177 | mov r2,a |
||
| 2178 | orl _ready,a |
||
| 2179 | 00105$: |
||
| 2180 | C$rt_task.c$551$2$6 ==. |
||
| 2181 | ;rt_task.c:551: END_CRITICAL; |
||
| 2182 | ; genAssign |
||
| 2183 | mov c,_signal_EA_local_1_1 |
||
| 2184 | mov _EA,c |
||
| 2185 | 00106$: |
||
| 2186 | C$rt_task.c$552$2$6 ==. |
||
| 2187 | XG$signal$0$0 ==. |
||
| 2188 | ret |
||
| 2189 | ;------------------------------------------------------------ |
||
| 2190 | ;Allocation info for local variables in function 'rt_system_init' |
||
| 2191 | ;------------------------------------------------------------ |
||
| 2192 | ;------------------------------------------------------------ |
||
| 2193 | G$rt_system_init$0$0 ==. |
||
| 2194 | C$rt_task.c$559$2$6 ==. |
||
| 2195 | ;rt_task.c:559: void rt_system_init(void) |
||
| 2196 | ; ----------------------------------------- |
||
| 2197 | ; function rt_system_init |
||
| 2198 | ; ----------------------------------------- |
||
| 2199 | _rt_system_init: |
||
| 2200 | C$rt_task.c$562$1$1 ==. |
||
| 2201 | ;rt_task.c:562: AUXR = M0 |XRS1 | XRS0 ; |
||
| 2202 | ; genAssign |
||
| 2203 | mov _AUXR,#0x2C |
||
| 2204 | C$rt_task.c$563$1$1 ==. |
||
| 2205 | ;rt_task.c:563: CKCON = WdX2 | PcaX2 | SiX2 | T2X2 | T0X2 | X2; /* T1X2 bit is '0' to double UART speed */ |
||
| 2206 | ; genAssign |
||
| 2207 | mov _CKCON,#0x7B |
||
| 2208 | C$rt_task.c$565$1$1 ==. |
||
| 2209 | ;rt_task.c:565: TMOD = 0x20; /* timer1 mode2 timer0 mode0 */ |
||
| 2210 | ; genAssign |
||
| 2211 | mov _TMOD,#0x20 |
||
| 2212 | C$rt_task.c$567$1$1 ==. |
||
| 2213 | ;rt_task.c:567: EA = 0; |
||
| 2214 | ; genAssign |
||
| 2215 | clr _EA |
||
| 2216 | 00101$: |
||
| 2217 | C$rt_task.c$570$1$1 ==. |
||
| 2218 | XG$rt_system_init$0$0 ==. |
||
| 2219 | ret |
||
| 2220 | .area CSEG (CODE) |
||
| 2221 | G$priotab$0$0 == . |
||
| 2222 | _priotab: |
||
| 2223 | .db #0x00 |
||
| 2224 | .db #0x00 |
||
| 2225 | .db #0x01 |
||
| 2226 | .db #0x01 |
||
| 2227 | .db #0x02 |
||
| 2228 | .db #0x02 |
||
| 2229 | .db #0x02 |
||
| 2230 | .db #0x02 |
||
| 2231 | .db #0x03 |
||
| 2232 | .db #0x03 |
||
| 2233 | .db #0x03 |
||
| 2234 | .db #0x03 |
||
| 2235 | .db #0x03 |
||
| 2236 | .db #0x03 |
||
| 2237 | .db #0x03 |
||
| 2238 | .db #0x03 |
||
| 2239 | .db #0x00 |
||
| 2240 | .db #0x00 |
||
| 2241 | .db #0x01 |
||
| 2242 | .db #0x00 |
||
| 2243 | .db #0x02 |
||
| 2244 | .db #0x00 |
||
| 2245 | .db #0x01 |
||
| 2246 | .db #0x01 |
||
| 2247 | .db #0x03 |
||
| 2248 | .db #0x00 |
||
| 2249 | .db #0x01 |
||
| 2250 | .db #0x01 |
||
| 2251 | .db #0x02 |
||
| 2252 | .db #0x02 |
||
| 2253 | .db #0x02 |
||
| 2254 | .db #0x02 |
||
| 2255 | .db #0x00 |
||
| 2256 | .db #0x00 |
||
| 2257 | .db #0x01 |
||
| 2258 | .db #0x01 |
||
| 2259 | .db #0x02 |
||
| 2260 | .db #0x02 |
||
| 2261 | .db #0x02 |
||
| 2262 | .db #0x00 |
||
| 2263 | .db #0x03 |
||
| 2264 | .db #0x03 |
||
| 2265 | .db #0x03 |
||
| 2266 | .db #0x00 |
||
| 2267 | .db #0x03 |
||
| 2268 | .db #0x00 |
||
| 2269 | .db #0x01 |
||
| 2270 | .db #0x01 |
||
| 2271 | .db #0x00 |
||
| 2272 | .db #0x00 |
||
| 2273 | .db #0x01 |
||
| 2274 | .db #0x00 |
||
| 2275 | .db #0x02 |
||
| 2276 | .db #0x00 |
||
| 2277 | .db #0x01 |
||
| 2278 | .db #0x02 |
||
| 2279 | .db #0x03 |
||
| 2280 | .db #0x00 |
||
| 2281 | .db #0x01 |
||
| 2282 | .db #0x03 |
||
| 2283 | .db #0x02 |
||
| 2284 | .db #0x03 |
||
| 2285 | .db #0x03 |
||
| 2286 | .db #0x00 |
||
| 2287 | .area XINIT (CODE) |