113 lines
3.3 KiB
C
113 lines
3.3 KiB
C
/*
|
|
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;
|
|
}
|