lpc176x: Use enumerations for buses and reserve pins
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
bc9fd03dab
commit
3e71a57f67
|
@ -11,6 +11,9 @@
|
||||||
#include "internal.h" // gpio_peripheral
|
#include "internal.h" // gpio_peripheral
|
||||||
#include "sched.h" // sched_shutdown
|
#include "sched.h" // sched_shutdown
|
||||||
|
|
||||||
|
DECL_ENUMERATION("i2c_bus", "i2c1", 0);
|
||||||
|
DECL_CONSTANT_STR("BUS_PINS_i2c1", "P0.1,P0.0");
|
||||||
|
|
||||||
// i2c connection status flags
|
// i2c connection status flags
|
||||||
enum {
|
enum {
|
||||||
IF_START = 1<<5, IF_STOP = 1<<4, IF_IRQ = 1<<3, IF_ACK = 1<<2, IF_ENA = 1<<6
|
IF_START = 1<<5, IF_STOP = 1<<4, IF_IRQ = 1<<3, IF_ACK = 1<<2, IF_ENA = 1<<6
|
||||||
|
@ -25,8 +28,8 @@ i2c_init(void)
|
||||||
have_run_init = 1;
|
have_run_init = 1;
|
||||||
|
|
||||||
// Init i2c bus 1 pins
|
// Init i2c bus 1 pins
|
||||||
gpio_peripheral(GPIO(0, 0), 3, 0);
|
|
||||||
gpio_peripheral(GPIO(0, 1), 3, 0);
|
gpio_peripheral(GPIO(0, 1), 3, 0);
|
||||||
|
gpio_peripheral(GPIO(0, 0), 3, 0);
|
||||||
|
|
||||||
// Set 100Khz frequency
|
// Set 100Khz frequency
|
||||||
enable_pclock(PCLK_I2C1);
|
enable_pclock(PCLK_I2C1);
|
||||||
|
|
|
@ -8,9 +8,12 @@
|
||||||
#include "autoconf.h" // CONFIG_SERIAL_BAUD
|
#include "autoconf.h" // CONFIG_SERIAL_BAUD
|
||||||
#include "board/irq.h" // irq_save
|
#include "board/irq.h" // irq_save
|
||||||
#include "board/serial_irq.h" // serial_rx_data
|
#include "board/serial_irq.h" // serial_rx_data
|
||||||
|
#include "command.h" // DECL_CONSTANT_STR
|
||||||
#include "internal.h" // gpio_peripheral
|
#include "internal.h" // gpio_peripheral
|
||||||
#include "sched.h" // DECL_INIT
|
#include "sched.h" // DECL_INIT
|
||||||
|
|
||||||
|
DECL_CONSTANT_STR("RESERVE_PINS_serial", "P0.3,P0.2");
|
||||||
|
|
||||||
void
|
void
|
||||||
serial_init(void)
|
serial_init(void)
|
||||||
{
|
{
|
||||||
|
@ -27,8 +30,8 @@ serial_init(void)
|
||||||
LPC_UART0->FCR = 0x01;
|
LPC_UART0->FCR = 0x01;
|
||||||
|
|
||||||
// Setup pins
|
// Setup pins
|
||||||
gpio_peripheral(GPIO(0, 2), 1, 0);
|
|
||||||
gpio_peripheral(GPIO(0, 3), 1, 0);
|
gpio_peripheral(GPIO(0, 3), 1, 0);
|
||||||
|
gpio_peripheral(GPIO(0, 2), 1, 0);
|
||||||
|
|
||||||
// Enable receive irq
|
// Enable receive irq
|
||||||
NVIC_SetPriority(UART0_IRQn, 0);
|
NVIC_SetPriority(UART0_IRQn, 0);
|
||||||
|
|
|
@ -10,6 +10,9 @@
|
||||||
#include "internal.h" // gpio_peripheral
|
#include "internal.h" // gpio_peripheral
|
||||||
#include "sched.h" // sched_shutdown
|
#include "sched.h" // sched_shutdown
|
||||||
|
|
||||||
|
DECL_ENUMERATION("spi_bus", "ssp0", 0);
|
||||||
|
DECL_CONSTANT_STR("BUS_PINS_ssp0", "P0.17,P0.18,P0.15");
|
||||||
|
|
||||||
static void
|
static void
|
||||||
spi_init(void)
|
spi_init(void)
|
||||||
{
|
{
|
||||||
|
@ -18,10 +21,10 @@ spi_init(void)
|
||||||
return;
|
return;
|
||||||
have_run_init = 1;
|
have_run_init = 1;
|
||||||
|
|
||||||
// Configure SCK0, MISO0, MOSI0 pins
|
// Configure MISO0, MOSI0, SCK0 pins
|
||||||
gpio_peripheral(GPIO(0, 15), 2, 0);
|
|
||||||
gpio_peripheral(GPIO(0, 17), 2, 0);
|
gpio_peripheral(GPIO(0, 17), 2, 0);
|
||||||
gpio_peripheral(GPIO(0, 18), 2, 0);
|
gpio_peripheral(GPIO(0, 18), 2, 0);
|
||||||
|
gpio_peripheral(GPIO(0, 15), 2, 0);
|
||||||
|
|
||||||
// Setup clock
|
// Setup clock
|
||||||
enable_pclock(PCLK_SSP0);
|
enable_pclock(PCLK_SSP0);
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
#include "board/irq.h" // irq_disable
|
#include "board/irq.h" // irq_disable
|
||||||
#include "board/misc.h" // timer_read_time
|
#include "board/misc.h" // timer_read_time
|
||||||
#include "byteorder.h" // cpu_to_le32
|
#include "byteorder.h" // cpu_to_le32
|
||||||
#include "command.h" // output
|
#include "command.h" // DECL_CONSTANT_STR
|
||||||
#include "generic/usb_cdc.h" // usb_notify_ep0
|
#include "generic/usb_cdc.h" // usb_notify_ep0
|
||||||
#include "internal.h" // gpio_peripheral
|
#include "internal.h" // gpio_peripheral
|
||||||
#include "sched.h" // DECL_INIT
|
#include "sched.h" // DECL_INIT
|
||||||
|
@ -261,6 +261,8 @@ usb_request_bootloader(void)
|
||||||
NVIC_SystemReset();
|
NVIC_SystemReset();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DECL_CONSTANT_STR("RESERVE_PINS_USB", "P0.30,P0.29,P2.9");
|
||||||
|
|
||||||
void
|
void
|
||||||
usbserial_init(void)
|
usbserial_init(void)
|
||||||
{
|
{
|
||||||
|
@ -271,9 +273,9 @@ usbserial_init(void)
|
||||||
LPC_USB->USBClkCtrl = 0x12;
|
LPC_USB->USBClkCtrl = 0x12;
|
||||||
while (LPC_USB->USBClkSt != 0x12)
|
while (LPC_USB->USBClkSt != 0x12)
|
||||||
;
|
;
|
||||||
// configure USBD+, USBD-, and USB Connect pins
|
// configure USBD-, USBD+, and USB Connect pins
|
||||||
gpio_peripheral(GPIO(0, 29), 1, 0);
|
|
||||||
gpio_peripheral(GPIO(0, 30), 1, 0);
|
gpio_peripheral(GPIO(0, 30), 1, 0);
|
||||||
|
gpio_peripheral(GPIO(0, 29), 1, 0);
|
||||||
gpio_peripheral(GPIO(2, 9), 1, 0);
|
gpio_peripheral(GPIO(2, 9), 1, 0);
|
||||||
// setup endpoints
|
// setup endpoints
|
||||||
realize_endpoint(EP0OUT, USB_CDC_EP0_SIZE);
|
realize_endpoint(EP0OUT, USB_CDC_EP0_SIZE);
|
||||||
|
|
Loading…
Reference in New Issue