Move the ChibiOS test subproject board and ld files to the kebyoard folder, so that the build system can find them
		
			
				
	
	
		
			167 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			167 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|     ChibiOS - Copyright (C) 2006..2015 Giovanni Di Sirio
 | |
| 
 | |
|     Licensed under the Apache License, Version 2.0 (the "License");
 | |
|     you may not use this file except in compliance with the License.
 | |
|     You may obtain a copy of the License at
 | |
| 
 | |
|         http://www.apache.org/licenses/LICENSE-2.0
 | |
| 
 | |
|     Unless required by applicable law or agreed to in writing, software
 | |
|     distributed under the License is distributed on an "AS IS" BASIS,
 | |
|     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
|     See the License for the specific language governing permissions and
 | |
|     limitations under the License.
 | |
| */
 | |
| 
 | |
| #ifndef _BOARD_H_
 | |
| #define _BOARD_H_
 | |
| 
 | |
| /*
 | |
|  * Setup for a Generic STM32F103 board.
 | |
|  */
 | |
| 
 | |
| /*
 | |
|  * Board identifier.
 | |
|  */
 | |
| #define BOARD_GENERIC_STM32_F103
 | |
| #define BOARD_NAME              "Generic STM32F103x board"
 | |
| 
 | |
| /*
 | |
|  * Board frequencies.
 | |
|  */
 | |
| #define STM32_LSECLK            32768
 | |
| #define STM32_HSECLK            8000000
 | |
| 
 | |
| /*
 | |
|  * MCU type, supported types are defined in ./os/hal/platforms/hal_lld.h.
 | |
|  */
 | |
| #define STM32F103xB
 | |
| 
 | |
| /*
 | |
|  * IO pins assignments
 | |
|  */
 | |
| 
 | |
| /* on-board */
 | |
| 
 | |
| #define GPIOC_LED               13
 | |
| #define GPIOD_OSC_IN            0
 | |
| #define GPIOD_OSC_OUT           1
 | |
| 
 | |
| /* In case your board has a "USB enable" hardware
 | |
|    controlled by a pin, define it here. (It could be just
 | |
|    a 1.5k resistor connected to D+ line.)
 | |
| */
 | |
| /*
 | |
| #define GPIOB_USB_DISC          10
 | |
| */
 | |
| 
 | |
| /*
 | |
|  * I/O ports initial setup, this configuration is established soon after reset
 | |
|  * in the initialization code.
 | |
|  *
 | |
|  * The digits have the following meaning:
 | |
|  *   0 - Analog input.
 | |
|  *   1 - Push Pull output 10MHz.
 | |
|  *   2 - Push Pull output 2MHz.
 | |
|  *   3 - Push Pull output 50MHz.
 | |
|  *   4 - Digital input.
 | |
|  *   5 - Open Drain output 10MHz.
 | |
|  *   6 - Open Drain output 2MHz.
 | |
|  *   7 - Open Drain output 50MHz.
 | |
|  *   8 - Digital input with PullUp or PullDown resistor depending on ODR.
 | |
|  *   9 - Alternate Push Pull output 10MHz.
 | |
|  *   A - Alternate Push Pull output 2MHz.
 | |
|  *   B - Alternate Push Pull output 50MHz.
 | |
|  *   C - Reserved.
 | |
|  *   D - Alternate Open Drain output 10MHz.
 | |
|  *   E - Alternate Open Drain output 2MHz.
 | |
|  *   F - Alternate Open Drain output 50MHz.
 | |
|  * Please refer to the STM32 Reference Manual for details.
 | |
|  */
 | |
| 
 | |
| /*
 | |
|  * Port A setup.
 | |
|  * Everything input with pull-up except:
 | |
|  * PA2  - Alternate output  (USART2 TX).
 | |
|  * PA3  - Normal input      (USART2 RX).
 | |
|  * PA9  - Alternate output  (USART1 TX).
 | |
|  * PA10 - Normal input      (USART1 RX).
 | |
|  */
 | |
| #define VAL_GPIOACRL            0x88884B88      /*  PA7...PA0 */
 | |
| #define VAL_GPIOACRH            0x888884B8      /* PA15...PA8 */
 | |
| #define VAL_GPIOAODR            0xFFFFFFFF
 | |
| 
 | |
| /*
 | |
|  * Port B setup.
 | |
|  * Everything input with pull-up except:
 | |
|  * PB10    - Push Pull output  (USB switch).
 | |
|  */
 | |
| #define VAL_GPIOBCRL            0x88888888      /*  PB7...PB0 */
 | |
| #define VAL_GPIOBCRH            0x88888388      /* PB15...PB8 */
 | |
| #define VAL_GPIOBODR            0xFFFFFFFF
 | |
| 
 | |
| /*
 | |
|  * Port C setup.
 | |
|  * Everything input with pull-up except:
 | |
|  * PC13    - Push Pull output  (LED).
 | |
|  */
 | |
| #define VAL_GPIOCCRL            0x88888888      /*  PC7...PC0 */
 | |
| #define VAL_GPIOCCRH            0x88388888      /* PC15...PC8 */
 | |
| #define VAL_GPIOCODR            0xFFFFFFFF
 | |
| 
 | |
| /*
 | |
|  * Port D setup.
 | |
|  * Everything input with pull-up except:
 | |
|  * PD0  - Normal input (XTAL).
 | |
|  * PD1  - Normal input (XTAL).
 | |
|  */
 | |
| #define VAL_GPIODCRL            0x88888844      /*  PD7...PD0 */
 | |
| #define VAL_GPIODCRH            0x88888888      /* PD15...PD8 */
 | |
| #define VAL_GPIODODR            0xFFFFFFFF
 | |
| 
 | |
| /*
 | |
|  * Port E setup.
 | |
|  * Everything input with pull-up except:
 | |
|  */
 | |
| #define VAL_GPIOECRL            0x88888888      /*  PE7...PE0 */
 | |
| #define VAL_GPIOECRH            0x88888888      /* PE15...PE8 */
 | |
| #define VAL_GPIOEODR            0xFFFFFFFF
 | |
| 
 | |
| /*
 | |
|  * USB bus activation macro, required by the USB driver.
 | |
|  */
 | |
| /* The point is that most of the generic STM32F103* boards
 | |
|    have a 1.5k resistor connected on one end to the D+ line
 | |
|    and on the other end to some pin. Or even a slightly more
 | |
|    complicated "USB enable" circuit, controlled by a pin.
 | |
|    That should go here.
 | |
| 
 | |
|    However on some boards (e.g. one that I have), there's no
 | |
|    such hardware. In which case it's better to not do anything.
 | |
| */
 | |
| /*
 | |
| #define usb_lld_connect_bus(usbp) palClearPad(GPIOB, GPIOB_USB_DISC)
 | |
| */
 | |
| #define usb_lld_connect_bus(usbp) palSetPadMode(GPIOA, 12, PAL_MODE_INPUT);
 | |
| 
 | |
| /*
 | |
|  * USB bus de-activation macro, required by the USB driver.
 | |
|  */
 | |
| /*
 | |
| #define usb_lld_disconnect_bus(usbp) palSetPad(GPIOB, GPIOB_USB_DISC)
 | |
| */
 | |
| #define usb_lld_disconnect_bus(usbp) palSetPadMode(GPIOA, 12, PAL_MODE_OUTPUT_PUSHPULL); palClearPad(GPIOA, 12);
 | |
| 
 | |
| #if !defined(_FROM_ASM_)
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
|   void boardInit(void);
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 | |
| #endif /* _FROM_ASM_ */
 | |
| 
 | |
| #endif /* _BOARD_H_ */
 |