/sys/arm/stm32l031x6/rtc_test/u8x8cb.c
https://github.com/olikraus/u8g2 · C · 112 lines · 62 code · 13 blank · 37 comment · 5 complexity · 166c4ad91e75437abb6993af3728fe85 MD5 · raw file
- /*
- u8x8cb.c
-
- STM32L031
-
- PA9: Clock
- PA10: Data
- Both lines have a pullup resistor
-
- */
- #include "stm32l031xx.h"
- #include "delay.h"
- #include "u8x8.h"
- uint8_t u8x8_gpio_and_delay_stm32l0(u8x8_t *u8x8, uint8_t msg, uint8_t arg_int, void *arg_ptr)
- {
- switch(msg)
- {
- case U8X8_MSG_GPIO_AND_DELAY_INIT:
- /* only support for software I2C*/
-
- RCC->IOPENR |= RCC_IOPENR_IOPAEN; /* Enable clock for GPIO Port A */
- __NOP();
- __NOP();
-
- GPIOA->MODER &= ~GPIO_MODER_MODE10; /* clear mode for PA10 */
- //GPIOA->MODER |= GPIO_MODER_MODE10_0; /* Output mode for PA10 */
- GPIOA->OTYPER &= ~GPIO_OTYPER_OT_10; /* no open drain for PA10 */
- GPIOA->OSPEEDR &= ~GPIO_OSPEEDER_OSPEED10; /* low speed for PA10 */
- GPIOA->PUPDR &= ~GPIO_PUPDR_PUPD10; /* no pullup/pulldown for PA10 */
- //GPIOA->BSRR = GPIO_BSRR_BS_10; /* atomic set PA10 */
-
- GPIOA->MODER &= ~GPIO_MODER_MODE9; /* clear mode for PA9 */
- //GPIOA->MODER |= GPIO_MODER_MODE9_0; /* Output mode for PA9 */
- GPIOA->OTYPER &= ~GPIO_OTYPER_OT_9; /* no open drain for PA9 */
- GPIOA->OSPEEDR &= ~GPIO_OSPEEDER_OSPEED9; /* low speed for PA9 */
- GPIOA->PUPDR &= ~GPIO_PUPDR_PUPD9; /* no pullup/pulldown for PA9 */
- //GPIOA->BSRR = GPIO_BSRR_BS_9; /* atomic set PA9 */
-
- break;
- case U8X8_MSG_DELAY_NANO:
- /* not required for SW I2C */
- break;
-
- case U8X8_MSG_DELAY_10MICRO:
- /* not used at the moment */
- break;
-
- case U8X8_MSG_DELAY_100NANO:
- /* not used at the moment */
- break;
-
- case U8X8_MSG_DELAY_MILLI:
- delay_micro_seconds(arg_int*1000UL);
- break;
- case U8X8_MSG_DELAY_I2C:
- /* arg_int is 1 or 4: 100KHz (5us) or 400KHz (1.25us) */
- delay_micro_seconds(arg_int<=2?5:1);
- break;
-
- case U8X8_MSG_GPIO_I2C_CLOCK:
-
- if ( arg_int == 0 )
- {
- GPIOA->MODER &= ~GPIO_MODER_MODE9; /* clear mode for PA10 */
- GPIOA->MODER |= GPIO_MODER_MODE9_0; /* Output mode for PA10 */
- GPIOA->BSRR = GPIO_BSRR_BR_9; /* atomic clr PA9 */
- }
- else
- {
- //GPIOA->BSRR = GPIO_BSRR_BS_9; /* atomic set PA9 */
- GPIOA->MODER &= ~GPIO_MODER_MODE9; /* clear mode for PA9: input mode */
- }
- break;
- case U8X8_MSG_GPIO_I2C_DATA:
-
- if ( arg_int == 0 )
- {
- GPIOA->MODER &= ~GPIO_MODER_MODE10; /* clear mode for PA10 */
- GPIOA->MODER |= GPIO_MODER_MODE10_0; /* Output mode for PA10 */
- GPIOA->BSRR = GPIO_BSRR_BR_10; /* atomic clr PA10 */
- }
- else
- {
- //GPIOA->BSRR = GPIO_BSRR_BS_10; /* atomic set PA10 */
- // input mode
- GPIOA->MODER &= ~GPIO_MODER_MODE10; /* clear mode for PA10: input mode */
- }
- break;
- /*
- case U8X8_MSG_GPIO_MENU_SELECT:
- u8x8_SetGPIOResult(u8x8, Chip_GPIO_GetPinState(LPC_GPIO, KEY_SELECT_PORT, KEY_SELECT_PIN));
- break;
- case U8X8_MSG_GPIO_MENU_NEXT:
- u8x8_SetGPIOResult(u8x8, Chip_GPIO_GetPinState(LPC_GPIO, KEY_NEXT_PORT, KEY_NEXT_PIN));
- break;
- case U8X8_MSG_GPIO_MENU_PREV:
- u8x8_SetGPIOResult(u8x8, Chip_GPIO_GetPinState(LPC_GPIO, KEY_PREV_PORT, KEY_PREV_PIN));
- break;
-
- case U8X8_MSG_GPIO_MENU_HOME:
- u8x8_SetGPIOResult(u8x8, Chip_GPIO_GetPinState(LPC_GPIO, KEY_HOME_PORT, KEY_HOME_PIN));
- break;
- */
- default:
- u8x8_SetGPIOResult(u8x8, 1);
- break;
- }
- return 1;
- }