Merge branch 'fix-stm-discovery' of github.com:dhylands/micropython into dhylands-fix-stm-discovery

Conflicts:
	stm/main.c
This commit is contained in:
Damien George 2014-01-22 11:56:24 +00:00
commit 8ae1c1beac
3 changed files with 26 additions and 3 deletions

View File

@ -49,6 +49,11 @@
#define SD_DETECT_PIN GPIO_Pin_8 /* PA..8 */ #define SD_DETECT_PIN GPIO_Pin_8 /* PA..8 */
#define SD_DETECT_GPIO_PORT GPIOA /* GPIOA */ #define SD_DETECT_GPIO_PORT GPIOA /* GPIOA */
#define SD_DETECT_GPIO_CLK RCC_AHB1Periph_GPIOA #define SD_DETECT_GPIO_CLK RCC_AHB1Periph_GPIOA
#elif defined(STM32F4DISC)
// PB15 on the DM-STSTF4BB Base Board
#define SD_DETECT_PIN GPIO_Pin_15 /* PB.15 */
#define SD_DETECT_GPIO_PORT GPIOB /* GPIOB */
#define SD_DETECT_GPIO_CLK RCC_AHB1Periph_GPIOB
#endif #endif
#define SDIO_FIFO_ADDRESS ((uint32_t)0x40012C80) #define SDIO_FIFO_ADDRESS ((uint32_t)0x40012C80)

View File

@ -715,7 +715,11 @@ int main(void) {
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_4); NVIC_PriorityGroupConfig(NVIC_PriorityGroup_4);
// enable the CCM RAM and the GPIO's // enable the CCM RAM and the GPIO's
RCC->AHB1ENR |= RCC_AHB1ENR_CCMDATARAMEN | RCC_AHB1ENR_GPIOAEN | RCC_AHB1ENR_GPIOBEN | RCC_AHB1ENR_GPIOCEN; RCC->AHB1ENR |= RCC_AHB1ENR_CCMDATARAMEN | RCC_AHB1ENR_GPIOAEN | RCC_AHB1ENR_GPIOBEN | RCC_AHB1ENR_GPIOCEN
#if defined(STM32F4DISC)
| RCC_AHB1ENR_GPIODEN
#endif
;
// configure SDIO pins to be high to start with (apparently makes it more robust) // configure SDIO pins to be high to start with (apparently makes it more robust)
{ {
@ -794,9 +798,11 @@ soft_reset:
rt_store_attr(m, MP_QSTR_switch, (mp_obj_t)&pyb_switch_obj); rt_store_attr(m, MP_QSTR_switch, (mp_obj_t)&pyb_switch_obj);
rt_store_attr(m, MP_QSTR_servo, rt_make_function_n(2, pyb_servo_set)); rt_store_attr(m, MP_QSTR_servo, rt_make_function_n(2, pyb_servo_set));
rt_store_attr(m, MP_QSTR_pwm, rt_make_function_n(2, pyb_pwm_set)); rt_store_attr(m, MP_QSTR_pwm, rt_make_function_n(2, pyb_pwm_set));
#if BOARD_HAS_MMA7660
rt_store_attr(m, MP_QSTR_accel, (mp_obj_t)&pyb_mma_read_obj); rt_store_attr(m, MP_QSTR_accel, (mp_obj_t)&pyb_mma_read_obj);
rt_store_attr(m, MP_QSTR_mma_read, (mp_obj_t)&pyb_mma_read_all_obj); rt_store_attr(m, MP_QSTR_mma_read, (mp_obj_t)&pyb_mma_read_all_obj);
rt_store_attr(m, MP_QSTR_mma_mode, (mp_obj_t)&pyb_mma_write_mode_obj); rt_store_attr(m, MP_QSTR_mma_mode, (mp_obj_t)&pyb_mma_write_mode_obj);
#endif
rt_store_attr(m, MP_QSTR_hid, rt_make_function_n(1, pyb_hid_send_report)); rt_store_attr(m, MP_QSTR_hid, rt_make_function_n(1, pyb_hid_send_report));
rt_store_attr(m, MP_QSTR_time, rt_make_function_n(0, pyb_rtc_read)); rt_store_attr(m, MP_QSTR_time, rt_make_function_n(0, pyb_rtc_read));
rt_store_attr(m, MP_QSTR_rand, rt_make_function_n(0, pyb_rng_get)); rt_store_attr(m, MP_QSTR_rand, rt_make_function_n(0, pyb_rng_get));
@ -911,10 +917,11 @@ soft_reset:
// USB host; not working! // USB host; not working!
//pyb_usbh_init(); //pyb_usbh_init();
// MMA
if (first_soft_reset) { if (first_soft_reset) {
// init and reset address to zero #if BOARD_HAS_MMA7660
// MMA: init and reset address to zero
mma_init(); mma_init();
#endif
} }
// turn boot-up LED off // turn boot-up LED off
@ -941,6 +948,8 @@ soft_reset:
vstr_free(vstr); vstr_free(vstr);
} }
#if BOARD_HAS_MMA7660
// HID example // HID example
if (0) { if (0) {
uint8_t data[4]; uint8_t data[4];
@ -969,6 +978,7 @@ soft_reset:
sys_tick_delay_ms(15); sys_tick_delay_ms(15);
} }
} }
#endif
// wifi // wifi
//pyb_wlan_init(); //pyb_wlan_init();

View File

@ -27,6 +27,14 @@ machine_float_t machine_sqrt(machine_float_t x);
#define PYBOARD4 #define PYBOARD4
//#define STM32F4DISC //#define STM32F4DISC
#if defined(PYBOARD) || defined(PYBOARD4)
#define BOARD_HAS_MMA7660 (1)
#define BOARD_HAS_LIS3DSH (0)
#else
#define BOARD_HAS_MMA7660 (0)
#define BOARD_HAS_LIS3DSH (1)
#endif
#define STM32F40_41xxx #define STM32F40_41xxx
#define USE_STDPERIPH_DRIVER #define USE_STDPERIPH_DRIVER
#define HSE_VALUE (8000000) #define HSE_VALUE (8000000)