commit
21304c01b6
|
@ -4,6 +4,7 @@
|
|||
## Copyright (C) 2009 Uwe Hermann <uwe@hermann-uwe.de>
|
||||
## Copyright (C) 2010 Piotr Esden-Tempski <piotr@esden.net>
|
||||
## Copyright (C) 2012 Michael Ossmann <mike@ossmann.com>
|
||||
## Copyright (C) 2012 Benjamin Vernoux <titanmkd@gmail.com>
|
||||
##
|
||||
## This library is free software: you can redistribute it and/or modify
|
||||
## it under the terms of the GNU Lesser General Public License as published by
|
||||
|
@ -29,12 +30,12 @@ GDB = $(PREFIX)-gdb
|
|||
# Uncomment this line if you want to use the installed (not local) library.
|
||||
# TOOLCHAIN_DIR := $(shell dirname `which $(CC)`)/../$(PREFIX)
|
||||
TOOLCHAIN_DIR = ../../../..
|
||||
CFLAGS += -O0 -g -Wall -Wextra -I$(TOOLCHAIN_DIR)/include -fno-common \
|
||||
CFLAGS += -O2 -g -Wall -Wextra -I$(TOOLCHAIN_DIR)/include -fno-common \
|
||||
-mcpu=cortex-m4 -mthumb -MD \
|
||||
-mfloat-abi=hard -mfpu=fpv4-sp-d16
|
||||
LDSCRIPT ?= $(BINARY).ld
|
||||
LDFLAGS += -L$(TOOLCHAIN_DIR)/lib -L$(TOOLCHAIN_DIR)/lib/lpc43xx \
|
||||
-T$(LDSCRIPT) -nostartfiles -Wl,--gc-sections
|
||||
-T$(LDSCRIPT) -nostartfiles -Wl,--gc-sections -Xlinker -Map=$(BINARY).map
|
||||
OBJS += $(BINARY).o
|
||||
|
||||
OOCD ?= openocd
|
||||
|
|
|
@ -0,0 +1,80 @@
|
|||
/*
|
||||
* This file is part of the libopencm3 project.
|
||||
*
|
||||
* Copyright (C) 2012 Benjamin Vernoux <titanmkd@gmail.com>
|
||||
*
|
||||
* This library is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU Lesser General Public License as published by
|
||||
* the Free Software Foundation, either version 3 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* This library is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public License
|
||||
* along with this library. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef __JELLYBEAN_CONF_H
|
||||
#define __JELLYBEAN_CONF_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C"
|
||||
{
|
||||
#endif
|
||||
|
||||
#include <libopencm3/lpc43xx/scu.h>
|
||||
|
||||
/************************/
|
||||
/* JellyBean SCU PinMux */
|
||||
/************************/
|
||||
|
||||
/* GPIO Output PinMux */
|
||||
#define SCU_PINMUX_LED1 (P4_1) /* GPIO2[1] on P4_1 */
|
||||
#define SCU_PINMUX_LED2 (P4_2) /* GPIO2[2] on P4_2 */
|
||||
#define SCU_PINMUX_LED3 (P6_12) /* GPIO2[8] on P6_12 */
|
||||
|
||||
#define SCU_PINMUX_EN1V8 (P6_10) /* GPIO3[6] on P6_10 */
|
||||
|
||||
/* GPIO Input PinMux */
|
||||
#define SCU_PINMUX_BOOT0 (P1_1) /* GPIO0[8] on P1_1 */
|
||||
#define SCU_PINMUX_BOOT1 (P1_2) /* GPIO0[9] on P1_2 */
|
||||
#define SCU_PINMUX_BOOT2 (P2_8) /* GPIO5[7] on P2_8 */
|
||||
#define SCU_PINMUX_BOOT3 (P2_9) /* GPIO1[10] on P2_9 */
|
||||
|
||||
/* TODO add other Pins */
|
||||
|
||||
/**********************/
|
||||
/* JellyBean GPIO Pin */
|
||||
/**********************/
|
||||
|
||||
/* GPIO Output */
|
||||
#define PIN_LED1 (BIT1) /* GPIO2[1] on P4_1 */
|
||||
#define PIN_LED2 (BIT2) /* GPIO2[2] on P4_2 */
|
||||
#define PIN_LED3 (BIT8) /* GPIO2[8] on P6_12 */
|
||||
#define PORT_LED1_3 (GPIO2) /* PORT for LED1, 2 & 3 */
|
||||
|
||||
#define PIN_EN1V8 (BIT6) /* GPIO3[6] on P6_10 */
|
||||
#define PORT_EN1V8 (GPIO3)
|
||||
|
||||
/* GPIO Input */
|
||||
#define PIN_BOOT0 (BIT8) /* GPIO0[8] on P1_1 */
|
||||
#define PIN_BOOT1 (BIT9) /* GPIO0[9] on P1_2 */
|
||||
#define PIN_BOOT2 (BIT7) /* GPIO5[7] on P2_8 */
|
||||
#define PIN_BOOT3 (BIT10) /* GPIO1[10] on P2_9 */
|
||||
|
||||
/* Read GPIO Pin */
|
||||
#define BOOT0_STATE ( (GPIO0_PIN & PIN_BOOT0)==PIN_BOOT0 )
|
||||
#define BOOT1_STATE ( (GPIO0_PIN & PIN_BOOT1)==PIN_BOOT1 )
|
||||
#define BOOT2_STATE ( (GPIO5_PIN & PIN_BOOT2)==PIN_BOOT2 )
|
||||
#define BOOT3_STATE ( (GPIO1_PIN & PIN_BOOT3)==PIN_BOOT3 )
|
||||
|
||||
/* TODO add other Pins */
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
|
@ -19,26 +19,65 @@
|
|||
*/
|
||||
|
||||
#include <libopencm3/lpc43xx/gpio.h>
|
||||
#include <libopencm3/lpc43xx/scu.h>
|
||||
|
||||
#include "../jellybean_conf.h"
|
||||
|
||||
void gpio_setup(void)
|
||||
{
|
||||
GPIO2_DIR |= (1 << 1); /* Configure GPIO2[1] (P4_1) as output. */
|
||||
/* Configure SCU Pin Mux as GPIO */
|
||||
scu_pinmux(SCU_PINMUX_LED1, SCU_GPIO_FAST);
|
||||
scu_pinmux(SCU_PINMUX_LED2, SCU_GPIO_FAST);
|
||||
scu_pinmux(SCU_PINMUX_LED3, SCU_GPIO_FAST);
|
||||
|
||||
scu_pinmux(SCU_PINMUX_EN1V8, SCU_GPIO_FAST);
|
||||
|
||||
scu_pinmux(SCU_PINMUX_BOOT0, SCU_GPIO_FAST);
|
||||
scu_pinmux(SCU_PINMUX_BOOT1, SCU_GPIO_FAST);
|
||||
scu_pinmux(SCU_PINMUX_BOOT2, SCU_GPIO_FAST);
|
||||
scu_pinmux(SCU_PINMUX_BOOT3, SCU_GPIO_FAST);
|
||||
|
||||
/* Configure SCU I2C0 Peripheral (to be moved later in I2C driver) */
|
||||
SCU_SFSI2C0 = SCU_I2C0_NOMINAL;
|
||||
|
||||
/* Configure all GPIO as Input (safe state) */
|
||||
GPIO0_DIR = 0;
|
||||
GPIO1_DIR = 0;
|
||||
GPIO2_DIR = 0;
|
||||
GPIO3_DIR = 0;
|
||||
GPIO4_DIR = 0;
|
||||
GPIO5_DIR = 0;
|
||||
GPIO6_DIR = 0;
|
||||
GPIO7_DIR = 0;
|
||||
|
||||
/* Configure GPIO as Output */
|
||||
GPIO2_DIR |= (PIN_LED1|PIN_LED2|PIN_LED3); /* Configure GPIO2[1/2/8] (P4_1/2 P6_12) as output. */
|
||||
GPIO3_DIR |= PIN_EN1V8; /* GPIO3[6] on P6_10 as output. */
|
||||
}
|
||||
|
||||
u32 boot0, boot1, boot2, boot3;
|
||||
|
||||
int main(void)
|
||||
{
|
||||
int i;
|
||||
|
||||
gpio_setup();
|
||||
|
||||
/* Blink LED1 on the board. */
|
||||
while (1) {
|
||||
|
||||
gpio_set(GPIO2, GPIOPIN1); /* LED on */
|
||||
for (i = 0; i < 800000; i++) /* Wait a bit. */
|
||||
/* Set 1V8 */
|
||||
gpio_set(PORT_EN1V8, PIN_EN1V8);
|
||||
|
||||
/* Blink LED1/2/3 on the board and Read BOOT0/1/2/3 pins. */
|
||||
while (1)
|
||||
{
|
||||
boot0 = BOOT0_STATE;
|
||||
boot1 = BOOT1_STATE;
|
||||
boot2 = BOOT2_STATE;
|
||||
boot3 = BOOT3_STATE;
|
||||
|
||||
gpio_set(PORT_LED1_3, (PIN_LED1|PIN_LED2|PIN_LED3)); /* LEDs on */
|
||||
for (i = 0; i < 2000000; i++) /* Wait a bit. */
|
||||
__asm__("nop");
|
||||
gpio_clear(GPIO2, GPIOPIN1); /* LED off */
|
||||
for (i = 0; i < 800000; i++) /* Wait a bit. */
|
||||
gpio_clear(PORT_LED1_3, (PIN_LED1|PIN_LED2|PIN_LED3)); /* LED off */
|
||||
for (i = 0; i < 2000000; i++) /* Wait a bit. */
|
||||
__asm__("nop");
|
||||
}
|
||||
|
||||
|
|
|
@ -38,6 +38,40 @@ typedef uint64_t u64;
|
|||
#define MMIO32(addr) (*(volatile u32 *)(addr))
|
||||
#define MMIO64(addr) (*(volatile u64 *)(addr))
|
||||
|
||||
/* Generic bit definition */
|
||||
#define BIT0 (1<<0)
|
||||
#define BIT1 (1<<1)
|
||||
#define BIT2 (1<<2)
|
||||
#define BIT3 (1<<3)
|
||||
#define BIT4 (1<<4)
|
||||
#define BIT5 (1<<5)
|
||||
#define BIT6 (1<<6)
|
||||
#define BIT7 (1<<7)
|
||||
#define BIT8 (1<<8)
|
||||
#define BIT9 (1<<9)
|
||||
#define BIT10 (1<<10)
|
||||
#define BIT11 (1<<11)
|
||||
#define BIT12 (1<<12)
|
||||
#define BIT13 (1<<13)
|
||||
#define BIT14 (1<<14)
|
||||
#define BIT15 (1<<15)
|
||||
#define BIT16 (1<<16)
|
||||
#define BIT17 (1<<17)
|
||||
#define BIT18 (1<<18)
|
||||
#define BIT19 (1<<19)
|
||||
#define BIT20 (1<<20)
|
||||
#define BIT21 (1<<21)
|
||||
#define BIT22 (1<<22)
|
||||
#define BIT23 (1<<23)
|
||||
#define BIT24 (1<<24)
|
||||
#define BIT25 (1<<25)
|
||||
#define BIT26 (1<<26)
|
||||
#define BIT27 (1<<27)
|
||||
#define BIT28 (1<<28)
|
||||
#define BIT29 (1<<29)
|
||||
#define BIT30 (1<<30)
|
||||
#define BIT31 (1<<31)
|
||||
|
||||
/* Main page for the doxygen-generated documentation: */
|
||||
|
||||
/**
|
||||
|
|
|
@ -2,6 +2,7 @@
|
|||
* This file is part of the libopencm3 project.
|
||||
*
|
||||
* Copyright (C) 2012 Michael Ossmann <mike@ossmann.com>
|
||||
* Copyright (C) 2012 Benjamin Vernoux <titanmkd@gmail.com>
|
||||
*
|
||||
* This library is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU Lesser General Public License as published by
|
||||
|
@ -288,7 +289,6 @@
|
|||
#define SCU_SFSUSB MMIO32(SCU_BASE + 0xC80)
|
||||
#define SCU_SFSI2C0 MMIO32(SCU_BASE + 0xC84)
|
||||
|
||||
|
||||
/* ADC pin select registers */
|
||||
|
||||
/* ADC0 function select register */
|
||||
|
@ -300,17 +300,431 @@
|
|||
/* Analog function select register */
|
||||
#define SCU_ENAIO2 MMIO32(SCU_BASE + 0xC90)
|
||||
|
||||
|
||||
/* EMC clock delay register */
|
||||
#define SCU_EMCDELAYCLK MMIO32(SCU_BASE + 0xD00)
|
||||
|
||||
|
||||
/* Pin interrupt select registers */
|
||||
|
||||
/* Pin interrupt select register for pin interrupts 0 to 3 */
|
||||
#define SCU_PINTSEL0 MMIO32(SCU_BASE + 0xE00)
|
||||
|
||||
/* Pin interrupt select register for pin interrupts 4 to 7 */
|
||||
#define SCU_PINTSEL1 MMIO32(SCU_BASE + 0xE00)
|
||||
#define SCU_PINTSEL1 MMIO32(SCU_BASE + 0xE04)
|
||||
|
||||
/**************************/
|
||||
/* SCU I2C0 Configuration */
|
||||
/**************************/
|
||||
/*
|
||||
* Select input glitch filter time constant for the SCL pin.
|
||||
* 0 = 50 ns glitch filter.
|
||||
* 1 = 3ns glitch filter.
|
||||
*/
|
||||
#define SCU_SCL_EFP (BIT0)
|
||||
|
||||
/* BIT1 Reserved. Always write a 0 to this bit. */
|
||||
|
||||
/*
|
||||
* Select I2C mode for the SCL pin.
|
||||
* 0 = Standard/Fast mode transmit.
|
||||
* 1 = Fast-mode Plus transmit.
|
||||
*/
|
||||
#define SCU_SCL_EHD (BIT2)
|
||||
|
||||
/*
|
||||
* Enable the input receiver for the SCL pin.
|
||||
* Always write a 1 to this bit when using the
|
||||
* I2C0.
|
||||
* 0 = Disabled.
|
||||
* 1 = Enabled.
|
||||
*/
|
||||
#define SCU_SCL_EZI_EN (BIT3)
|
||||
|
||||
/* BIT4-6 Reserved. */
|
||||
|
||||
/*
|
||||
* Enable or disable input glitch filter for the
|
||||
* SCL pin. The filter time constant is
|
||||
* determined by bit EFP.
|
||||
* 0 = Enable input filter.
|
||||
* 1 = Disable input filter.
|
||||
*/
|
||||
#define SCU_SCL_ZIF_DIS (BIT7)
|
||||
|
||||
/*
|
||||
* Select input glitch filter time constant for the SDA pin.
|
||||
* 0 = 50 ns glitch filter.
|
||||
* 1 = 3ns glitch filter.
|
||||
*/
|
||||
#define SCU_SDA_EFP (BIT8)
|
||||
|
||||
/* BIT9 Reserved. Always write a 0 to this bit. */
|
||||
|
||||
/*
|
||||
* Select I2C mode for the SDA pin.
|
||||
* 0 = Standard/Fast mode transmit.
|
||||
* 1 = Fast-mode Plus transmit.
|
||||
*/
|
||||
#define SCU_SDA_EHD (BIT10)
|
||||
|
||||
/*
|
||||
* Enable the input receiver for the SDA pin.
|
||||
* Always write a 1 to this bit when using the
|
||||
* I2C0.
|
||||
* 0 = Disabled.
|
||||
* 1 = Enabled.
|
||||
*/
|
||||
#define SCU_SDA_EZI_EN (BIT11)
|
||||
|
||||
/* BIT 12-14 - Reserved */
|
||||
|
||||
/*
|
||||
* Enable or disable input glitch filter for the
|
||||
* SDA pin. The filter time constant is
|
||||
* determined by bit SDA_EFP.
|
||||
* 0 = Enable input filter.
|
||||
* 1 = Disable input filter.
|
||||
*/
|
||||
#define SCU_SDA_ZIF_DIS (BIT15)
|
||||
|
||||
/* Standard mode for I2C SCL/SDA Standard/Fast mode */
|
||||
#define SCU_I2C0_NOMINAL (SCU_SCL_EZI_EN | SCU_SDA_EZI_EN)
|
||||
|
||||
/* Standard mode for I2C SCL/SDA Fast-mode Plus transmit */
|
||||
#define SCU_I2C0_FAST (SCU_SCL_EFP | SCU_SCL_EHD | SCU_SCL_EZI_EN | SCU_SCL_ZIF_DIS \
|
||||
SCU_SDA_EFP | SCU_SDA_EHD | SCU_SDA_EZI_EN)
|
||||
|
||||
/*
|
||||
* SCU PIN Normal Drive:
|
||||
* The pin configuration registers for normal-drive pins control the following pins:
|
||||
* - P0_0 and P0_1
|
||||
* - P1_0 to P1_16 and P1_18 to P1_20
|
||||
* - P2_0 to P2_2 and P2_6 to P2_13
|
||||
* - P3_0 to P3_2 and P3_4 to P3_8
|
||||
* - P4_0 to P4_10
|
||||
* - P5_0 to P5_7
|
||||
* - P6_0 to P6_12
|
||||
* - P7_0 to P7_7
|
||||
* - P8_3 to P8_8
|
||||
* - P9_0 to P9_6
|
||||
* - PA_0 and PA_4
|
||||
* - PB_0 to PB_6
|
||||
* - PC_0 to PC_14
|
||||
* - PE_0 to PE_15
|
||||
* - PF_0 to PF_11
|
||||
*
|
||||
* Pin configuration registers for High-Drive pins.
|
||||
* The pin configuration registers for high-drive pins control the following pins:
|
||||
* - P1_17
|
||||
* - P2_3 to P2_5
|
||||
* - P8_0 to P8_2
|
||||
* - PA_1 to PA_3
|
||||
*
|
||||
* Pin configuration registers for High-Speed pins.
|
||||
* This register controls the following pins:
|
||||
* - P3_3 and pins CLK0 to CLK3.
|
||||
*/
|
||||
typedef enum {
|
||||
/* Group Port 0 */
|
||||
P0_0 = (PIN_GROUP0+PIN0),
|
||||
P0_1 = (PIN_GROUP0+PIN1),
|
||||
|
||||
/* Group Port 1 */
|
||||
P1_0 = (PIN_GROUP1+PIN0),
|
||||
P1_1 = (PIN_GROUP1+PIN1),
|
||||
P1_2 = (PIN_GROUP1+PIN2),
|
||||
P1_3 = (PIN_GROUP1+PIN3),
|
||||
P1_4 = (PIN_GROUP1+PIN4),
|
||||
P1_5 = (PIN_GROUP1+PIN5),
|
||||
P1_6 = (PIN_GROUP1+PIN6),
|
||||
P1_7 = (PIN_GROUP1+PIN7),
|
||||
P1_8 = (PIN_GROUP1+PIN8),
|
||||
P1_9 = (PIN_GROUP1+PIN9),
|
||||
P1_10 = (PIN_GROUP1+PIN10),
|
||||
P1_11 = (PIN_GROUP1+PIN11),
|
||||
P1_12 = (PIN_GROUP1+PIN12),
|
||||
P1_13 = (PIN_GROUP1+PIN13),
|
||||
P1_14 = (PIN_GROUP1+PIN14),
|
||||
P1_15 = (PIN_GROUP1+PIN15),
|
||||
P1_16 = (PIN_GROUP1+PIN16),
|
||||
|
||||
/* P1_17 is High-Drive pin */
|
||||
P1_17 = (PIN_GROUP1+PIN17),
|
||||
|
||||
P1_18 = (PIN_GROUP1+PIN18),
|
||||
P1_19 = (PIN_GROUP1+PIN19),
|
||||
P1_20 = (PIN_GROUP1+PIN20),
|
||||
|
||||
/* Group Port 2 */
|
||||
P2_0 = (PIN_GROUP2+PIN0),
|
||||
P2_1 = (PIN_GROUP2+PIN1),
|
||||
P2_2 = (PIN_GROUP2+PIN2),
|
||||
|
||||
/* P2_3 to P2_5 are High-Drive pins */
|
||||
P2_3 = (PIN_GROUP2+PIN3),
|
||||
P2_4 = (PIN_GROUP2+PIN4),
|
||||
P2_5 = (PIN_GROUP2+PIN5),
|
||||
|
||||
P2_6 = (PIN_GROUP2+PIN6),
|
||||
P2_7 = (PIN_GROUP2+PIN7),
|
||||
P2_8 = (PIN_GROUP2+PIN8),
|
||||
P2_9 = (PIN_GROUP2+PIN9),
|
||||
P2_10 = (PIN_GROUP2+PIN10),
|
||||
P2_11 = (PIN_GROUP2+PIN11),
|
||||
P2_12 = (PIN_GROUP2+PIN12),
|
||||
P2_13 = (PIN_GROUP2+PIN13),
|
||||
|
||||
/* Group Port 3 */
|
||||
P3_0 = (PIN_GROUP3+PIN0),
|
||||
P3_1 = (PIN_GROUP3+PIN1),
|
||||
P3_2 = (PIN_GROUP3+PIN2),
|
||||
|
||||
/* P3_3 is High-Speed pin */
|
||||
P3_3 = (PIN_GROUP3+PIN3),
|
||||
|
||||
P3_4 = (PIN_GROUP3+PIN4),
|
||||
P3_5 = (PIN_GROUP3+PIN5),
|
||||
P3_6 = (PIN_GROUP3+PIN6),
|
||||
P3_7 = (PIN_GROUP3+PIN7),
|
||||
P3_8 = (PIN_GROUP3+PIN8),
|
||||
|
||||
/* Group Port 4 */
|
||||
P4_0 = (PIN_GROUP4+PIN0),
|
||||
P4_1 = (PIN_GROUP4+PIN1),
|
||||
P4_2 = (PIN_GROUP4+PIN2),
|
||||
P4_3 = (PIN_GROUP4+PIN3),
|
||||
P4_4 = (PIN_GROUP4+PIN4),
|
||||
P4_5 = (PIN_GROUP4+PIN5),
|
||||
P4_6 = (PIN_GROUP4+PIN6),
|
||||
P4_7 = (PIN_GROUP4+PIN7),
|
||||
P4_8 = (PIN_GROUP4+PIN8),
|
||||
P4_9 = (PIN_GROUP4+PIN9),
|
||||
P4_10 = (PIN_GROUP4+PIN10),
|
||||
|
||||
/* Group Port 5 */
|
||||
P5_0 = (PIN_GROUP5+PIN0),
|
||||
P5_1 = (PIN_GROUP5+PIN1),
|
||||
P5_2 = (PIN_GROUP5+PIN2),
|
||||
P5_3 = (PIN_GROUP5+PIN3),
|
||||
P5_4 = (PIN_GROUP5+PIN4),
|
||||
P5_5 = (PIN_GROUP5+PIN5),
|
||||
P5_6 = (PIN_GROUP5+PIN6),
|
||||
P5_7 = (PIN_GROUP5+PIN7),
|
||||
|
||||
/* Group Port 6 */
|
||||
P6_0 = (PIN_GROUP6+PIN0),
|
||||
P6_1 = (PIN_GROUP6+PIN1),
|
||||
P6_2 = (PIN_GROUP6+PIN2),
|
||||
P6_3 = (PIN_GROUP6+PIN3),
|
||||
P6_4 = (PIN_GROUP6+PIN4),
|
||||
P6_5 = (PIN_GROUP6+PIN5),
|
||||
P6_6 = (PIN_GROUP6+PIN6),
|
||||
P6_7 = (PIN_GROUP6+PIN7),
|
||||
P6_8 = (PIN_GROUP6+PIN8),
|
||||
P6_9 = (PIN_GROUP6+PIN9),
|
||||
P6_10 = (PIN_GROUP6+PIN10),
|
||||
P6_11 = (PIN_GROUP6+PIN11),
|
||||
P6_12 = (PIN_GROUP6+PIN12),
|
||||
|
||||
/* Group Port 7 */
|
||||
P7_0 = (PIN_GROUP7+PIN0),
|
||||
P7_1 = (PIN_GROUP7+PIN1),
|
||||
P7_2 = (PIN_GROUP7+PIN2),
|
||||
P7_3 = (PIN_GROUP7+PIN3),
|
||||
P7_4 = (PIN_GROUP7+PIN4),
|
||||
P7_5 = (PIN_GROUP7+PIN5),
|
||||
P7_6 = (PIN_GROUP7+PIN6),
|
||||
P7_7 = (PIN_GROUP7+PIN7),
|
||||
|
||||
/* Group Port 8 */
|
||||
/* P8_0 to P8_2 are High-Drive pins */
|
||||
P8_0 = (PIN_GROUP8+PIN0),
|
||||
P8_1 = (PIN_GROUP8+PIN1),
|
||||
P8_2 = (PIN_GROUP8+PIN2),
|
||||
|
||||
P8_3 = (PIN_GROUP8+PIN3),
|
||||
P8_4 = (PIN_GROUP8+PIN4),
|
||||
P8_5 = (PIN_GROUP8+PIN5),
|
||||
P8_6 = (PIN_GROUP8+PIN6),
|
||||
P8_7 = (PIN_GROUP8+PIN7),
|
||||
P8_8 = (PIN_GROUP8+PIN8),
|
||||
|
||||
/* Group Port 9 */
|
||||
P9_0 = (PIN_GROUP9+PIN0),
|
||||
P9_1 = (PIN_GROUP9+PIN1),
|
||||
P9_2 = (PIN_GROUP9+PIN2),
|
||||
P9_3 = (PIN_GROUP9+PIN3),
|
||||
P9_4 = (PIN_GROUP9+PIN4),
|
||||
P9_5 = (PIN_GROUP9+PIN5),
|
||||
P9_6 = (PIN_GROUP9+PIN6),
|
||||
|
||||
/* Group Port A */
|
||||
PA_0 = (PIN_GROUPA+PIN0),
|
||||
/* PA_1 to PA_3 are Normal & High-Drive Pins */
|
||||
PA_1 = (PIN_GROUPA+PIN1),
|
||||
PA_2 = (PIN_GROUPA+PIN2),
|
||||
PA_3 = (PIN_GROUPA+PIN3),
|
||||
PA_4 = (PIN_GROUPA+PIN4),
|
||||
|
||||
/* Group Port B */
|
||||
PB_0 = (PIN_GROUPB+PIN0),
|
||||
PB_1 = (PIN_GROUPB+PIN1),
|
||||
PB_2 = (PIN_GROUPB+PIN2),
|
||||
PB_3 = (PIN_GROUPB+PIN3),
|
||||
PB_4 = (PIN_GROUPB+PIN4),
|
||||
PB_5 = (PIN_GROUPB+PIN5),
|
||||
PB_6 = (PIN_GROUPB+PIN6),
|
||||
|
||||
/* Group Port C */
|
||||
PC_0 = (PIN_GROUPC+PIN0),
|
||||
PC_1 = (PIN_GROUPC+PIN1),
|
||||
PC_2 = (PIN_GROUPC+PIN2),
|
||||
PC_3 = (PIN_GROUPC+PIN3),
|
||||
PC_4 = (PIN_GROUPC+PIN4),
|
||||
PC_5 = (PIN_GROUPC+PIN5),
|
||||
PC_6 = (PIN_GROUPC+PIN6),
|
||||
PC_7 = (PIN_GROUPC+PIN7),
|
||||
PC_8 = (PIN_GROUPC+PIN8),
|
||||
PC_9 = (PIN_GROUPC+PIN9),
|
||||
PC_10 = (PIN_GROUPC+PIN10),
|
||||
PC_11 = (PIN_GROUPC+PIN11),
|
||||
PC_12 = (PIN_GROUPC+PIN12),
|
||||
PC_13 = (PIN_GROUPC+PIN13),
|
||||
PC_14 = (PIN_GROUPC+PIN14),
|
||||
|
||||
/* Group Port D (seems not configurable through SCU, not defined in UM10503.pdf Rev.1, keep it here) */
|
||||
PD_0 = (PIN_GROUPD+PIN0),
|
||||
PD_1 = (PIN_GROUPD+PIN1),
|
||||
PD_2 = (PIN_GROUPD+PIN2),
|
||||
PD_3 = (PIN_GROUPD+PIN3),
|
||||
PD_4 = (PIN_GROUPD+PIN4),
|
||||
PD_5 = (PIN_GROUPD+PIN5),
|
||||
PD_6 = (PIN_GROUPD+PIN6),
|
||||
PD_7 = (PIN_GROUPD+PIN7),
|
||||
PD_8 = (PIN_GROUPD+PIN8),
|
||||
PD_9 = (PIN_GROUPD+PIN9),
|
||||
PD_10 = (PIN_GROUPD+PIN10),
|
||||
PD_11 = (PIN_GROUPD+PIN11),
|
||||
PD_12 = (PIN_GROUPD+PIN12),
|
||||
PD_13 = (PIN_GROUPD+PIN13),
|
||||
PD_14 = (PIN_GROUPD+PIN14),
|
||||
PD_15 = (PIN_GROUPD+PIN15),
|
||||
PD_16 = (PIN_GROUPD+PIN16),
|
||||
|
||||
/* Group Port E */
|
||||
PE_0 = (PIN_GROUPE+PIN0),
|
||||
PE_1 = (PIN_GROUPE+PIN1),
|
||||
PE_2 = (PIN_GROUPE+PIN2),
|
||||
PE_3 = (PIN_GROUPE+PIN3),
|
||||
PE_4 = (PIN_GROUPE+PIN4),
|
||||
PE_5 = (PIN_GROUPE+PIN5),
|
||||
PE_6 = (PIN_GROUPE+PIN6),
|
||||
PE_7 = (PIN_GROUPE+PIN7),
|
||||
PE_8 = (PIN_GROUPE+PIN8),
|
||||
PE_9 = (PIN_GROUPE+PIN9),
|
||||
PE_10 = (PIN_GROUPE+PIN10),
|
||||
PE_11 = (PIN_GROUPE+PIN11),
|
||||
PE_12 = (PIN_GROUPE+PIN12),
|
||||
PE_13 = (PIN_GROUPE+PIN13),
|
||||
PE_14 = (PIN_GROUPE+PIN14),
|
||||
PE_15 = (PIN_GROUPE+PIN15),
|
||||
|
||||
/* Group Port F */
|
||||
PF_0 = (PIN_GROUPF+PIN0),
|
||||
PF_1 = (PIN_GROUPF+PIN1),
|
||||
PF_2 = (PIN_GROUPF+PIN2),
|
||||
PF_3 = (PIN_GROUPF+PIN3),
|
||||
PF_4 = (PIN_GROUPF+PIN4),
|
||||
PF_5 = (PIN_GROUPF+PIN5),
|
||||
PF_6 = (PIN_GROUPF+PIN6),
|
||||
PF_7 = (PIN_GROUPF+PIN7),
|
||||
PF_8 = (PIN_GROUPF+PIN8),
|
||||
PF_9 = (PIN_GROUPF+PIN9),
|
||||
PF_10 = (PIN_GROUPF+PIN10),
|
||||
PF_11 = (PIN_GROUPF+PIN11),
|
||||
|
||||
/* Group Clock 0 to 3 High-Speed pins */
|
||||
CLK0 = (SCU_BASE + 0xC00),
|
||||
CLK1 = (SCU_BASE + 0xC04),
|
||||
CLK2 = (SCU_BASE + 0xC08),
|
||||
CLK3 = (SCU_BASE + 0xC0C)
|
||||
|
||||
} scu_grp_pin_t;
|
||||
|
||||
/*
|
||||
* Pin Configuration to be used for scu_pinmux() parameter scu_conf
|
||||
* For normal-drive pins, high-drive pins, high-speed pins
|
||||
*/
|
||||
/*
|
||||
* Function BIT0 to 2.
|
||||
* Common to normal-drive pins, high-drive pins, high-speed pins.
|
||||
*/
|
||||
#define SCU_CONF_FUNCTION0 (0x0)
|
||||
#define SCU_CONF_FUNCTION1 (0x1)
|
||||
#define SCU_CONF_FUNCTION2 (0x2)
|
||||
#define SCU_CONF_FUNCTION3 (0x3)
|
||||
#define SCU_CONF_FUNCTION4 (0x4)
|
||||
#define SCU_CONF_FUNCTION5 (0x5)
|
||||
#define SCU_CONF_FUNCTION6 (0x6)
|
||||
#define SCU_CONF_FUNCTION7 (0x7)
|
||||
|
||||
/*
|
||||
* Enable pull-down resistor at pad
|
||||
* By default=0 Disable pull-down.
|
||||
* Available to normal-drive pins, high-drive pins, high-speed pins
|
||||
*/
|
||||
#define SCU_CONF_EPD_EN_PULLDOWN (BIT3)
|
||||
|
||||
/*
|
||||
* Disable pull-up resistor at pad.
|
||||
* By default=0 the pull-up resistor is enabled at reset.
|
||||
* Available to normal-drive pins, high-drive pins, high-speed pins
|
||||
*/
|
||||
#define SCU_CONF_EPUN_DIS_PULLUP (BIT4)
|
||||
|
||||
/*
|
||||
* Select Slew Rate.
|
||||
* By Default=0 Slow.
|
||||
* Available to normal-drive pins and high-speed pins, reserved for high-drive pins.
|
||||
*/
|
||||
#define SCU_CONF_EHS_FAST (BIT5)
|
||||
|
||||
/*
|
||||
* Input buffer enable.
|
||||
* By Default=0 Disable Input Buffer.
|
||||
* The input buffer is disabled by default at reset and must be enabled.
|
||||
* for receiving(in normal/highspeed-drive) or to transfer data from the I/O buffer to the pad(in high-drive pins).
|
||||
* Available to normal-drive pins, high-drive pins, high-speed pins.
|
||||
*/
|
||||
#define SCU_CONF_EZI_EN_IN_BUFFER (BIT6)
|
||||
|
||||
/*
|
||||
* Input glitch filter. Disable the input glitch filter for clocking signals higher than 30 MHz.
|
||||
* Available to normal-drive pins, high-drive pins, high-speed pins.
|
||||
*/
|
||||
#define SCU_CONF_ZIF_DIS_IN_GLITCH_FILT (BIT7)
|
||||
|
||||
/*
|
||||
* Select drive strength. (default=0 Normal-drive: 4 mA drive strength) (BIT8/9).
|
||||
* Available to high-drive pins, reserved for others.
|
||||
*/
|
||||
#define SCU_CONF_EHD_NORMAL_DRIVE_8MILLIA (0x100)
|
||||
#define SCU_CONF_EHD_NORMAL_DRIVE_14MILLIA (0x200)
|
||||
#define SCU_CONF_EHD_NORMAL_DRIVE_20MILLIA (0x300)
|
||||
|
||||
/* BIT10 to 31 are Reserved */
|
||||
|
||||
/* Configuration for different I/O pins types */
|
||||
#define SCU_EMC_IO (SCU_CONF_EPD_EN_PULLDOWN | SCU_CONF_EHS_FAST | SCU_CONF_EZI_EN_IN_BUFFER | SCU_CONF_ZIF_DIS_IN_GLITCH_FILT)
|
||||
#define SCU_LCD (SCU_CONF_EPUN_DIS_PULLUP | SCU_CONF_EHS_FAST | SCU_CONF_EZI_EN_IN_BUFFER | SCU_CONF_ZIF_DIS_IN_GLITCH_FILT)
|
||||
#define SCU_CLK_IN (SCU_CONF_EPD_EN_PULLDOWN | SCU_CONF_EHS_FAST | SCU_CONF_EZI_EN_IN_BUFFER | SCU_CONF_ZIF_DIS_IN_GLITCH_FILT)
|
||||
#define SCU_CLK_OUT (SCU_CONF_EPD_EN_PULLDOWN | SCU_CONF_EHS_FAST | SCU_CONF_EZI_EN_IN_BUFFER | SCU_CONF_ZIF_DIS_IN_GLITCH_FILT)
|
||||
#define SCU_GPIO_PUP (SCU_CONF_EZI_EN_IN_BUFFER)
|
||||
#define SCU_GPIO_PDN (SCU_CONF_EPUN_DIS_PULLUP | SCU_CONF_EPD_EN_PULLDOWN | SCU_CONF_EZI_EN_IN_BUFFER)
|
||||
#define SCU_GPIO_NOPULL (SCU_CONF_EPUN_DIS_PULLUP | SCU_CONF_EZI_EN_IN_BUFFER)
|
||||
#define SCU_GPIO_FAST (SCU_CONF_EPUN_DIS_PULLUP | SCU_CONF_EHS_FAST | SCU_CONF_EZI_EN_IN_BUFFER | SCU_CONF_ZIF_DIS_IN_GLITCH_FILT)
|
||||
#define SCU_UART_RX_TX (SCU_CONF_EPUN_DIS_PULLUP | SCU_CONF_EPD_EN_PULLDOWN | SCU_CONF_EZI_EN_IN_BUFFER)
|
||||
#define SCU_SSP_IO (SCU_CONF_EPD_EN_PULLDOWN | SCU_CONF_EHS_FAST | SCU_CONF_EZI_EN_IN_BUFFER | SCU_CONF_ZIF_DIS_IN_GLITCH_FILT)
|
||||
|
||||
void scu_pinmux(scu_grp_pin_t group_pin, u32 scu_conf);
|
||||
|
||||
#endif
|
||||
|
|
|
@ -3,6 +3,7 @@
|
|||
##
|
||||
## Copyright (C) 2009 Uwe Hermann <uwe@hermann-uwe.de>
|
||||
## Copyright (C) 2012 Michael Ossmann <mike@ossmann.com>
|
||||
## Copyright (C) 2012 Benjamin Vernoux <titanmkd@gmail.com>
|
||||
##
|
||||
## This library is free software: you can redistribute it and/or modify
|
||||
## it under the terms of the GNU Lesser General Public License as published by
|
||||
|
@ -24,13 +25,13 @@ PREFIX ?= arm-none-eabi
|
|||
#PREFIX ?= arm-elf
|
||||
CC = $(PREFIX)-gcc
|
||||
AR = $(PREFIX)-ar
|
||||
CFLAGS = -O0 -g -Wall -Wextra -I../../include -fno-common \
|
||||
CFLAGS = -O2 -g -Wall -Wextra -I../../include -fno-common \
|
||||
-mcpu=cortex-m4 -mthumb -Wstrict-prototypes \
|
||||
-ffunction-sections -fdata-sections -MD \
|
||||
-mfloat-abi=hard -mfpu=fpv4-sp-d16
|
||||
# ARFLAGS = rcsv
|
||||
ARFLAGS = rcs
|
||||
OBJS = gpio.o vector.o
|
||||
OBJS = gpio.o vector.o scu.o
|
||||
|
||||
# VPATH += ../usb
|
||||
|
||||
|
@ -50,7 +51,7 @@ $(LIBNAME).a: $(OBJS)
|
|||
$(Q)$(CC) $(CFLAGS) -o $@ -c $<
|
||||
|
||||
clean:
|
||||
@printf " CLEAN lib/lpc17xx\n"
|
||||
@printf " CLEAN lib/lpc43xx\n"
|
||||
$(Q)rm -f *.o *.d
|
||||
$(Q)rm -f $(LIBNAME).a
|
||||
|
||||
|
|
|
@ -0,0 +1,30 @@
|
|||
/*
|
||||
* This file is part of the libopencm3 project.
|
||||
*
|
||||
* Copyright (C) 2012 Benjamin Vernoux <titanmkd@gmail.com>
|
||||
*
|
||||
* This library is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU Lesser General Public License as published by
|
||||
* the Free Software Foundation, either version 3 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* This library is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public License
|
||||
* along with this library. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#include <libopencm3/lpc43xx/scu.h>
|
||||
|
||||
/* For pin_conf_normal value see scu.h define SCU_CONF_XXX or Configuration for different I/O pins types */
|
||||
void scu_pinmux(scu_grp_pin_t group_pin, u32 scu_conf)
|
||||
{
|
||||
MMIO32(group_pin) = scu_conf;
|
||||
}
|
||||
|
||||
/* For other special SCU register USB1, I2C0, ADC0/1, DAC, EMC clock delay See scu.h */
|
||||
|
||||
/* For Pin interrupt select register see scu.h SCU_PINTSEL0 & SCU_PINTSEL1 */
|
Loading…
Reference in New Issue