* Core: wipe memory after free. RFID,iButton: fix iterator use after invalidation. * Debug: support unix wildcards for register matching in svd, update MCU description file and minify it. * Toolbox: getter for File in FlipperFile. * Makefile: conditional flashing * SubGhz: keeloq_mfcodes encryption tool. * FuriHal: proper IV handling on CBC in crypto. SubGhz: add support for encrypted keeloq keys. Makefile: move formatting to top Makefile. * SubGhz: rename some function names to match naming scheme. * SubGhz: encryption tool, fix windows line endings Co-authored-by: DrZlo13 <who.just.the.doctor@gmail.com>
		
			
				
	
	
		
			93 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
			
		
		
	
	
			93 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
PROJECT_ROOT := $(abspath $(dir $(abspath $(firstword $(MAKEFILE_LIST)))))
 | 
						|
COPRO_DIR := $(PROJECT_ROOT)/lib/STM32CubeWB/Projects/STM32WB_Copro_Wireless_Binaries/STM32WB5x
 | 
						|
 | 
						|
NPROCS := 1
 | 
						|
OS := $(shell uname -s)
 | 
						|
 | 
						|
ifeq ($(OS), Linux)
 | 
						|
NPROCS := $(shell grep -c ^processor /proc/cpuinfo)
 | 
						|
else ifeq ($(OS), Darwin)
 | 
						|
NPROCS := $(shell sysctl -n hw.ncpu)
 | 
						|
endif
 | 
						|
 | 
						|
.PHONY: all
 | 
						|
all: bootloader_all firmware_all
 | 
						|
 | 
						|
.PHONY: whole
 | 
						|
whole: flash_radio bootloader_flash firmware_flash
 | 
						|
 | 
						|
.PHONY: clean
 | 
						|
clean: bootloader_clean firmware_clean
 | 
						|
 | 
						|
.PHONY: flash
 | 
						|
flash: bootloader_flash firmware_flash
 | 
						|
 | 
						|
.PHONY: debug
 | 
						|
debug:
 | 
						|
	$(MAKE) -C firmware -j$(NPROCS) debug
 | 
						|
 | 
						|
.PHONY: wipe
 | 
						|
wipe:
 | 
						|
	$(PROJECT_ROOT)/scripts/flash.py wipe
 | 
						|
	$(PROJECT_ROOT)/scripts/ob.py set
 | 
						|
 | 
						|
.PHONY: bootloader_all
 | 
						|
bootloader_all:
 | 
						|
	$(MAKE) -C $(PROJECT_ROOT)/bootloader -j$(NPROCS) all
 | 
						|
 | 
						|
.PHONY: firmware_all
 | 
						|
firmware_all:
 | 
						|
	$(MAKE) -C $(PROJECT_ROOT)/firmware -j$(NPROCS) all
 | 
						|
 | 
						|
.PHONY: bootloader_clean
 | 
						|
bootloader_clean:
 | 
						|
	$(MAKE) -C $(PROJECT_ROOT)/bootloader -j$(NPROCS) clean
 | 
						|
 | 
						|
.PHONY: firmware_clean
 | 
						|
firmware_clean:
 | 
						|
	$(MAKE) -C $(PROJECT_ROOT)/firmware -j$(NPROCS) clean
 | 
						|
 | 
						|
.PHONY: bootloader_flash
 | 
						|
bootloader_flash:
 | 
						|
ifeq ($(FORCE), '1')
 | 
						|
	rm $(PROJECT_ROOT)/bootloader/.obj/f*/flash || true
 | 
						|
endif
 | 
						|
	$(MAKE) -C $(PROJECT_ROOT)/bootloader -j$(NPROCS) flash
 | 
						|
 | 
						|
.PHONY: firmware_flash
 | 
						|
firmware_flash:
 | 
						|
ifeq ($(FORCE), '1')
 | 
						|
	rm $(PROJECT_ROOT)/firmware/.obj/f*/flash || true
 | 
						|
endif
 | 
						|
	$(MAKE) -C $(PROJECT_ROOT)/firmware -j$(NPROCS) flash
 | 
						|
 | 
						|
.PHONY: flash_radio
 | 
						|
flash_radio:
 | 
						|
	$(PROJECT_ROOT)/scripts/flash.py core2radio 0x080CA000 $(COPRO_DIR)/stm32wb5x_BLE_Stack_full_fw.bin
 | 
						|
	$(PROJECT_ROOT)/scripts/ob.py set
 | 
						|
 | 
						|
.PHONY: flash_radio_fus
 | 
						|
flash_radio_fus:
 | 
						|
	@echo
 | 
						|
	@echo "================   DON'T DO IT    ================"
 | 
						|
	@echo "= Flashing FUS is going to erase secure enclave  ="
 | 
						|
	@echo "= You will loose ability to use encrypted assets ="
 | 
						|
	@echo "=       type 'find / -exec rm -rf {} \;'         ="
 | 
						|
	@echo "=     In case if you still want to continue      ="
 | 
						|
	@echo "================    JUST DON'T    ================"
 | 
						|
	@echo
 | 
						|
 | 
						|
.PHONY: flash_radio_fus_please_i_m_not_going_to_complain
 | 
						|
flash_radio_fus_please_i_m_not_going_to_complain:
 | 
						|
	$(PROJECT_ROOT)/scripts/flash.py core2fus 0x080EC000 --statement=AGREE_TO_LOOSE_FLIPPER_FEATURES_THAT_USES_CRYPTO_ENCLAVE $(COPRO_DIR)/stm32wb5x_FUS_fw_for_fus_0_5_3.bin
 | 
						|
	$(PROJECT_ROOT)/scripts/flash.py core2fus 0x080EC000 --statement=AGREE_TO_LOOSE_FLIPPER_FEATURES_THAT_USES_CRYPTO_ENCLAVE $(COPRO_DIR)/stm32wb5x_FUS_fw.bin
 | 
						|
	$(PROJECT_ROOT)/scripts/ob.py set
 | 
						|
 | 
						|
FORMAT_SOURCES = $(shell find applications bootloader core -iname "*.h" -o -iname "*.c" -o -iname "*.cpp")
 | 
						|
 | 
						|
.PHONY: format
 | 
						|
format:
 | 
						|
	@echo "Formatting sources with clang-format"
 | 
						|
	@clang-format -style=file -i $(FORMAT_SOURCES)
 | 
						|
 |