Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependents: Eavesdropper BitstreamGenerator SimpleDecimationFilter 11U68_MP3Player with TFTLCD ... more
FastIO_KLXX.h@0:d394ebd01052, 2014-07-01 (annotated)
- Committer:
- Sissors
- Date:
- Tue Jul 01 17:04:08 2014 +0000
- Revision:
- 0:d394ebd01052
- Child:
- 2:1a6ed4b84590
v1.0
Who changed what in which revision?
| User | Revision | Line number | New contents of line |
|---|---|---|---|
| Sissors | 0:d394ebd01052 | 1 | #ifdef TARGET_KLXX |
| Sissors | 0:d394ebd01052 | 2 | |
| Sissors | 0:d394ebd01052 | 3 | #include "mbed.h" |
| Sissors | 0:d394ebd01052 | 4 | #include "pinmap.h" |
| Sissors | 0:d394ebd01052 | 5 | |
| Sissors | 0:d394ebd01052 | 6 | typedef struct { |
| Sissors | 0:d394ebd01052 | 7 | uint32_t mask; |
| Sissors | 0:d394ebd01052 | 8 | } fastio_vars; |
| Sissors | 0:d394ebd01052 | 9 | |
| Sissors | 0:d394ebd01052 | 10 | #define PORT_BASE ((FGPIO_Type *)(FPTA_BASE + ((unsigned int)pin >> PORT_SHIFT) * 0x40)) |
| Sissors | 0:d394ebd01052 | 11 | #define PINMASK (1 << ((pin & 0x7F) >> 2)) |
| Sissors | 0:d394ebd01052 | 12 | #define PCR ((__IO uint32_t*)(PORTA_BASE + pin)) |
| Sissors | 0:d394ebd01052 | 13 | |
| Sissors | 0:d394ebd01052 | 14 | #define INIT_PIN container.mask = PINMASK; pin_function(pin, 1) |
| Sissors | 0:d394ebd01052 | 15 | |
| Sissors | 0:d394ebd01052 | 16 | #define SET_DIR_INPUT (PORT_BASE->PDDR &= ~PINMASK) |
| Sissors | 0:d394ebd01052 | 17 | #define SET_DIR_OUTPUT (PORT_BASE->PDDR |= PINMASK) |
| Sissors | 0:d394ebd01052 | 18 | #define SET_MODE(pull) (*PCR = (*PCR & ~0x3) | pull) |
| Sissors | 0:d394ebd01052 | 19 | |
| Sissors | 0:d394ebd01052 | 20 | #define WRITE_PIN_SET (PORT_BASE->PSOR |= PINMASK) |
| Sissors | 0:d394ebd01052 | 21 | #define WRITE_PIN_CLR (PORT_BASE->PCOR |= PINMASK) |
| Sissors | 0:d394ebd01052 | 22 | |
| Sissors | 0:d394ebd01052 | 23 | #define READ_PIN ((PORT_BASE->PDIR & container.mask) ? 1 : 0) |
| Sissors | 0:d394ebd01052 | 24 | |
| Sissors | 0:d394ebd01052 | 25 | #endif |
