add prj debug print
This commit is contained in:
parent
5db0144d4c
commit
4cdd9a24c4
2 changed files with 191 additions and 0 deletions
167
myapps/practice/00b-uart-debug/Makefile
Normal file
167
myapps/practice/00b-uart-debug/Makefile
Normal file
|
|
@ -0,0 +1,167 @@
|
|||
######################################
|
||||
# target
|
||||
######################################
|
||||
TARGET = ch592_blinky
|
||||
DEFINES = -DDEBUG=Debug_UART3
|
||||
# ../../
|
||||
|
||||
|
||||
######################################
|
||||
# building variables
|
||||
######################################
|
||||
# debug build?
|
||||
DEBUG = 1
|
||||
# optimization for size
|
||||
OPT = -Os
|
||||
|
||||
|
||||
#######################################
|
||||
# paths
|
||||
#######################################
|
||||
# Build path
|
||||
BUILD_DIR = build
|
||||
|
||||
######################################
|
||||
# source
|
||||
######################################
|
||||
# C sources
|
||||
C_SOURCES = \
|
||||
src/main.c \
|
||||
../../../vendor/StdPeriphDriver/CH59x_clk.c \
|
||||
../../../vendor/StdPeriphDriver/CH59x_gpio.c \
|
||||
../../../vendor/StdPeriphDriver/CH59x_pwr.c \
|
||||
../../../vendor/StdPeriphDriver/CH59x_sys.c \
|
||||
../../../vendor/StdPeriphDriver/CH59x_uart3.c \
|
||||
../../../vendor/RVMSIS/core_riscv.c \
|
||||
|
||||
|
||||
# ASM sources
|
||||
ASM_SOURCES = \
|
||||
../../../vendor/Startup/startup_CH592.S
|
||||
|
||||
#######################################
|
||||
# binaries
|
||||
#######################################
|
||||
#PREFIX = riscv-none-elf-
|
||||
#PREFIX = riscv64-elf-
|
||||
#debian
|
||||
#PREFIX = riscv64-unknown-elf-
|
||||
PREFIX = riscv-wch-elf-
|
||||
|
||||
CC = $(PREFIX)gcc
|
||||
AS = $(PREFIX)gcc -x assembler-with-cpp
|
||||
CP = $(PREFIX)objcopy
|
||||
SZ = $(PREFIX)size
|
||||
|
||||
HEX = $(CP) -O ihex
|
||||
BIN = $(CP) -O binary -S
|
||||
|
||||
#######################################
|
||||
# CFLAGS
|
||||
#######################################
|
||||
# cpu
|
||||
CPU = -march=rv32imac_zicsr -mabi=ilp32 -msmall-data-limit=8
|
||||
|
||||
# For gcc version less than v12
|
||||
# CPU = -march=rv32imac -mabi=ilp32 -msmall-data-limit=8
|
||||
|
||||
# fpu
|
||||
FPU =
|
||||
|
||||
# float-abi
|
||||
FLOAT-ABI =
|
||||
|
||||
# mcu
|
||||
MCU = $(CPU) $(FPU) $(FLOAT-ABI)
|
||||
|
||||
# AS includes
|
||||
AS_INCLUDES =
|
||||
|
||||
# C includes
|
||||
C_INCLUDES = \
|
||||
-I../../../vendor/StdPeriphDriver/inc \
|
||||
-I../../../vendor/RVMSIS \
|
||||
-I../../../vendor/Core \
|
||||
-Isrc/include
|
||||
|
||||
# compile gcc flags
|
||||
ASFLAGS = $(MCU) $(AS_INCLUDES) $(OPT) -Wall -fdata-sections -ffunction-sections
|
||||
|
||||
CFLAGS = $(MCU) $(C_INCLUDES) $(OPT) $(DEFINES) -Wall -fdata-sections -ffunction-sections
|
||||
|
||||
ifeq ($(DEBUG), 1)
|
||||
CFLAGS += -g -gdwarf-2
|
||||
endif
|
||||
|
||||
|
||||
# Generate dependency information
|
||||
CFLAGS += -MMD -MP -MF"$(@:%.o=%.d)"
|
||||
|
||||
|
||||
#######################################
|
||||
# LDFLAGS
|
||||
#######################################
|
||||
# link script
|
||||
LDSCRIPT = ../../../vendor/Ld/Link.ld
|
||||
|
||||
# libraries
|
||||
LIBS = -lc -lm -lnosys ../../../vendor/StdPeriphDriver/libISP592.a
|
||||
LIBDIR =
|
||||
LDFLAGS = $(MCU) -mno-save-restore -fmessage-length=0 -fsigned-char -ffunction-sections -fdata-sections -Wunused -Wuninitialized -T $(LDSCRIPT) -nostartfiles -Xlinker --gc-sections -Wl,-Map=$(BUILD_DIR)/$(TARGET).map --specs=nano.specs $(LIBS)
|
||||
|
||||
# default action: build all
|
||||
all: $(BUILD_DIR)/$(TARGET).elf $(BUILD_DIR)/$(TARGET).hex $(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)
|
||||
$(AS) -c $(CFLAGS) $< -o $@
|
||||
#$(LUAOBJECTS) $(OBJECTS)
|
||||
$(BUILD_DIR)/$(TARGET).elf: $(OBJECTS) Makefile
|
||||
$(CC) $(OBJECTS) $(LDFLAGS) -o $@
|
||||
$(SZ) $@
|
||||
|
||||
$(BUILD_DIR)/%.hex: $(BUILD_DIR)/%.elf | $(BUILD_DIR)
|
||||
$(HEX) $< $@
|
||||
|
||||
$(BUILD_DIR)/%.bin: $(BUILD_DIR)/%.elf | $(BUILD_DIR)
|
||||
$(BIN) $< $@
|
||||
|
||||
$(BUILD_DIR):
|
||||
mkdir $@
|
||||
|
||||
#######################################
|
||||
# Program
|
||||
#######################################
|
||||
|
||||
isp: $(BUILD_DIR)/$(TARGET).bin
|
||||
wchisp flash $(BUILD_DIR)/$(TARGET).bin
|
||||
|
||||
flash: $(BUILD_DIR)/$(TARGET).bin
|
||||
wlink flash $(BUILD_DIR)/$(TARGET).bin
|
||||
|
||||
#######################################
|
||||
# clean up
|
||||
#######################################
|
||||
clean:
|
||||
-rm -fR $(BUILD_DIR)
|
||||
|
||||
#######################################
|
||||
# dependencies
|
||||
#######################################
|
||||
-include $(wildcard $(BUILD_DIR)/*.d)
|
||||
|
||||
# *** EOF ***
|
||||
24
myapps/practice/00b-uart-debug/src/main.c
Normal file
24
myapps/practice/00b-uart-debug/src/main.c
Normal file
|
|
@ -0,0 +1,24 @@
|
|||
// RXD3/TXD3: PA4/PA5
|
||||
|
||||
|
||||
#include "CH59x_common.h"
|
||||
#include <string.h>
|
||||
|
||||
|
||||
int main()
|
||||
{
|
||||
char *s = "Hello world\r\n";
|
||||
SetSysClock(CLK_SOURCE_PLL_60MHz);
|
||||
|
||||
#ifdef DEBUG
|
||||
GPIOA_ModeCfg(bTXD3, GPIO_ModeOut_PP_5mA);
|
||||
UART3_DefInit();
|
||||
#endif
|
||||
|
||||
while (1) {
|
||||
//UART3_SendString((uint8_t *)s, strlen(s));
|
||||
PRINT(s);
|
||||
mDelaymS(1000);
|
||||
}
|
||||
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue