initial commit
This commit is contained in:
		
						commit
						7df819dfee
					
				
					 13 changed files with 1558 additions and 0 deletions
				
			
		
							
								
								
									
										175
									
								
								myapps/blinky/Makefile
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										175
									
								
								myapps/blinky/Makefile
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,175 @@ | |||
| ######################################
 | ||||
| # target
 | ||||
| ######################################
 | ||||
| TARGET = blinky | ||||
| 
 | ||||
| 
 | ||||
| ######################################
 | ||||
| # building variables
 | ||||
| ######################################
 | ||||
| # debug build?
 | ||||
| DEBUG = 1 | ||||
| # optimization for size
 | ||||
| OPT = -Os | ||||
| 
 | ||||
| 
 | ||||
| #######################################
 | ||||
| # paths
 | ||||
| #######################################
 | ||||
| # Build path
 | ||||
| BUILD_DIR = build | ||||
| 
 | ||||
| ######################################
 | ||||
| # source
 | ||||
| ######################################
 | ||||
| # C sources
 | ||||
| include emlib.mk | ||||
| C_SOURCES += \
 | ||||
| ../../platform/Device/SiliconLabs/EFR32BG22/Source/system_efr32bg22.c \ | ||||
| src/main.c | ||||
| 
 | ||||
| 
 | ||||
| # ASM sources
 | ||||
| LDLIBS1 =  \
 | ||||
| ../../platform/Device/SiliconLabs/EFR32BG22/Source/GCC/startup_efr32bg22.S | ||||
| 
 | ||||
| #######################################
 | ||||
| # binaries
 | ||||
| #######################################
 | ||||
| PREFIX = arm-none-eabi- | ||||
| 
 | ||||
| CC = $(PREFIX)gcc | ||||
| CP = $(PREFIX)objcopy | ||||
| SZ = $(PREFIX)size | ||||
| 
 | ||||
| HEX = $(CP) -O ihex | ||||
| BIN = $(CP) -O binary -S | ||||
| 
 | ||||
| #######################################
 | ||||
| # CFLAGS
 | ||||
| #######################################
 | ||||
| # cpu
 | ||||
| CPU = \
 | ||||
|  -mcpu=cortex-m33 \
 | ||||
|  -mthumb \
 | ||||
|  -mfpu=fpv5-sp-d16 \
 | ||||
|  -mfloat-abi=hard \
 | ||||
|  -std=c99 \
 | ||||
|  -Wall \
 | ||||
|  -Wextra \
 | ||||
|  -fdata-sections \
 | ||||
|  -ffunction-sections \
 | ||||
|  -fomit-frame-pointer \
 | ||||
|  -imacros sl_gcc_preinclude.h \
 | ||||
|  -mcmse | ||||
| 
 | ||||
| DEFINES = -DEFR32BG22C224F512GM32 | ||||
| 
 | ||||
| # fpu
 | ||||
| FPU =  | ||||
| 
 | ||||
| # float-abi
 | ||||
| FLOAT-ABI = | ||||
| 
 | ||||
| # mcu
 | ||||
| MCU = $(CPU) $(FPU) $(FLOAT-ABI) | ||||
| 
 | ||||
| # C includes
 | ||||
| C_INCLUDES =  \
 | ||||
|  -I include -I../../platform/CMSIS/Core/Include \
 | ||||
|  -I../../platform/Device/SiliconLabs/EFR32BG22/Include \
 | ||||
|  -I../../platform/common/inc \
 | ||||
|  -I ../../platform/common/toolchain/inc \
 | ||||
|  -I ../../platform/emlib/inc | ||||
| 
 | ||||
| # compile gcc flags
 | ||||
| CFLAGS = $(MCU) $(C_INCLUDES) $(OPT) $(DEFINES) | ||||
| 
 | ||||
| ifeq ($(DEBUG), 1) | ||||
| CFLAGS += -g | ||||
| endif | ||||
| 
 | ||||
| 
 | ||||
| # Generate dependency information <<<<<<<<<<<<<<<<<<<<<<< check
 | ||||
| CFLAGS += -MMD -MP -MF"$(@:%.o=%.d)" | ||||
| 
 | ||||
| 
 | ||||
| #######################################
 | ||||
| # LDFLAGS
 | ||||
| #######################################
 | ||||
| # link script
 | ||||
| LDSCRIPT = ../../platform/Device/SiliconLabs/EFR32BG22/Source/GCC/efr32bg22.ld | ||||
| 
 | ||||
| # libraries
 | ||||
| GROUP_START =-Wl,--start-group | ||||
| GROUP_END =-Wl,--end-group | ||||
| 
 | ||||
| PROJECT_LIBS = \
 | ||||
|  -lgcc \
 | ||||
|  -lc \
 | ||||
|  -lm \
 | ||||
|  -lnosys | ||||
| 
 | ||||
| 
 | ||||
| LIBS = $(GROUP_START) $(PROJECT_LIBS) $(GROUP_END) | ||||
| LIBDIR =  | ||||
| LDFLAGS =  \
 | ||||
|  -mcpu=cortex-m33 \
 | ||||
|  -mthumb \
 | ||||
|  -mfpu=fpv5-sp-d16 \
 | ||||
|  -mfloat-abi=hard \
 | ||||
|  -T $(LDSCRIPT) \
 | ||||
|  --specs=nano.specs \
 | ||||
|  --specs=nosys.specs \
 | ||||
|  -Xlinker -Map=$(BUILD_DIR)/$(TARGET).map \
 | ||||
|  -Wl,--gc-sections \
 | ||||
|  $(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 $@ | ||||
| 
 | ||||
| #$(LUAOBJECTS) $(OBJECTS)
 | ||||
| $(BUILD_DIR)/$(TARGET).elf: $(OBJECTS) Makefile | ||||
| 	$(CC) $(OBJECTS) $(LDFLAGS) $(LDLIBS1) -o $@ | ||||
| 	$(SZ) $@ | ||||
| 
 | ||||
| $(BUILD_DIR)/%.hex: $(BUILD_DIR)/%.elf | $(BUILD_DIR) | ||||
| 	$(HEX) $< $@ | ||||
| 	 | ||||
| $(BUILD_DIR)/%.bin: $(BUILD_DIR)/%.elf | $(BUILD_DIR) | ||||
| 	$(BIN) $< $@	 | ||||
| 	 | ||||
| $(BUILD_DIR): | ||||
| 	mkdir $@		 | ||||
| 
 | ||||
| #######################################
 | ||||
| # Program
 | ||||
| #######################################
 | ||||
| 
 | ||||
| #######################################
 | ||||
| # clean up
 | ||||
| #######################################
 | ||||
| clean: | ||||
| 	-rm -fR $(BUILD_DIR) | ||||
|    | ||||
| #######################################
 | ||||
| # dependencies
 | ||||
| #######################################
 | ||||
| -include $(wildcard $(BUILD_DIR)/*.d) | ||||
| 
 | ||||
| # *** EOF ***
 | ||||
							
								
								
									
										44
									
								
								myapps/blinky/emlib.mk
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								myapps/blinky/emlib.mk
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,44 @@ | |||
| C_SOURCES = ../../platform/emlib/src/em_cmu_fpga.c \
 | ||||
| ../../platform/emlib/src/em_dma.c \ | ||||
| ../../platform/emlib/src/em_csen.c \ | ||||
| ../../platform/emlib/src/em_msc.c \ | ||||
| ../../platform/emlib/src/em_lcd.c \ | ||||
| ../../platform/emlib/src/em_rtcc.c \ | ||||
| ../../platform/emlib/src/em_can.c \ | ||||
| ../../platform/emlib/src/em_wdog.c \ | ||||
| ../../platform/emlib/src/em_system.c \ | ||||
| ../../platform/emlib/src/em_prs.c \ | ||||
| ../../platform/emlib/src/em_se.c \ | ||||
| ../../platform/emlib/src/em_eusart.c \ | ||||
| ../../platform/emlib/src/em_dbg.c \ | ||||
| ../../platform/emlib/src/em_cmu.c \ | ||||
| ../../platform/emlib/src/em_rmu.c \ | ||||
| ../../platform/emlib/src/em_vcmp.c \ | ||||
| ../../platform/emlib/src/em_gpio.c \ | ||||
| ../../platform/emlib/src/em_aes.c \ | ||||
| ../../platform/emlib/src/em_burtc.c \ | ||||
| ../../platform/emlib/src/em_usart.c \ | ||||
| ../../platform/emlib/src/em_qspi.c \ | ||||
| ../../platform/emlib/src/em_lesense.c \ | ||||
| ../../platform/emlib/src/em_adc.c \ | ||||
| ../../platform/emlib/src/em_core.c \ | ||||
| ../../platform/emlib/src/em_letimer.c \ | ||||
| ../../platform/emlib/src/em_idac.c \ | ||||
| ../../platform/emlib/src/em_ldma.c \ | ||||
| ../../platform/emlib/src/em_vdac.c \ | ||||
| ../../platform/emlib/src/em_rtc.c \ | ||||
| ../../platform/emlib/src/em_dac.c \ | ||||
| ../../platform/emlib/src/em_pcnt.c \ | ||||
| ../../platform/emlib/src/em_pdm.c \ | ||||
| ../../platform/emlib/src/em_cryotimer.c \ | ||||
| ../../platform/emlib/src/em_iadc.c \ | ||||
| ../../platform/emlib/src/em_acmp.c \ | ||||
| ../../platform/emlib/src/em_opamp.c \ | ||||
| ../../platform/emlib/src/em_timer.c \ | ||||
| ../../platform/emlib/src/em_i2c.c \ | ||||
| ../../platform/emlib/src/em_gpcrc.c \ | ||||
| ../../platform/emlib/src/em_crypto.c \ | ||||
| ../../platform/emlib/src/em_emu.c \ | ||||
| ../../platform/emlib/src/em_ebi.c \ | ||||
| ../../platform/emlib/src/em_leuart.c | ||||
| 
 | ||||
							
								
								
									
										17
									
								
								myapps/blinky/src/main.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								myapps/blinky/src/main.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,17 @@ | |||
| #include "em_cmu.h" | ||||
| #include "em_gpio.h" | ||||
| 
 | ||||
| int main (void) | ||||
| { | ||||
|   CMU_ClockEnable(cmuClock_GPIO, true); | ||||
|   GPIO_PinModeSet(gpioPortA, 0/*pin 0*/, gpioModePushPull /*push-pull output*/, 1/*output level*/); | ||||
|    | ||||
|   while(1) { | ||||
|     GPIO_PinOutToggle(gpioPortA, 0/*pin 0*/); | ||||
|     for (volatile uint32_t i = 0; i < 100000; i++) { } // busy delay
 | ||||
|   } | ||||
|    | ||||
|   return 0; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue