Texas Instruments TMS320C3x User Manual
Page 194

Delayed Branches
7-10
Example 7–6. Incorrectly Placed Delayed Branches
B1:
BD
L1
NOP
NOP
B2:
B
L2
; This branch is incorrectly placed.
NOP
NOP
NOP
.
.
.
For faster execution, it might still be advantageous to use a delayed branch
followed by NOP instructions by trading increased program size for faster
speed. This is shown in Example 7–7 where a NOP takes the place of the third
unused instruction after the delayed branch.
Example 7–7. Delayed Branch Execution
*
TITLE DELAYED BRANCH EXECUTION
.
.
.
.
LDF* +AR1(5),R2
; Load contents of memory to R2
BGED
SKIP
; If loaded number >=0, branch
; (delayed)
LDFN
R2,R1
; If loaded number <0, load it to R1
SUBF
3.0,R1
; Subtract 3 from R1
NOP
; Dummy operation to complete delayed
; branch
MPYF
1.5,R1
; Continue here if loaded number <0
.
.
.
SKIP
LDF
R1,R3
; Continue here if loaded number >=0
- Digital Signal Processor SM320F2812-HT (153 pages)
- MSP430x1xx (440 pages)
- Laser And Motor Drives DRV8811EVM (13 pages)
- TMS320 DSP (88 pages)
- MSP430x11x1 (45 pages)
- TVP5154EVM (55 pages)
- TMS320DM646X DMSOC (64 pages)
- CC2511 (24 pages)
- SN65HVS880 (4 pages)
- TPS650231EVM (14 pages)
- TMS320TCI648x (256 pages)
- TSC2007EVM-PDK (16 pages)
- UCC38500EVM (16 pages)
- TMS320C6000 (62 pages)
- SCAU020 (21 pages)
- TPS40051 (17 pages)
- TNETE2201 (14 pages)
- TMS320C64x DSP (306 pages)
- UCC2891 (21 pages)
- MSP430 (138 pages)
- TMS320C6712D (102 pages)
- MSP430x4xx (512 pages)
- TMS320C6454 (225 pages)
- SPRU938B (48 pages)
- TUSB3210 (22 pages)
- TMS320C6457 (43 pages)
- CC2530ZNP (3 pages)
- TMS320C6455 (50 pages)
- TSB12LV26 (91 pages)
- TMS320C6472 (2 pages)
- VLYNQ Port (49 pages)
- TMS380C26 (92 pages)
- MSP-FET430 (95 pages)
- TMS320TCI6486 (160 pages)
- TPS2330 (22 pages)
- DM648 DSP (47 pages)
- TMS320DM36X (134 pages)
- MSC1211 (35 pages)
- SPRAA56 (29 pages)
- DAC7741EVM (28 pages)
- CDCM7005 (34 pages)
- TMS370 (99 pages)
- Adpater (37 pages)
- TMS320C6452 DSP (46 pages)