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