mbed(SerialHalfDuplex入り)
Fork of mbed by
Revision 28:667d61c9177b, committed 2011-12-08
- Comitter:
- emilmont
- Date:
- Thu Dec 08 12:04:01 2011 +0000
- Parent:
- 27:7110ebee3484
- Child:
- 29:078e4b97a13e
- Commit message:
- Add additional M0 peripherals implementations, fix GCC stdio/uart
Changed in this revision
Binary file LPC11U24/ARM/capi.ar has changed
Binary file LPC11U24/ARM/cmsis_nvic.o has changed
Binary file LPC11U24/ARM/mbed.ar has changed
Binary file LPC11U24/ARM/system_LPC11Uxx.o has changed
Binary file LPC11U24/GCC_ARM/libcapi.a has changed
Binary file LPC11U24/GCC_ARM/libmbed.a has changed
Binary file LPC11U24/GCC_CR/libcapi.a has changed
Binary file LPC11U24/GCC_CR/libmbed.a has changed
Binary file LPC11U24/GCC_CS/libcapi.a has changed
Binary file LPC11U24/GCC_CS/libmbed.a has changed
Binary file LPC11U24/uARM/capi.ar has changed
Binary file LPC11U24/uARM/cmsis_nvic.o has changed
Binary file LPC11U24/uARM/mbed.ar has changed
Binary file LPC11U24/uARM/system_LPC11Uxx.o has changed
Binary file LPC1768/ARM/capi.ar has changed
Binary file LPC1768/ARM/cmsis_nvic.o has changed
Binary file LPC1768/ARM/mbed.ar has changed
Binary file LPC1768/ARM/system_LPC17xx.o has changed
Binary file LPC1768/GCC_ARM/libcapi.a has changed
Binary file LPC1768/GCC_ARM/libmbed.a has changed
Binary file LPC1768/GCC_CR/libcapi.a has changed
Binary file LPC1768/GCC_CR/libmbed.a has changed
Binary file LPC1768/GCC_CS/libcapi.a has changed
Binary file LPC1768/GCC_CS/libmbed.a has changed
Binary file LPC1768/uARM/capi.ar has changed
Binary file LPC1768/uARM/cmsis_nvic.o has changed
Binary file LPC1768/uARM/mbed.ar has changed
Binary file LPC1768/uARM/system_LPC17xx.o has changed
Binary file LPC2368/ARM/capi.ar has changed
Binary file LPC2368/ARM/mbed.ar has changed
Binary file LPC2368/GCC_ARM/libcapi.a has changed
Binary file LPC2368/GCC_ARM/libmbed.a has changed
Binary file LPC2368/GCC_CR/libcapi.a has changed
Binary file LPC2368/GCC_CR/libmbed.a has changed
Binary file LPC2368/GCC_CS/libcapi.a has changed
Binary file LPC2368/GCC_CS/libmbed.a has changed
Binary file LPC2368/uARM/capi.ar has changed
Binary file LPC2368/uARM/mbed.ar has changed
--- a/PeripheralNames.h Tue Nov 29 14:59:27 2011 +0000 +++ b/PeripheralNames.h Thu Dec 08 12:04:01 2011 +0000 @@ -77,9 +77,6 @@ }; typedef enum CANName CANName; -#define STDIO_UART_TX USBTX -#define STDIO_UART_RX USBRX -#define STDIO_UART UART_0 #define US_TICKER_TIMER TIMER_3 #define US_TICKER_TIMER_IRQn TIMER3_IRQn @@ -96,8 +93,8 @@ typedef enum I2CName I2CName; enum TimerName { - TIMER_0 = (int)LPC_CT32B0_BASE - , TIMER_1 = (int)LPC_CT32B1_BASE + TIMER_0 = (int)LPC_CT32B0_BASE + , TIMER_1 = (int)LPC_CT32B1_BASE }; typedef enum TimerName TimerName; @@ -119,15 +116,22 @@ }; typedef enum SPIName SPIName; +#define US_TICKER_TIMER TIMER_1 +#define US_TICKER_TIMER_IRQn TIMER_32_1_IRQn + +typedef enum PWMName { + PWM_1 = 0 + , PWM_2 + , PWM_3 + , PWM_4 +} PWMName; + +#endif + #define STDIO_UART_TX USBTX #define STDIO_UART_RX USBRX #define STDIO_UART UART_0 -#define US_TICKER_TIMER TIMER_1 -#define US_TICKER_TIMER_IRQn TIMER_32_1_IRQn - -#endif - #ifdef __cplusplus } #endif
--- a/PinNames.h Tue Nov 29 14:59:27 2011 +0000 +++ b/PinNames.h Thu Dec 08 12:04:01 2011 +0000 @@ -96,6 +96,19 @@ }; typedef enum PinMode PinMode; +// version of PINCON_TypeDef using register arrays +typedef struct { + __IO uint32_t PINSEL[11]; + uint32_t RESERVED0[5]; + __IO uint32_t PINMODE[10]; +#ifndef TARGET_LPC2368 +// Open drain mode is not available on LPC2368 + __IO uint32_t PINMODE_OD[5]; +#endif +} PINCONARRAY_TypeDef; + +#define PINCONARRAY ((PINCONARRAY_TypeDef *)LPC_PINCON_BASE) + #elif defined(TARGET_LPC11U24) @@ -126,6 +139,10 @@ , P0_21 = 21 , P0_22 = 22 , P0_23 = 23 + , P0_24 = 24 + , P0_25 = 25 + , P0_26 = 26 + , P0_27 = 27 , P1_0 = 32 , P1_1 = 33
--- a/PortIn.h Tue Nov 29 14:59:27 2011 +0000 +++ b/PortIn.h Thu Dec 08 12:04:01 2011 +0000 @@ -54,9 +54,7 @@ * Variables: * returns - An integer with each bit corresponding to associated port pin setting */ - int read() { - return _gpio->FIOPIN & _mask; - } + int read(); /* Function: mode * Set the input pin mode @@ -74,9 +72,11 @@ } private: +#if defined(TARGET_LPC1768) || defined(TARGET_LPC2368) LPC_GPIO_TypeDef *_gpio; +#endif PortName _port; - uint32_t _mask; + uint32_t _mask; }; } // namespace mbed
--- a/PortInOut.h Tue Nov 29 14:59:27 2011 +0000 +++ b/PortInOut.h Thu Dec 08 12:04:01 2011 +0000 @@ -35,9 +35,7 @@ * Variables: * value - An integer specifying a bit to write for every corresponding port pin */ - void write(int value) { - _gpio->FIOPIN = (_gpio->FIOPIN & ~_mask) | (value & _mask); - } + void write(int value); /* Function: read * Read the value currently output on the port @@ -45,9 +43,7 @@ * Variables: * returns - An integer with each bit corresponding to associated port pin setting */ - int read() { - return _gpio->FIOPIN & _mask; - } + int read(); /* Function: output * Set as an output @@ -88,9 +84,11 @@ } private: +#if defined(TARGET_LPC1768) || defined(TARGET_LPC2368) LPC_GPIO_TypeDef *_gpio; +#endif PortName _port; - uint32_t _mask; + uint32_t _mask; }; } // namespace mbed
--- a/PortOut.h Tue Nov 29 14:59:27 2011 +0000 +++ b/PortOut.h Thu Dec 08 12:04:01 2011 +0000 @@ -56,9 +56,7 @@ * Variables: * value - An integer specifying a bit to write for every corresponding PortOut pin */ - void write(int value) { - _gpio->FIOPIN = (_gpio->FIOPIN & ~_mask) | (value & _mask); - } + void write(int value); /* Function: read * Read the value currently output on the port @@ -66,9 +64,7 @@ * Variables: * returns - An integer with each bit corresponding to associated PortOut pin setting */ - int read() { - return _gpio->FIOPIN & _mask; - } + int read(); /* Function: operator= * A shorthand for <write> @@ -91,9 +87,11 @@ } private: +#if defined(TARGET_LPC1768) || defined(TARGET_LPC2368) LPC_GPIO_TypeDef *_gpio; - PortName _port; - uint32_t _mask; +#endif + PortName _port; + uint32_t _mask; }; } // namespace mbed
--- a/device.h Tue Nov 29 14:59:27 2011 +0000 +++ b/device.h Thu Dec 08 12:04:01 2011 +0000 @@ -33,9 +33,9 @@ #elif defined(TARGET_LPC11U24) -#define DEVICE_PORTIN 0 -#define DEVICE_PORTOUT 0 -#define DEVICE_PORTINOUT 0 +#define DEVICE_PORTIN 1 +#define DEVICE_PORTOUT 1 +#define DEVICE_PORTINOUT 1 #define DEVICE_INTERRUPTIN 1 @@ -58,7 +58,7 @@ #define DEVICE_ETHERNET 0 -#define DEVICE_PWMOUT 0 +#define DEVICE_PWMOUT 1 #endif
--- a/platform.h Tue Nov 29 14:59:27 2011 +0000 +++ b/platform.h Thu Dec 08 12:04:01 2011 +0000 @@ -5,9 +5,7 @@ #ifndef MBED_PLATFORM_H #define MBED_PLATFORM_H -#if defined(TARGET_LPC1768) || defined(TARGET_LPC2368) #define MBED_RPC -#endif #define MBED_OPERATORS
--- a/rpc.h Tue Nov 29 14:59:27 2011 +0000 +++ b/rpc.h Thu Dec 08 12:04:01 2011 +0000 @@ -210,7 +210,11 @@ if(pin2 <= 9) { pin = pin * 10 + pin2; } +#if defined(TARGET_LPC1768) || defined(TARGET_LPC2368) return (PinName)(LPC_GPIO0_BASE + port * 32 + pin); +#elif defined(TARGET_LPC11U24) + return (PinName)(port * 32 + pin); +#endif } else if(str[0] == 'p') { // pn uint32_t pin = str[1] - '0'; // pn uint32_t pin2 = str[2] - '0'; // pnn