refactor: st7567 demo, change pins to port a

This commit is contained in:
IOsetting 2023-03-18 00:52:20 +08:00
parent 4c651bfc34
commit 504c1dde99
2 changed files with 43 additions and 59 deletions

View File

@ -2,28 +2,30 @@
* Demo: ST7567 LCD
*
* PY32 ST7567
* PB2 ------> CS
* PB3 ------> CLK/SCK
* PB5 ------> DIN/MOSI
* PA8 ------> Reset
* PA9 ------> DC/A0
* PA10 ------> Back Light
* PA0 ------> Reset
* PA1 ------> CLK/SCK
* PA4 ------> Backlight
* PA5 ------> DC/AO
* PA6 ------> CSN/CE
* PA7 ------> MOSI
*
* PA2 ------> UART TX
*/
#include <string.h>
#include "main.h"
#include "py32f0xx_bsp_clock.h"
#include "py32f0xx_bsp_printf.h"
#include "st7567.h"
static void APP_SPIConfig(void);
static void APP_SystemClockConfig(void);
int main(void)
{
int y1, y2;
uint8_t d1, d2;
APP_SystemClockConfig();
BSP_RCC_HSI_24MConfig();
BSP_USART_Config(115200);
printf("SPI Demo: ST7567 LCD\r\nClock: %ld\r\n", SystemCoreClock);
@ -227,29 +229,28 @@ static void APP_SPIConfig(void)
LL_APB1_GRP2_EnableClock(LL_APB1_GRP2_PERIPH_SPI1);
LL_IOP_GRP1_EnableClock(LL_IOP_GRP1_PERIPH_GPIOA | LL_IOP_GRP1_PERIPH_GPIOB);
// PB2 CS
LL_GPIO_SetPinMode(GPIOB, LL_GPIO_PIN_2, LL_GPIO_MODE_OUTPUT);
LL_GPIO_SetPinMode(GPIOA, LL_GPIO_PIN_8, LL_GPIO_MODE_OUTPUT);
LL_GPIO_SetPinMode(GPIOA, LL_GPIO_PIN_9, LL_GPIO_MODE_OUTPUT);
LL_GPIO_SetPinMode(GPIOA, LL_GPIO_PIN_10, LL_GPIO_MODE_OUTPUT);
// PB3 SCK
GPIO_InitStruct.Pin = LL_GPIO_PIN_3;
// PA6 CS
LL_GPIO_SetPinMode(GPIOA, LL_GPIO_PIN_6, LL_GPIO_MODE_OUTPUT);
// PA5 DC/AO
LL_GPIO_SetPinMode(GPIOA, LL_GPIO_PIN_5, LL_GPIO_MODE_OUTPUT);
// PA0 RESET
LL_GPIO_SetPinMode(GPIOA, LL_GPIO_PIN_0, LL_GPIO_MODE_OUTPUT);
// PA4 ------> Backlight
LL_GPIO_SetPinMode(GPIOA, LL_GPIO_PIN_4, LL_GPIO_MODE_OUTPUT);
// PA1 SCK
GPIO_InitStruct.Pin = LL_GPIO_PIN_1;
GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE;
GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_HIGH;
GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
GPIO_InitStruct.Pull = LL_GPIO_PULL_UP;
GPIO_InitStruct.Alternate = LL_GPIO_AF_0;
LL_GPIO_Init(GPIOB, &GPIO_InitStruct);
// PB4 MISO (not connected)
GPIO_InitStruct.Pin = LL_GPIO_PIN_4;
LL_GPIO_Init(GPIOA, &GPIO_InitStruct);
// PA7 MOSI
GPIO_InitStruct.Pin = LL_GPIO_PIN_7;
GPIO_InitStruct.Pull = LL_GPIO_PULL_NO;
GPIO_InitStruct.Alternate = LL_GPIO_AF_0;
LL_GPIO_Init(GPIOB, &GPIO_InitStruct);
// PB5 MOSI
GPIO_InitStruct.Pin = LL_GPIO_PIN_5;
GPIO_InitStruct.Pull = LL_GPIO_PULL_NO;
GPIO_InitStruct.Alternate = LL_GPIO_AF_0;
LL_GPIO_Init(GPIOB, &GPIO_InitStruct);
LL_GPIO_Init(GPIOA, &GPIO_InitStruct);
SPI_InitStruct.TransferDirection = LL_SPI_FULL_DUPLEX;
SPI_InitStruct.Mode = LL_SPI_MODE_MASTER;
@ -263,23 +264,6 @@ static void APP_SPIConfig(void)
LL_SPI_Enable(SPI1);
}
static void APP_SystemClockConfig(void)
{
LL_UTILS_ClkInitTypeDef UTILS_ClkInitStruct;
LL_RCC_HSI_Enable();
/* Change this value to adjust clock frequency, larger is faster */
LL_RCC_HSI_SetCalibFreq(LL_RCC_HSICALIBRATION_24MHz + 15);
while (LL_RCC_HSI_IsReady() != 1);
UTILS_ClkInitStruct.AHBCLKDivider = LL_RCC_SYSCLK_DIV_1;
UTILS_ClkInitStruct.APB1CLKDivider = LL_RCC_APB1_DIV_1;
LL_PLL_ConfigSystemClock_HSI(&UTILS_ClkInitStruct);
/* Re-init frequency of SysTick source, reload = freq/ticks = 48000000/1000 = 48000 */
LL_InitTick(48000000, 1000U);
}
void APP_ErrorHandler(void)
{
while (1);

View File

@ -19,24 +19,24 @@
#define ST7567_BUF_SIZE 1024
#define ST7567_HARDWARE_SPI 1
// CS: PB2
#define ST7567_CS_LOW LL_GPIO_ResetOutputPin(GPIOB, LL_GPIO_PIN_2)
#define ST7567_CS_HIGH LL_GPIO_SetOutputPin(GPIOB, LL_GPIO_PIN_2)
// SCK: PB3
#define ST7567_SCK_PORT GPIOB
#define ST7567_SCK_PIN LL_GPIO_PIN_3
// MOSI: PB5
#define ST7567_MOSI_PORT GPIOB
#define ST7567_MOSI_PIN LL_GPIO_PIN_5
// Reset: PA8
#define ST7567_RESET_LOW LL_GPIO_ResetOutputPin(GPIOA, LL_GPIO_PIN_8)
#define ST7567_RESET_HIGH LL_GPIO_SetOutputPin(GPIOA, LL_GPIO_PIN_8)
// DC: PA9
#define ST7567_DC_LOW LL_GPIO_ResetOutputPin(GPIOA, LL_GPIO_PIN_9)
#define ST7567_DC_HIGH LL_GPIO_SetOutputPin(GPIOA, LL_GPIO_PIN_9)
// Black Light: PA10
#define ST7567_BL_LOW LL_GPIO_ResetOutputPin(GPIOA, LL_GPIO_PIN_10)
#define ST7567_BL_HIGH LL_GPIO_SetOutputPin(GPIOA, LL_GPIO_PIN_10)
// CS: PA6
#define ST7567_CS_LOW LL_GPIO_ResetOutputPin(GPIOA, LL_GPIO_PIN_6)
#define ST7567_CS_HIGH LL_GPIO_SetOutputPin(GPIOA, LL_GPIO_PIN_6)
// SCK: PA1
#define ST7567_SCK_PORT GPIOA
#define ST7567_SCK_PIN LL_GPIO_PIN_1
// MOSI: PA7
#define ST7567_MOSI_PORT GPIOA
#define ST7567_MOSI_PIN LL_GPIO_PIN_7
// Reset: PA0
#define ST7567_RESET_LOW LL_GPIO_ResetOutputPin(GPIOA, LL_GPIO_PIN_0)
#define ST7567_RESET_HIGH LL_GPIO_SetOutputPin(GPIOA, LL_GPIO_PIN_0)
// DC: PA5
#define ST7567_DC_LOW LL_GPIO_ResetOutputPin(GPIOA, LL_GPIO_PIN_5)
#define ST7567_DC_HIGH LL_GPIO_SetOutputPin(GPIOA, LL_GPIO_PIN_5)
// Black Light: PA4
#define ST7567_BL_LOW LL_GPIO_ResetOutputPin(GPIOA, LL_GPIO_PIN_4)
#define ST7567_BL_HIGH LL_GPIO_SetOutputPin(GPIOA, LL_GPIO_PIN_4)
// X width
#define ST7567_WIDTH 128