Compare commits
3 commits
84d00d8178
...
2535a7c089
| Author | SHA1 | Date | |
|---|---|---|---|
| 2535a7c089 | |||
| 118d4f97fa | |||
| 91beef5d0b |
22 changed files with 576 additions and 63 deletions
145
myapps/OLD/practice/00-uart-tx/Makefile
Normal file
145
myapps/OLD/practice/00-uart-tx/Makefile
Normal file
|
|
@ -0,0 +1,145 @@
|
||||||
|
######################################
|
||||||
|
# target
|
||||||
|
######################################
|
||||||
|
TARGET = stm32g0_blinky
|
||||||
|
PART = STM32G030xx
|
||||||
|
PYOCD_TARGET = stm32g030f6px
|
||||||
|
|
||||||
|
|
||||||
|
######################################
|
||||||
|
# building variables
|
||||||
|
######################################
|
||||||
|
# debug build?
|
||||||
|
DEBUG = 1
|
||||||
|
# optimization for size
|
||||||
|
OPT = -Os
|
||||||
|
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# paths
|
||||||
|
#######################################
|
||||||
|
# Build path
|
||||||
|
BUILD_DIR = build
|
||||||
|
VND_DIR = ../../../vendor
|
||||||
|
|
||||||
|
######################################
|
||||||
|
# source
|
||||||
|
######################################
|
||||||
|
# C sources
|
||||||
|
include hal.mk
|
||||||
|
C_SOURCES += \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/CMSIS/Device/ST/STM32G0xx/Source/Templates/system_stm32g0xx.c \
|
||||||
|
src/main.c
|
||||||
|
|
||||||
|
|
||||||
|
# ASM sources
|
||||||
|
ASM_SOURCES = \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/CMSIS/Device/ST/STM32G0xx/Source/Templates/gcc/startup_stm32g030xx.s
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# binaries
|
||||||
|
#######################################
|
||||||
|
PREFIX = arm-none-eabi-
|
||||||
|
|
||||||
|
CC = $(PREFIX)gcc
|
||||||
|
CP = $(PREFIX)objcopy
|
||||||
|
#SZ = $(PREFIX)size
|
||||||
|
|
||||||
|
BIN = $(CP) -O binary -S
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# CFLAGS
|
||||||
|
#######################################
|
||||||
|
# cpu
|
||||||
|
CPU = \
|
||||||
|
-mcpu=cortex-m0plus \
|
||||||
|
-mthumb
|
||||||
|
|
||||||
|
DEFINES = -D$(PART)
|
||||||
|
|
||||||
|
# fpu
|
||||||
|
FPU =
|
||||||
|
|
||||||
|
# float-abi
|
||||||
|
FLOAT-ABI =
|
||||||
|
|
||||||
|
# mcu
|
||||||
|
MCU = $(CPU) $(FPU) $(FLOAT-ABI)
|
||||||
|
|
||||||
|
# C includes
|
||||||
|
C_INCLUDES += \
|
||||||
|
-Isrc/inc \
|
||||||
|
-I$(VND_DIR)/STM32CubeG0/Drivers/CMSIS/Core/Include \
|
||||||
|
-I$(VND_DIR)/STM32CubeG0/Drivers/CMSIS/Device/ST/STM32G0xx/Include
|
||||||
|
|
||||||
|
# compile gcc flags
|
||||||
|
ADDN_CFLAGS = \
|
||||||
|
-Wall \
|
||||||
|
-fno-common \
|
||||||
|
-fdata-sections \
|
||||||
|
-ffunction-sections
|
||||||
|
|
||||||
|
CFLAGS = $(MCU) $(ADDN_CFLAGS) $(C_INCLUDES) $(OPT) $(DEFINES)
|
||||||
|
|
||||||
|
ifeq ($(DEBUG), 1)
|
||||||
|
CFLAGS += -ggdb3
|
||||||
|
endif
|
||||||
|
|
||||||
|
|
||||||
|
# Generate dependency information
|
||||||
|
#CFLAGS += -MMD -MP -MF"$(@:%.o=%.d)"
|
||||||
|
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# LDFLAGS
|
||||||
|
#######################################
|
||||||
|
# link script
|
||||||
|
LDSCRIPT = $(VND_DIR)/Ld/STM32G030F6MX_FLASH.ld
|
||||||
|
|
||||||
|
LIBDIR =
|
||||||
|
LDFLAGS = \
|
||||||
|
$(MCU) \
|
||||||
|
-T $(LDSCRIPT) \
|
||||||
|
--specs=nano.specs \
|
||||||
|
-Wl,--gc-sections \
|
||||||
|
-Wl,--print-memory-usage \
|
||||||
|
-Wl,--no-warn-rwx-segments
|
||||||
|
|
||||||
|
# default action: build all
|
||||||
|
all: $(BUILD_DIR)/$(TARGET).elf $(BUILD_DIR)/$(TARGET).bin
|
||||||
|
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# build the application
|
||||||
|
#######################################
|
||||||
|
# list of objects
|
||||||
|
OBJECTS = $(addprefix $(BUILD_DIR)/,$(notdir $(C_SOURCES:.c=.o)))
|
||||||
|
vpath %.c $(sort $(dir $(C_SOURCES)))
|
||||||
|
|
||||||
|
$(BUILD_DIR)/%.o: %.c Makefile | $(BUILD_DIR)
|
||||||
|
$(CC) -c $(CFLAGS) -Wa,-a,-ad,-alms=$(BUILD_DIR)/$(notdir $(<:.c=.lst)) $< -o $@
|
||||||
|
|
||||||
|
#$(LUAOBJECTS) $(OBJECTS)
|
||||||
|
$(BUILD_DIR)/$(TARGET).elf: $(OBJECTS) Makefile
|
||||||
|
$(CC) $(OBJECTS) $(LDFLAGS) $(ASM_SOURCES) -o $@
|
||||||
|
|
||||||
|
$(BUILD_DIR)/%.bin: $(BUILD_DIR)/%.elf | $(BUILD_DIR)
|
||||||
|
$(BIN) $< $@
|
||||||
|
|
||||||
|
$(BUILD_DIR):
|
||||||
|
mkdir $@
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# Program
|
||||||
|
#######################################
|
||||||
|
|
||||||
|
flash: $(BUILD_DIR)/$(TARGET).bin
|
||||||
|
pyocd load --target $(PYOCD_TARGET) $(BUILD_DIR)/$(TARGET).bin
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# clean up
|
||||||
|
#######################################
|
||||||
|
clean:
|
||||||
|
-rm -fR $(BUILD_DIR)
|
||||||
|
|
||||||
|
# *** EOF ***
|
||||||
20
myapps/OLD/practice/00-uart-tx/hal.mk
Normal file
20
myapps/OLD/practice/00-uart-tx/hal.mk
Normal file
|
|
@ -0,0 +1,20 @@
|
||||||
|
C_INCLUDES += \
|
||||||
|
-I$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Inc
|
||||||
|
|
||||||
|
|
||||||
|
C_SOURCES += \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal.c \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_cortex.c \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_pwr.c \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_pwr_ex.c \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_rcc.c \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_rcc_ex.c \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_exti.c \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_dma.c \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_dma_ex.c \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_flash.c \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_flash_ex.c \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_gpio.c \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_uart.c \
|
||||||
|
src/stm32g0xx_hal_msp.c
|
||||||
|
|
||||||
60
myapps/OLD/practice/00-uart-tx/src/main.c
Normal file
60
myapps/OLD/practice/00-uart-tx/src/main.c
Normal file
|
|
@ -0,0 +1,60 @@
|
||||||
|
// Tx/Rx: PA09[PA11]/PA10[PA12]
|
||||||
|
|
||||||
|
//#include <string.h>
|
||||||
|
//#include <stdio.h>
|
||||||
|
#include "stm32g0xx_hal_msp.h"
|
||||||
|
|
||||||
|
UART_HandleTypeDef huart1;
|
||||||
|
|
||||||
|
char buffer[] = "Hello World\r\n";
|
||||||
|
#define TXBUFFERSIZE 14 //strlen(buffer)
|
||||||
|
#define TIMEOUT 0xFFFF
|
||||||
|
/*
|
||||||
|
int __io_putchar(int ch)
|
||||||
|
{
|
||||||
|
HAL_UART_Transmit(&huart1, (uint8_t *)&ch, 1, TIMEOUT);
|
||||||
|
return ch;
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
/*
|
||||||
|
setvbuf(stout, NULL, _IOLBF, 0);
|
||||||
|
|
||||||
|
int _write (int file, const void * ptr, size_t len)
|
||||||
|
{
|
||||||
|
HAL_UART_Transmit(&huart1, ptr, len, TIMEOUT);
|
||||||
|
return len;
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
static void uart_init(void)
|
||||||
|
{
|
||||||
|
|
||||||
|
huart1.Instance = USART1; // Defined in CMSIS header as peripheral address
|
||||||
|
huart1.Init.BaudRate = 115200;
|
||||||
|
huart1.Init.WordLength = UART_WORDLENGTH_8B;
|
||||||
|
huart1.Init.StopBits = UART_STOPBITS_1;
|
||||||
|
huart1.Init.Parity = UART_PARITY_NONE;
|
||||||
|
huart1.Init.Mode = UART_MODE_TX_RX;
|
||||||
|
huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE;
|
||||||
|
huart1.Init.OverSampling = UART_OVERSAMPLING_16;
|
||||||
|
huart1.Init.OneBitSampling = UART_ONE_BIT_SAMPLE_DISABLE;
|
||||||
|
huart1.Init.ClockPrescaler = UART_PRESCALER_DIV1;
|
||||||
|
huart1.AdvancedInit.AdvFeatureInit = UART_ADVFEATURE_NO_INIT;
|
||||||
|
while (HAL_UART_Init(&huart1) != HAL_OK);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
HAL_Init();
|
||||||
|
SystemClock_Config();
|
||||||
|
uart_init();
|
||||||
|
|
||||||
|
while(1)
|
||||||
|
{
|
||||||
|
HAL_UART_Transmit(&huart1, (uint8_t *)buffer, TXBUFFERSIZE, TIMEOUT);
|
||||||
|
//printf("Hello World\r\n");
|
||||||
|
HAL_Delay(100);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
154
myapps/ll-hal-test/Makefile
Normal file
154
myapps/ll-hal-test/Makefile
Normal file
|
|
@ -0,0 +1,154 @@
|
||||||
|
######################################
|
||||||
|
# target
|
||||||
|
######################################
|
||||||
|
TARGET = stm32g0_blinky
|
||||||
|
PART = STM32G030xx
|
||||||
|
PYOCD_TARGET = stm32g030f6px
|
||||||
|
|
||||||
|
|
||||||
|
######################################
|
||||||
|
# building variables
|
||||||
|
######################################
|
||||||
|
# debug build?
|
||||||
|
DEBUG = 1
|
||||||
|
# optimization for size
|
||||||
|
OPT = -Os
|
||||||
|
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# paths
|
||||||
|
#######################################
|
||||||
|
# Build path
|
||||||
|
BUILD_DIR = build
|
||||||
|
VND_DIR = ../../vendor
|
||||||
|
|
||||||
|
######################################
|
||||||
|
# source
|
||||||
|
######################################
|
||||||
|
# C sources
|
||||||
|
include hal.mk
|
||||||
|
C_SOURCES += \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/CMSIS/Device/ST/STM32G0xx/Source/Templates/system_stm32g0xx.c \
|
||||||
|
src/main.c
|
||||||
|
|
||||||
|
|
||||||
|
# ASM sources
|
||||||
|
ASM_SOURCES = \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/CMSIS/Device/ST/STM32G0xx/Source/Templates/gcc/startup_stm32g030xx.s
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# binaries
|
||||||
|
#######################################
|
||||||
|
PREFIX = arm-none-eabi-
|
||||||
|
|
||||||
|
CC = $(PREFIX)gcc
|
||||||
|
CP = $(PREFIX)objcopy
|
||||||
|
#SZ = $(PREFIX)size
|
||||||
|
|
||||||
|
BIN = $(CP) -O binary -S
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# CFLAGS
|
||||||
|
#######################################
|
||||||
|
|
||||||
|
ifeq ($(DEBUG), 1)
|
||||||
|
DEBUG_FLAGS = -gdwarf-3
|
||||||
|
endif
|
||||||
|
|
||||||
|
# cpu
|
||||||
|
CPU = \
|
||||||
|
-mcpu=cortex-m0plus
|
||||||
|
|
||||||
|
DEFINES = -D$(PART)
|
||||||
|
|
||||||
|
# fpu
|
||||||
|
FPU =
|
||||||
|
|
||||||
|
# float-abi
|
||||||
|
FLOAT-ABI =
|
||||||
|
|
||||||
|
# mcu
|
||||||
|
MCU = $(CPU) $(FPU) $(FLOAT-ABI)
|
||||||
|
|
||||||
|
# C includes
|
||||||
|
C_INCLUDES += \
|
||||||
|
-Isrc/inc \
|
||||||
|
-I$(VND_DIR)/STM32CubeG0/Drivers/CMSIS/Core/Include \
|
||||||
|
-I$(VND_DIR)/STM32CubeG0/Drivers/CMSIS/Device/ST/STM32G0xx/Include
|
||||||
|
|
||||||
|
# compile gcc flags
|
||||||
|
ADDN_CFLAGS = \
|
||||||
|
-Wall \
|
||||||
|
-fdata-sections \
|
||||||
|
-ffunction-sections
|
||||||
|
|
||||||
|
CFLAGS = $(MCU) $(ADDN_CFLAGS) $(C_INCLUDES) $(DEBUG_FLAGS) $(OPT) $(DEFINES)
|
||||||
|
|
||||||
|
|
||||||
|
# Generate dependency information
|
||||||
|
#CFLAGS += -MMD -MP -MF"$(@:%.o=%.d)"
|
||||||
|
|
||||||
|
|
||||||
|
ASFLAGS = $(MCU) $(DEBUG_FLAGS) $(OPT) -Wa,--warn
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# LDFLAGS
|
||||||
|
#######################################
|
||||||
|
# link script
|
||||||
|
LDSCRIPT = $(VND_DIR)/Ld/STM32G030F6MX_FLASH.ld
|
||||||
|
|
||||||
|
LIBDIR =
|
||||||
|
LDFLAGS = \
|
||||||
|
$(MCU) \
|
||||||
|
-T $(LDSCRIPT) \
|
||||||
|
--specs=nano.specs \
|
||||||
|
-specs=nosys.specs -lc -lm \
|
||||||
|
-Wl,--gc-sections \
|
||||||
|
-Wl,--print-memory-usage \
|
||||||
|
-Wl,--no-warn-rwx-segments
|
||||||
|
|
||||||
|
# default action: build all
|
||||||
|
all: $(BUILD_DIR)/$(TARGET).elf $(BUILD_DIR)/$(TARGET).bin
|
||||||
|
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# build the application
|
||||||
|
#######################################
|
||||||
|
# list of objects
|
||||||
|
OBJECTS = $(addprefix $(BUILD_DIR)/,$(notdir $(C_SOURCES:.c=.o)))
|
||||||
|
vpath %.c $(sort $(dir $(C_SOURCES)))
|
||||||
|
|
||||||
|
# list of ASM program objects
|
||||||
|
OBJECTS += $(addprefix $(BUILD_DIR)/,$(notdir $(ASM_SOURCES:.s=.o)))
|
||||||
|
vpath %.s $(sort $(dir $(ASM_SOURCES)))
|
||||||
|
|
||||||
|
$(BUILD_DIR)/%.o: %.c Makefile | $(BUILD_DIR)
|
||||||
|
$(CC) -c $(CFLAGS) -Wa,-a,-ad,-alms=$(BUILD_DIR)/$(notdir $(<:.c=.lst)) $< -o $@
|
||||||
|
|
||||||
|
$(BUILD_DIR)/%.o: %.s Makefile | $(BUILD_DIR)
|
||||||
|
$(CC) -c $(ASFLAGS) $< -o $@
|
||||||
|
|
||||||
|
#$(LUAOBJECTS) $(OBJECTS)
|
||||||
|
$(BUILD_DIR)/$(TARGET).elf: $(OBJECTS) Makefile
|
||||||
|
$(CC) $(OBJECTS) $(LDFLAGS) -o $@
|
||||||
|
|
||||||
|
$(BUILD_DIR)/%.bin: $(BUILD_DIR)/%.elf | $(BUILD_DIR)
|
||||||
|
$(BIN) $< $@
|
||||||
|
|
||||||
|
$(BUILD_DIR):
|
||||||
|
mkdir $@
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# Program
|
||||||
|
#######################################
|
||||||
|
|
||||||
|
flash: $(BUILD_DIR)/$(TARGET).bin
|
||||||
|
pyocd load --target $(PYOCD_TARGET) $(BUILD_DIR)/$(TARGET).bin
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# clean up
|
||||||
|
#######################################
|
||||||
|
clean:
|
||||||
|
-rm -fR $(BUILD_DIR)
|
||||||
|
|
||||||
|
# *** EOF ***
|
||||||
13
myapps/ll-hal-test/hal.mk
Normal file
13
myapps/ll-hal-test/hal.mk
Normal file
|
|
@ -0,0 +1,13 @@
|
||||||
|
C_INCLUDES += \
|
||||||
|
-I$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Inc
|
||||||
|
|
||||||
|
# "stm32g0xx_ll_bus.h" "stm32g0xx_ll_system.h" "stm32g0xx_ll_cortex.h" : missing
|
||||||
|
C_SOURCES += \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_ll_rcc.c \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_ll_crs.c \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_ll_exti.c \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_ll_utils.c \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_ll_pwr.c \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_ll_dma.c \
|
||||||
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_ll_gpio.c
|
||||||
|
|
||||||
66
myapps/ll-hal-test/src/main.c
Normal file
66
myapps/ll-hal-test/src/main.c
Normal file
|
|
@ -0,0 +1,66 @@
|
||||||
|
|
||||||
|
|
||||||
|
#define LED_Pin LL_GPIO_PIN_4
|
||||||
|
#define LED_GPIO_Port GPIOA
|
||||||
|
|
||||||
|
#include "stm32g0xx_ll_rcc.h"
|
||||||
|
#include "stm32g0xx_ll_bus.h"
|
||||||
|
#include "stm32g0xx_ll_crs.h"
|
||||||
|
#include "stm32g0xx_ll_system.h"
|
||||||
|
#include "stm32g0xx_ll_exti.h"
|
||||||
|
#include "stm32g0xx_ll_cortex.h"
|
||||||
|
#include "stm32g0xx_ll_utils.h"
|
||||||
|
#include "stm32g0xx_ll_pwr.h"
|
||||||
|
#include "stm32g0xx_ll_dma.h"
|
||||||
|
#include "stm32g0xx_ll_gpio.h"
|
||||||
|
|
||||||
|
void SystemClock_Config(void)
|
||||||
|
{
|
||||||
|
LL_FLASH_SetLatency(LL_FLASH_LATENCY_2);
|
||||||
|
while(LL_FLASH_GetLatency() != LL_FLASH_LATENCY_2);
|
||||||
|
|
||||||
|
/* HSI configuration and activation */
|
||||||
|
LL_RCC_HSI_Enable();
|
||||||
|
while(LL_RCC_HSI_IsReady() != 1);
|
||||||
|
|
||||||
|
/* Main PLL configuration and activation */
|
||||||
|
LL_RCC_PLL_ConfigDomain_SYS(LL_RCC_PLLSOURCE_HSI, LL_RCC_PLLM_DIV_1, 8, LL_RCC_PLLR_DIV_2);
|
||||||
|
LL_RCC_PLL_Enable();
|
||||||
|
LL_RCC_PLL_EnableDomain_SYS();
|
||||||
|
while(LL_RCC_PLL_IsReady() != 1);
|
||||||
|
|
||||||
|
/* Set AHB prescaler*/
|
||||||
|
LL_RCC_SetAHBPrescaler(LL_RCC_SYSCLK_DIV_1);
|
||||||
|
|
||||||
|
/* Sysclk activation on the main PLL */
|
||||||
|
LL_RCC_SetSysClkSource(LL_RCC_SYS_CLKSOURCE_PLL);
|
||||||
|
while(LL_RCC_GetSysClkSource() != LL_RCC_SYS_CLKSOURCE_STATUS_PLL);
|
||||||
|
|
||||||
|
/* Set APB1 prescaler*/
|
||||||
|
LL_RCC_SetAPB1Prescaler(LL_RCC_APB1_DIV_1);
|
||||||
|
LL_Init1msTick(64000000);
|
||||||
|
/* Update CMSIS variable (which can be updated also through SystemCoreClockUpdate function) */
|
||||||
|
LL_SetSystemCoreClock(64000000);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
/* Reset of all peripherals, Initializes the Flash interface and the Systick. */
|
||||||
|
LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_SYSCFG);
|
||||||
|
LL_APB1_GRP1_EnableClock(LL_APB1_GRP1_PERIPH_PWR);
|
||||||
|
/** Disable the internal Pull-Up in Dead Battery pins of UCPD peripheral */
|
||||||
|
//LL_SYSCFG_DisableDBATT(LL_SYSCFG_UCPD1_STROBE | LL_SYSCFG_UCPD2_STROBE);
|
||||||
|
|
||||||
|
SystemClock_Config();
|
||||||
|
|
||||||
|
LL_IOP_GRP1_EnableClock(LL_IOP_GRP1_PERIPH_GPIOA);
|
||||||
|
LL_GPIO_SetPinMode(LED_GPIO_Port, LL_GPIO_PIN_4, LL_GPIO_MODE_OUTPUT);
|
||||||
|
|
||||||
|
while(1)
|
||||||
|
{
|
||||||
|
LL_GPIO_TogglePin(LED_GPIO_Port, LED_Pin);
|
||||||
|
LL_mDelay(250);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
@ -50,10 +50,14 @@ BIN = $(CP) -O binary -S
|
||||||
#######################################
|
#######################################
|
||||||
# CFLAGS
|
# CFLAGS
|
||||||
#######################################
|
#######################################
|
||||||
|
|
||||||
|
ifeq ($(DEBUG), 1)
|
||||||
|
DEBUG_FLAGS = -gdwarf-3
|
||||||
|
endif
|
||||||
|
|
||||||
# cpu
|
# cpu
|
||||||
CPU = \
|
CPU = \
|
||||||
-mcpu=cortex-m0plus \
|
-mcpu=cortex-m0plus
|
||||||
-mthumb
|
|
||||||
|
|
||||||
DEFINES = -D$(PART)
|
DEFINES = -D$(PART)
|
||||||
|
|
||||||
|
|
@ -75,21 +79,18 @@ C_INCLUDES += \
|
||||||
# compile gcc flags
|
# compile gcc flags
|
||||||
ADDN_CFLAGS = \
|
ADDN_CFLAGS = \
|
||||||
-Wall \
|
-Wall \
|
||||||
-fno-common \
|
|
||||||
-fdata-sections \
|
-fdata-sections \
|
||||||
-ffunction-sections
|
-ffunction-sections
|
||||||
|
|
||||||
CFLAGS = $(MCU) $(ADDN_CFLAGS) $(C_INCLUDES) $(OPT) $(DEFINES)
|
CFLAGS = $(MCU) $(ADDN_CFLAGS) $(C_INCLUDES) $(DEBUG_FLAGS) $(OPT) $(DEFINES)
|
||||||
|
|
||||||
ifeq ($(DEBUG), 1)
|
|
||||||
CFLAGS += -ggdb3
|
|
||||||
endif
|
|
||||||
|
|
||||||
|
|
||||||
# Generate dependency information
|
# Generate dependency information
|
||||||
#CFLAGS += -MMD -MP -MF"$(@:%.o=%.d)"
|
#CFLAGS += -MMD -MP -MF"$(@:%.o=%.d)"
|
||||||
|
|
||||||
|
|
||||||
|
ASFLAGS = $(MCU) $(DEBUG_FLAGS) $(OPT) -Wa,--warn
|
||||||
|
|
||||||
#######################################
|
#######################################
|
||||||
# LDFLAGS
|
# LDFLAGS
|
||||||
#######################################
|
#######################################
|
||||||
|
|
@ -101,6 +102,7 @@ LDFLAGS = \
|
||||||
$(MCU) \
|
$(MCU) \
|
||||||
-T $(LDSCRIPT) \
|
-T $(LDSCRIPT) \
|
||||||
--specs=nano.specs \
|
--specs=nano.specs \
|
||||||
|
-specs=nosys.specs -lc -lm \
|
||||||
-Wl,--gc-sections \
|
-Wl,--gc-sections \
|
||||||
-Wl,--print-memory-usage \
|
-Wl,--print-memory-usage \
|
||||||
-Wl,--no-warn-rwx-segments
|
-Wl,--no-warn-rwx-segments
|
||||||
|
|
@ -116,12 +118,19 @@ all: $(BUILD_DIR)/$(TARGET).elf $(BUILD_DIR)/$(TARGET).bin
|
||||||
OBJECTS = $(addprefix $(BUILD_DIR)/,$(notdir $(C_SOURCES:.c=.o)))
|
OBJECTS = $(addprefix $(BUILD_DIR)/,$(notdir $(C_SOURCES:.c=.o)))
|
||||||
vpath %.c $(sort $(dir $(C_SOURCES)))
|
vpath %.c $(sort $(dir $(C_SOURCES)))
|
||||||
|
|
||||||
|
# list of ASM program objects
|
||||||
|
OBJECTS += $(addprefix $(BUILD_DIR)/,$(notdir $(ASM_SOURCES:.s=.o)))
|
||||||
|
vpath %.s $(sort $(dir $(ASM_SOURCES)))
|
||||||
|
|
||||||
$(BUILD_DIR)/%.o: %.c Makefile | $(BUILD_DIR)
|
$(BUILD_DIR)/%.o: %.c Makefile | $(BUILD_DIR)
|
||||||
$(CC) -c $(CFLAGS) -Wa,-a,-ad,-alms=$(BUILD_DIR)/$(notdir $(<:.c=.lst)) $< -o $@
|
$(CC) -c $(CFLAGS) -Wa,-a,-ad,-alms=$(BUILD_DIR)/$(notdir $(<:.c=.lst)) $< -o $@
|
||||||
|
|
||||||
|
$(BUILD_DIR)/%.o: %.s Makefile | $(BUILD_DIR)
|
||||||
|
$(CC) -c $(ASFLAGS) $< -o $@
|
||||||
|
|
||||||
#$(LUAOBJECTS) $(OBJECTS)
|
#$(LUAOBJECTS) $(OBJECTS)
|
||||||
$(BUILD_DIR)/$(TARGET).elf: $(OBJECTS) Makefile
|
$(BUILD_DIR)/$(TARGET).elf: $(OBJECTS) Makefile
|
||||||
$(CC) $(OBJECTS) $(LDFLAGS) $(ASM_SOURCES) -o $@
|
$(CC) $(OBJECTS) $(LDFLAGS) -o $@
|
||||||
|
|
||||||
$(BUILD_DIR)/%.bin: $(BUILD_DIR)/%.elf | $(BUILD_DIR)
|
$(BUILD_DIR)/%.bin: $(BUILD_DIR)/%.elf | $(BUILD_DIR)
|
||||||
$(BIN) $< $@
|
$(BIN) $< $@
|
||||||
|
|
|
||||||
|
|
@ -1,20 +1,14 @@
|
||||||
C_INCLUDES += \
|
C_INCLUDES += \
|
||||||
-I$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Inc
|
-I$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Inc
|
||||||
|
|
||||||
|
# "stm32g0xx_ll_bus.h" "stm32g0xx_ll_system.h" "stm32g0xx_ll_cortex.h" : missing
|
||||||
C_SOURCES += \
|
C_SOURCES += \
|
||||||
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal.c \
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_ll_rcc.c \
|
||||||
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_cortex.c \
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_ll_crs.c \
|
||||||
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_pwr.c \
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_ll_exti.c \
|
||||||
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_pwr_ex.c \
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_ll_utils.c \
|
||||||
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_rcc.c \
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_ll_pwr.c \
|
||||||
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_rcc_ex.c \
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_ll_dma.c \
|
||||||
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_exti.c \
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_ll_gpio.c \
|
||||||
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_dma.c \
|
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_ll_usart.c
|
||||||
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_dma_ex.c \
|
|
||||||
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_flash.c \
|
|
||||||
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_flash_ex.c \
|
|
||||||
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_gpio.c \
|
|
||||||
$(VND_DIR)/STM32CubeG0/Drivers/STM32G0xx_HAL_Driver/Src/stm32g0xx_hal_uart.c \
|
|
||||||
src/stm32g0xx_hal_msp.c
|
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,60 +1,112 @@
|
||||||
// Tx/Rx: PA09[PA11]/PA10[PA12]
|
|
||||||
|
|
||||||
//#include <string.h>
|
|
||||||
//#include <stdio.h>
|
|
||||||
#include "stm32g0xx_hal_msp.h"
|
|
||||||
|
|
||||||
UART_HandleTypeDef huart1;
|
#include "stm32g0xx_ll_rcc.h"
|
||||||
|
#include "stm32g0xx_ll_bus.h"
|
||||||
|
#include "stm32g0xx_ll_crs.h"
|
||||||
|
#include "stm32g0xx_ll_system.h"
|
||||||
|
#include "stm32g0xx_ll_exti.h"
|
||||||
|
#include "stm32g0xx_ll_cortex.h"
|
||||||
|
#include "stm32g0xx_ll_utils.h"
|
||||||
|
#include "stm32g0xx_ll_pwr.h"
|
||||||
|
#include "stm32g0xx_ll_dma.h"
|
||||||
|
#include "stm32g0xx_ll_gpio.h"
|
||||||
|
#include "stm32g0xx_ll_usart.h"
|
||||||
|
|
||||||
char buffer[] = "Hello World\r\n";
|
void SystemClock_Config(void)
|
||||||
#define TXBUFFERSIZE 14 //strlen(buffer)
|
|
||||||
#define TIMEOUT 0xFFFF
|
|
||||||
/*
|
|
||||||
int __io_putchar(int ch)
|
|
||||||
{
|
{
|
||||||
HAL_UART_Transmit(&huart1, (uint8_t *)&ch, 1, TIMEOUT);
|
LL_FLASH_SetLatency(LL_FLASH_LATENCY_2);
|
||||||
return ch;
|
while(LL_FLASH_GetLatency() != LL_FLASH_LATENCY_2);
|
||||||
|
|
||||||
|
/* HSI configuration and activation */
|
||||||
|
LL_RCC_HSI_Enable();
|
||||||
|
while(LL_RCC_HSI_IsReady() != 1);
|
||||||
|
|
||||||
|
/* Main PLL configuration and activation */
|
||||||
|
LL_RCC_PLL_ConfigDomain_SYS(LL_RCC_PLLSOURCE_HSI, LL_RCC_PLLM_DIV_1, 8, LL_RCC_PLLR_DIV_2);
|
||||||
|
LL_RCC_PLL_Enable();
|
||||||
|
LL_RCC_PLL_EnableDomain_SYS();
|
||||||
|
while(LL_RCC_PLL_IsReady() != 1);
|
||||||
|
|
||||||
|
/* Set AHB prescaler*/
|
||||||
|
LL_RCC_SetAHBPrescaler(LL_RCC_SYSCLK_DIV_1);
|
||||||
|
|
||||||
|
/* Sysclk activation on the main PLL */
|
||||||
|
LL_RCC_SetSysClkSource(LL_RCC_SYS_CLKSOURCE_PLL);
|
||||||
|
while(LL_RCC_GetSysClkSource() != LL_RCC_SYS_CLKSOURCE_STATUS_PLL);
|
||||||
|
|
||||||
|
/* Set APB1 prescaler*/
|
||||||
|
LL_RCC_SetAPB1Prescaler(LL_RCC_APB1_DIV_1);
|
||||||
|
LL_Init1msTick(64000000);
|
||||||
|
/* Update CMSIS variable (which can be updated also through SystemCoreClockUpdate function) */
|
||||||
|
LL_SetSystemCoreClock(64000000);
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
/*
|
|
||||||
setvbuf(stout, NULL, _IOLBF, 0);
|
|
||||||
|
|
||||||
int _write (int file, const void * ptr, size_t len)
|
void BSP_USART_Config(uint32_t baudRate)
|
||||||
{
|
{
|
||||||
HAL_UART_Transmit(&huart1, ptr, len, TIMEOUT);
|
LL_APB1_GRP1_EnableClock(LL_APB1_GRP1_PERIPH_USART2);
|
||||||
return len;
|
|
||||||
|
/* USART Init */
|
||||||
|
LL_USART_SetBaudRate(USART2, SystemCoreClock, LL_USART_PRESCALER_DIV1, LL_USART_OVERSAMPLING_16, baudRate);
|
||||||
|
LL_USART_SetDataWidth(USART2, LL_USART_DATAWIDTH_8B);
|
||||||
|
LL_USART_SetStopBitsLength(USART2, LL_USART_STOPBITS_1);
|
||||||
|
LL_USART_SetParity(USART2, LL_USART_PARITY_NONE);
|
||||||
|
LL_USART_SetHWFlowCtrl(USART2, LL_USART_HWCONTROL_NONE);
|
||||||
|
LL_USART_SetTransferDirection(USART2, LL_USART_DIRECTION_TX_RX);
|
||||||
|
LL_USART_Enable(USART2);
|
||||||
|
LL_USART_ClearFlag_TC(USART2);
|
||||||
|
|
||||||
|
/**USART GPIO Configuration
|
||||||
|
PA2 ------> USART2_TX
|
||||||
|
PA3 ------> USART2_RX
|
||||||
|
*/
|
||||||
|
LL_IOP_GRP1_EnableClock(LL_IOP_GRP1_PERIPH_GPIOA);
|
||||||
|
|
||||||
|
LL_GPIO_SetPinMode(GPIOA, LL_GPIO_PIN_2, LL_GPIO_MODE_ALTERNATE);
|
||||||
|
LL_GPIO_SetPinSpeed(GPIOA, LL_GPIO_PIN_2, LL_GPIO_SPEED_FREQ_VERY_HIGH);
|
||||||
|
LL_GPIO_SetPinPull(GPIOA, LL_GPIO_PIN_2, LL_GPIO_PULL_UP);
|
||||||
|
LL_GPIO_SetAFPin_0_7(GPIOA, LL_GPIO_PIN_2, LL_GPIO_AF_1);
|
||||||
|
|
||||||
|
LL_GPIO_SetPinMode(GPIOA, LL_GPIO_PIN_3, LL_GPIO_MODE_ALTERNATE);
|
||||||
|
LL_GPIO_SetPinSpeed(GPIOA, LL_GPIO_PIN_3, LL_GPIO_SPEED_FREQ_VERY_HIGH);
|
||||||
|
LL_GPIO_SetPinPull(GPIOA, LL_GPIO_PIN_3, LL_GPIO_PULL_UP);
|
||||||
|
LL_GPIO_SetAFPin_0_7(GPIOA, LL_GPIO_PIN_3, LL_GPIO_AF_1);
|
||||||
|
|
||||||
|
//#if defined (__GNUC__) && !defined (__clang__)
|
||||||
|
// To avoid io buffer
|
||||||
|
// setvbuf(stdout, NULL, _IONBF, 0);
|
||||||
|
// setvbuf(stdin, NULL, _IONBF, 0);
|
||||||
|
//#endif
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
static void uart_init(void)
|
void BSP_UART_TxChar(char ch)
|
||||||
{
|
{
|
||||||
|
LL_USART_TransmitData8(USART2, ch);
|
||||||
|
while (!LL_USART_IsActiveFlag_TC(USART2));
|
||||||
|
LL_USART_ClearFlag_TC(USART2);
|
||||||
|
}
|
||||||
|
|
||||||
huart1.Instance = USART1; // Defined in CMSIS header as peripheral address
|
void BSP_UART_TxString(char *str)
|
||||||
huart1.Init.BaudRate = 115200;
|
{
|
||||||
huart1.Init.WordLength = UART_WORDLENGTH_8B;
|
while (*str) BSP_UART_TxChar(*str++);
|
||||||
huart1.Init.StopBits = UART_STOPBITS_1;
|
|
||||||
huart1.Init.Parity = UART_PARITY_NONE;
|
|
||||||
huart1.Init.Mode = UART_MODE_TX_RX;
|
|
||||||
huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE;
|
|
||||||
huart1.Init.OverSampling = UART_OVERSAMPLING_16;
|
|
||||||
huart1.Init.OneBitSampling = UART_ONE_BIT_SAMPLE_DISABLE;
|
|
||||||
huart1.Init.ClockPrescaler = UART_PRESCALER_DIV1;
|
|
||||||
huart1.AdvancedInit.AdvFeatureInit = UART_ADVFEATURE_NO_INIT;
|
|
||||||
while (HAL_UART_Init(&huart1) != HAL_OK);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int main(void)
|
int main(void)
|
||||||
{
|
{
|
||||||
HAL_Init();
|
/* Reset of all peripherals, Initializes the Flash interface and the Systick. */
|
||||||
|
LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_SYSCFG);
|
||||||
|
LL_APB1_GRP1_EnableClock(LL_APB1_GRP1_PERIPH_PWR);
|
||||||
|
/** Disable the internal Pull-Up in Dead Battery pins of UCPD peripheral */
|
||||||
|
//LL_SYSCFG_DisableDBATT(LL_SYSCFG_UCPD1_STROBE | LL_SYSCFG_UCPD2_STROBE);
|
||||||
|
|
||||||
SystemClock_Config();
|
SystemClock_Config();
|
||||||
uart_init();
|
|
||||||
|
BSP_USART_Config(115200);
|
||||||
|
|
||||||
while(1)
|
while(1)
|
||||||
{
|
{
|
||||||
HAL_UART_Transmit(&huart1, (uint8_t *)buffer, TXBUFFERSIZE, TIMEOUT);
|
BSP_UART_TxString("Hello World\r\n");
|
||||||
//printf("Hello World\r\n");
|
LL_mDelay(500);
|
||||||
HAL_Delay(100);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue