add practice projs
This commit is contained in:
		
							parent
							
								
									9a350fc0cc
								
							
						
					
					
						commit
						728c4925ea
					
				
					 13 changed files with 1279 additions and 0 deletions
				
			
		
							
								
								
									
										166
									
								
								myapps/practice/04-pwm/Makefile
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										166
									
								
								myapps/practice/04-pwm/Makefile
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,166 @@ | |||
| ######################################
 | ||||
| # target
 | ||||
| ######################################
 | ||||
| TARGET = ch592_blinky | ||||
| # ../../
 | ||||
| 
 | ||||
| 
 | ||||
| ######################################
 | ||||
| # 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_timer1.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) -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 ***
 | ||||
							
								
								
									
										61
									
								
								myapps/practice/04-pwm/src/main.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								myapps/practice/04-pwm/src/main.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,61 @@ | |||
| 
 | ||||
| // TMR1/PWM1/CAP1: PA10 (active low)
 | ||||
| 
 | ||||
| #include "CH59x_common.h" | ||||
| #include <stdbool.h> | ||||
| 
 | ||||
| #define PWM_FREQ  1000 | ||||
| #define PWM_PRD   FREQ_SYS/PWM_FREQ | ||||
| // 0 -> 60,000
 | ||||
| #define PWM_STEP  600 | ||||
| // 600: 100 steps
 | ||||
| #define DELAY_STEP 50 | ||||
| // 5 second fade in
 | ||||
| 
 | ||||
| int main() | ||||
| { | ||||
|   int32_t d = 0; | ||||
|   bool rising = true; | ||||
|    | ||||
|   SetSysClock(CLK_SOURCE_PLL_60MHz); | ||||
|    | ||||
|   GPIOA_SetBits(GPIO_Pin_10); // PWM OUT
 | ||||
|   GPIOA_ModeCfg(GPIO_Pin_10, GPIO_ModeOut_PP_5mA); | ||||
|    | ||||
|   TMR1_PWMInit(Low_Level, PWM_Times_1); // Note: PWMX_PolarTypeDef defined in CH58x_pwm.h
 | ||||
|                       // Need to init before setting PWMCycleCfg & PWMActDataWidth
 | ||||
|   TMR1_PWMCycleCfg(PWM_PRD); | ||||
|   //TMR1_PWMActDataWidth(PWM_PRD*PWM_DUTY); // MAX value: TMR1_PWMCycleCfg above (for 100%)
 | ||||
|   TMR1_PWMActDataWidth(d); // MAX value: TMR1_PWMCycleCfg above (for 100%)
 | ||||
|   TMR1_PWMEnable(); // enables output pin, configured above
 | ||||
|   TMR1_Enable(); | ||||
|    | ||||
|   while (1) { | ||||
|      | ||||
|     if (rising == true) { | ||||
|        | ||||
|       DelayMs(DELAY_STEP); | ||||
|       d += PWM_STEP; | ||||
|        | ||||
|       if (d == PWM_PRD) | ||||
|         rising = false; | ||||
|        | ||||
|       TMR1_Disable(); | ||||
|       TMR1_PWMActDataWidth(d); | ||||
|       TMR1_Enable(); | ||||
|      | ||||
|     } else { | ||||
|        | ||||
|       DelayMs(DELAY_STEP); | ||||
|       d -= PWM_STEP; | ||||
|        | ||||
|       if (d == 0) | ||||
|         rising = true; | ||||
|        | ||||
|       TMR1_Disable(); | ||||
|       TMR1_PWMActDataWidth(d); | ||||
|       TMR1_Enable(); | ||||
|     } | ||||
|   } | ||||
|    | ||||
| } | ||||
							
								
								
									
										26
									
								
								myapps/practice/04-pwm/src/main.c.fixedpulse
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								myapps/practice/04-pwm/src/main.c.fixedpulse
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,26 @@ | |||
| 
 | ||||
| // TMR1/PWM1/CAP1: PA10 (active low) | ||||
| 
 | ||||
| #include "CH59x_common.h" | ||||
| 
 | ||||
| #define PWM_FREQ  1000 | ||||
| #define PWM_PRD   FREQ_SYS/PWM_FREQ | ||||
| #define PWM_DUTY  0.20 | ||||
| 
 | ||||
| int main() | ||||
| { | ||||
|   SetSysClock(CLK_SOURCE_PLL_60MHz); | ||||
|    | ||||
|   GPIOA_SetBits(GPIO_Pin_10); // PWM OUT | ||||
|   GPIOA_ModeCfg(GPIO_Pin_10, GPIO_ModeOut_PP_5mA); | ||||
|    | ||||
|   TMR1_PWMInit(Low_Level, PWM_Times_1); // Note: PWMX_PolarTypeDef defined in CH58x_pwm.h | ||||
|                       // Need to init before setting PWMCycleCfg & PWMActDataWidth | ||||
|   TMR1_PWMCycleCfg(PWM_PRD); | ||||
|   TMR1_PWMActDataWidth(PWM_PRD*PWM_DUTY); // MAX value: TMR1_PWMCycleCfg above (for 100%) | ||||
|   TMR1_PWMEnable(); // enables output pin, configured above | ||||
|   TMR1_Enable(); | ||||
|    | ||||
|   while (1); | ||||
|    | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue