Skip to content

Commit a125a25

Browse files
committed
Implemented PortIn, PortOut and PortInOut API #8
Followingt test cases have been passed: * PortOut (#24) * PortOut PortIn (#9) * PortInOut (#8)
1 parent 9f47511 commit a125a25

File tree

6 files changed

+42
-21
lines changed

6 files changed

+42
-21
lines changed

libraries/mbed/targets/hal/TARGET_NXP/TARGET_LPC11XX/device.h

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -16,9 +16,9 @@
1616
#ifndef MBED_DEVICE_H
1717
#define MBED_DEVICE_H
1818

19-
#define DEVICE_PORTIN 0
20-
#define DEVICE_PORTOUT 0
21-
#define DEVICE_PORTINOUT 0
19+
#define DEVICE_PORTIN 1
20+
#define DEVICE_PORTOUT 1
21+
#define DEVICE_PORTINOUT 1
2222

2323
#define DEVICE_INTERRUPTIN 1
2424

libraries/mbed/targets/hal/TARGET_NXP/TARGET_LPC11XX/objects.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -32,7 +32,7 @@ struct gpio_irq_s {
3232

3333
struct port_s {
3434
__IO uint32_t *reg_dir;
35-
__IO uint32_t *reg_mpin;
35+
__IO uint32_t *reg_data;
3636
PortName port;
3737
uint32_t mask;
3838
};

libraries/mbed/targets/hal/TARGET_NXP/TARGET_LPC11XX/port_api.c

Lines changed: 19 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -14,32 +14,35 @@
1414
* limitations under the License.
1515
*/
1616

17-
#warning TODO(@toyowata) This platform doesn't support PortIn, PortOut and PortInOut
18-
#if 0
19-
2017
#include "port_api.h"
2118
#include "pinmap.h"
2219
#include "gpio_api.h"
2320

24-
PinName port_pin(PortName port, int pin_n) {
25-
return (PinName)((port << PORT_SHIFT) | pin_n);
21+
// LPC114 IOCON offset table [port][pin]
22+
23+
static uint8_t iocon_offset[4][12] = {
24+
{0x0c,0x10,0x1c,0x2c,0x30,0x34,0x4c,0x50,0x60,0x64,0x68,0x74}, // PORT 0
25+
{0x78,0x7c,0x80,0x90,0x94,0xa0,0xa4,0xa8,0x14,0x38,0x6c,0x98}, // PORT 1
26+
{0x08,0x28,0x5c,0x8c,0x40,0x44,0x00,0x20,0x24,0x54,0x58,0x70}, // PORT 2
27+
{0x84,0x88,0x9c,0xac,0x3c,0x48} // PORT 3
28+
};
29+
30+
static PinName port_pin(PortName port, int pin) {
31+
return (PinName)((port << PORT_SHIFT) | (pin << PIN_SHIFT) | (uint32_t)iocon_offset[port][pin]);
2632
}
2733

2834
void port_init(port_t *obj, PortName port, int mask, PinDirection dir) {
2935
obj->port = port;
3036
obj->mask = mask;
3137

32-
LPC_GPIO_TypeDef *port_reg = (LPC_GPIO_TypeDef *)(LPC_GPIO0_BASE + ((int)port * 0x20));
38+
LPC_GPIO_TypeDef *port_reg = ((LPC_GPIO_TypeDef *) (LPC_GPIO0_BASE + (port * 0x10000)));
3339

34-
port_reg->MASK = ~mask;
35-
36-
obj->reg_out = &port_reg->PIN;
37-
obj->reg_in = &port_reg->PIN;
38-
obj->reg_dir = &port_reg->DIR;
40+
obj->reg_data = &port_reg->DATA;
41+
obj->reg_dir = &port_reg->DIR;
3942

4043
uint32_t i;
4144
// The function is set per pin: reuse gpio logic
42-
for (i=0; i<32; i++) {
45+
for (i=0; i<12; i++) {
4346
if (obj->mask & (1<<i)) {
4447
gpio_set(port_pin(obj->port, i));
4548
}
@@ -51,7 +54,7 @@ void port_init(port_t *obj, PortName port, int mask, PinDirection dir) {
5154
void port_mode(port_t *obj, PinMode mode) {
5255
uint32_t i;
5356
// The mode is set per pin: reuse pinmap logic
54-
for (i=0; i<32; i++) {
57+
for (i=0; i<12; i++) {
5558
if (obj->mask & (1<<i)) {
5659
pin_mode(port_pin(obj->port, i), mode);
5760
}
@@ -66,10 +69,10 @@ void port_dir(port_t *obj, PinDirection dir) {
6669
}
6770

6871
void port_write(port_t *obj, int value) {
69-
*obj->reg_mpin = value;
72+
*obj->reg_data = (value & obj->mask);
7073
}
7174

7275
int port_read(port_t *obj) {
73-
return (*obj->reg_mpin);
76+
return (*obj->reg_data & obj->mask);
7477
}
75-
#endif
78+

libraries/tests/mbed/portinout/main.cpp

Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,15 @@
1818
#define P2_2 (1 << 0) // p2.0 -> p26
1919
#define PORT_2 Port2
2020

21+
#elif defined(TARGET_LPC1114)
22+
#define P1_1 (1 << 9) // p0.9
23+
#define P1_2 (1 << 8) // p0.8
24+
#define PORT_1 Port0
25+
26+
#define P2_1 (1 << 1) // p1.1
27+
#define P2_2 (1 << 0) // p1.0
28+
#define PORT_2 Port1
29+
2130
#elif defined(TARGET_KL25Z)
2231
#define P1_1 (1 << 1) // PTA1
2332
#define P1_2 (1 << 2) // PTA2

libraries/tests/mbed/portout/main.cpp

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,7 @@
55
# define LED2 (1 << 20) // P1.20
66
# define LED3 (1 << 21) // P1.21
77
# define LED4 (1 << 23) // P1.23
8-
# elif defined(TARGET_LPC11U24)
8+
# elif defined(TARGET_LPC11U24) || defined(TARGET_LPC1114)
99
# define LED1 (1 << 8) // P1.8
1010
# define LED2 (1 << 9) // P1.9
1111
# define LED3 (1 << 10) // P1.10

libraries/tests/mbed/portout_portin/main.cpp

Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,15 @@
1818
#define P2_2 (1 << 0) // p2.0 -> p26
1919
#define PORT_2 Port2
2020

21+
#elif defined(TARGET_LPC1114)
22+
#define P1_1 (1 << 9) // p0.9
23+
#define P1_2 (1 << 8) // p0.8
24+
#define PORT_1 Port0
25+
26+
#define P2_1 (1 << 1) // p1.1
27+
#define P2_2 (1 << 0) // p1.0
28+
#define PORT_2 Port1
29+
2130
#elif defined(TARGET_KL25Z)
2231
#define P1_1 (1 << 1) // PTA1
2332
#define P1_2 (1 << 2) // PTA2

0 commit comments

Comments
 (0)