Differences
This shows you the differences between two versions of the page.
| Both sides previous revision Previous revision Next revision | Previous revision | ||
| ctboard:peripherals:dipsw [2016/01/26 10:29] – feur | ctboard:peripherals:dipsw [2022/12/27 16:38] (current) – [Registers] ruan | ||
|---|---|---|---|
| Line 1: | Line 1: | ||
| - | ====== | + | ====== | 
| - | On the CT Board are 32 DIP switches | + | The CT Board features | 
| If a DIP switch is in the position " | If a DIP switch is in the position " | ||
| - | > {{ctboard_mode_1.svg? | + | > {{ctboard:ctboard_mode_1.svg? | 
| - | > Supported modes: **1**, **2**, **3** | + | > Supported | 
| + | \\ | ||
| ===== Registers ===== | ===== Registers ===== | ||
| - | The Registers | + | The registers | 
| - | |< 100% 10em >| | + | \\ {{ctboard_dipsw_reg.svg}} \\ \\ | 
| - | ^  Address | + | |
| - | ^  0x6000' | + | |
| - | ^  0x6000' | + | |
| - | ^  0x6000' | + | |
| - | ^  0x6000' | + | |
| ===== Diagram ===== | ===== Diagram ===== | ||
| - | \\ {{: | + | \\ {{: | 
| + | |||
| + | ===== Programming Example ===== | ||
| + | |||
| + | The code snippets below show how to use the DIPSW. | ||
| + | |||
| + | <code c> | ||
| + | #include " | ||
| + | |||
| + | uint8_t data_byte = CT_DIPSW-> | ||
| + | uint16_t data_hword = CT_DIPSW-> | ||
| + | uint32_t data_word = CT_DIPSW-> | ||
| + | </ | ||
| + | \\ | ||
| + | |||
| + | <code asm> | ||
| + | ADDR_DIPSW | ||
| + | |||
| + | LDR r0, =ADDR_DIPSW | ||
| + | LDRB r1, [r0, #0] ; Read byte from S7..0. | ||
| + | LDRH r1, [r0, #2] ; Read half word from S31..16. | ||
| + | LDR r1, [r0, #0] ; Read all DIPSW at once into a word. | ||
| + | </ | ||
| + | \\ | ||