
The side effect of this is to disable GPIO mode for OC, but I2C still works Using both addons together is super unlikely
259 lines
8.2 KiB
CMake
259 lines
8.2 KiB
CMake
# Copyright 2009 Uwe Hermann <uwe@hermann-uwe.de>
|
|
# Copyright 2010 Piotr Esden-Tempski <piotr@esden.net>
|
|
# Copyright 2012 Michael Ossmann <mike@ossmann.com>
|
|
# Copyright 2012 Benjamin Vernoux <titanmkd@gmail.com>
|
|
# Copyright 2012 Jared Boone <jared@sharebrained.com>
|
|
# Copyright 2016 Dominic Spill <dominicgs@gmail.com>
|
|
#
|
|
# This file is part of HackRF.
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 2, or (at your option)
|
|
# any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; see the file COPYING. If not, write to
|
|
# the Free Software Foundation, Inc., 51 Franklin Street,
|
|
# Boston, MA 02110-1301, USA.
|
|
#
|
|
|
|
# derived primarily from Makefiles in libopencm3
|
|
|
|
enable_language(C CXX ASM)
|
|
|
|
SET(PATH_HACKRF_FIRMWARE ${CMAKE_CURRENT_LIST_DIR})
|
|
SET(PATH_HACKRF ${PATH_HACKRF_FIRMWARE}/..)
|
|
SET(PATH_HACKRF_FIRMWARE_COMMON ${PATH_HACKRF_FIRMWARE}/common)
|
|
SET(LIBOPENCM3 ${PATH_HACKRF_FIRMWARE}/libopencm3)
|
|
SET(PATH_DFU_PY ${PATH_HACKRF_FIRMWARE}/dfu.py)
|
|
|
|
include(${PATH_HACKRF_FIRMWARE}/dfu-util.cmake)
|
|
|
|
include(ExternalProject)
|
|
ExternalProject_Add(libopencm3_${PROJECT_NAME}
|
|
SOURCE_DIR "${LIBOPENCM3}"
|
|
BUILD_IN_SOURCE true
|
|
DOWNLOAD_COMMAND ""
|
|
CONFIGURE_COMMAND ""
|
|
INSTALL_COMMAND ""
|
|
)
|
|
|
|
#set(VERSION "")
|
|
if (NOT DEFINED VERSION)
|
|
execute_process(
|
|
COMMAND git log -n 1 --format=%h
|
|
WORKING_DIRECTORY ${PROJECT_SOURCE_DIR}
|
|
RESULT_VARIABLE GIT_VERSION_FOUND
|
|
ERROR_QUIET
|
|
OUTPUT_VARIABLE GIT_VERSION
|
|
OUTPUT_STRIP_TRAILING_WHITESPACE
|
|
)
|
|
if (GIT_VERSION_FOUND)
|
|
set(VERSION "unknown")
|
|
else (GIT_VERSION_FOUND)
|
|
set(VERSION "git-${GIT_VERSION}")
|
|
endif (GIT_VERSION_FOUND)
|
|
endif()
|
|
|
|
if(NOT DEFINED BOARD)
|
|
set(BOARD HACKRF_ONE)
|
|
endif()
|
|
|
|
if(BOARD STREQUAL "HACKRF_ONE")
|
|
set(MCU_PARTNO LPC4320)
|
|
else()
|
|
set(MCU_PARTNO LPC4330)
|
|
endif()
|
|
|
|
if(BOARD STREQUAL "RAD1O")
|
|
set(USER_INTERFACE RAD1O)
|
|
endif()
|
|
|
|
if(NOT DEFINED USER_INTERFACE)
|
|
set(USER_INTERFACE NONE)
|
|
endif()
|
|
|
|
if(NOT DEFINED SRC_M0)
|
|
set(SRC_M0 "${PATH_HACKRF_FIRMWARE_COMMON}/m0_sleep.c")
|
|
endif()
|
|
|
|
SET(HACKRF_OPTS "-D${BOARD} -DUSER_INTERFACE_${USER_INTERFACE} -DLPC43XX -D${MCU_PARTNO} -DTX_ENABLE -D'VERSION_STRING=\"${VERSION}\"'")
|
|
|
|
SET(LDSCRIPT_M4 "-T${PATH_HACKRF_FIRMWARE_COMMON}/${MCU_PARTNO}_M4_memory.ld -Tlibopencm3_lpc43xx_rom_to_ram.ld -T${PATH_HACKRF_FIRMWARE_COMMON}/LPC43xx_M4_M0_image_from_text.ld")
|
|
|
|
SET(LDSCRIPT_M4_DFU "-T${PATH_HACKRF_FIRMWARE_COMMON}/${MCU_PARTNO}_M4_memory.ld -Tlibopencm3_lpc43xx.ld -T${PATH_HACKRF_FIRMWARE_COMMON}/LPC43xx_M4_M0_image_from_text.ld")
|
|
|
|
SET(LDSCRIPT_M0 "-T${PATH_HACKRF_FIRMWARE_COMMON}/LPC43xx_M0_memory.ld -Tlibopencm3_lpc43xx_m0.ld")
|
|
|
|
SET(CFLAGS_COMMON "-Os -g3 -Wall -Wextra ${HACKRF_OPTS} -fno-common -MD")
|
|
SET(LDFLAGS_COMMON "-nostartfiles -Wl,--gc-sections")
|
|
|
|
if(V STREQUAL "1")
|
|
SET(LDFLAGS_COMMON "${LDFLAGS_COMMON} -Wl,--print-gc-sections")
|
|
endif()
|
|
|
|
SET(CPUFLAGS_M0 "-mthumb -mcpu=cortex-m0 -mfloat-abi=soft")
|
|
SET(CFLAGS_M0 "-std=gnu99 ${CFLAGS_COMMON} ${CPUFLAGS_M0} -DLPC43XX_M0")
|
|
SET(CXXFLAGS_M0 "-std=gnu++0x ${CFLAGS_COMMON} ${CPUFLAGS_M0} -DLPC43XX_M0")
|
|
SET(LDFLAGS_M0 "${LDFLAGS_COMMON} ${CPUFLAGS_M0} ${LDSCRIPT_M0} -Xlinker -Map=m0.map")
|
|
|
|
SET(CPUFLAGS_M4 "-mthumb -mcpu=cortex-m4 -mfloat-abi=hard -mfpu=fpv4-sp-d16")
|
|
SET(CFLAGS_M4 "-std=gnu99 ${CFLAGS_COMMON} ${CPUFLAGS_M4} -DLPC43XX_M4")
|
|
SET(CXXFLAGS_M4 "-std=gnu++0x ${CFLAGS_COMMON} ${CPUFLAGS_M4} -DLPC43XX_M4")
|
|
SET(LDFLAGS_M4 "${LDFLAGS_COMMON} ${CPUFLAGS_M4} ${LDSCRIPT_M4} -Xlinker -Map=m4.map")
|
|
|
|
SET(CFLAGS_M4_DFU "-std=gnu99 ${CFLAGS_COMMON} ${CPUFLAGS_M4} -DLPC43XX_M4")
|
|
if(NOT USER_INTERFACE STREQUAL "PORTAPACK")
|
|
SET(CFLAGS_M4_DFU "${CFLAGS_M4_DFU} -DDFU_MODE")
|
|
endif()
|
|
SET(LDFLAGS_M4_DFU "${LDFLAGS_COMMON} ${CPUFLAGS_M4} ${LDSCRIPT_M4_DFU} -Xlinker -Map=m4.map")
|
|
|
|
set(BUILD_SHARED_LIBS OFF)
|
|
|
|
include_directories("${LIBOPENCM3}/include/")
|
|
include_directories("${PATH_HACKRF_FIRMWARE_COMMON}")
|
|
|
|
macro(DeclareTargets)
|
|
SET(SRC_M4
|
|
${SRC_M4}
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/hackrf_core.c
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/sgpio.c
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/rf_path.c
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/si5351c.c
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/max2837.c
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/max2837_target.c
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/max5864.c
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/max5864_target.c
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/mixer.c
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/i2c_bus.c
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/i2c_lpc.c
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/w25q80bv.c
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/w25q80bv_target.c
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/spi_bus.c
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/spi_ssp.c
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/gpio_lpc.c
|
|
)
|
|
|
|
if(BOARD STREQUAL "RAD1O")
|
|
SET(SRC_M4
|
|
${SRC_M4}
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/max2871.c
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/max2871_regs.c
|
|
)
|
|
else()
|
|
SET(SRC_M4
|
|
${SRC_M4}
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/rffc5071.c
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/rffc5071_spi.c
|
|
)
|
|
endif()
|
|
|
|
configure_file(
|
|
${PATH_HACKRF_FIRMWARE_COMMON}/m0_bin.s.cmake
|
|
m0_bin.s
|
|
)
|
|
|
|
link_directories(
|
|
"${PATH_HACKRF_FIRMWARE_COMMON}"
|
|
"${LIBOPENCM3}/lib"
|
|
"${LIBOPENCM3}/lib/lpc43xx"
|
|
"${CMAKE_INSTALL_PREFIX}/lib/armv7e-m/fpu"
|
|
)
|
|
|
|
add_executable(${PROJECT_NAME}_m0.elf ${SRC_M0})
|
|
add_dependencies(${PROJECT_NAME}_m0.elf libopencm3_${PROJECT_NAME})
|
|
|
|
target_link_libraries(
|
|
${PROJECT_NAME}_m0.elf
|
|
c
|
|
nosys
|
|
opencm3_lpc43xx_m0
|
|
)
|
|
|
|
set_target_properties(${PROJECT_NAME}_m0.elf PROPERTIES COMPILE_FLAGS "${CFLAGS_M0}")
|
|
set_target_properties(${PROJECT_NAME}_m0.elf PROPERTIES LINK_FLAGS "${LDFLAGS_M0}")
|
|
|
|
add_custom_target(
|
|
${PROJECT_NAME}_m0.bin
|
|
DEPENDS ${PROJECT_NAME}_m0.elf
|
|
COMMAND ${CMAKE_OBJCOPY} -Obinary ${PROJECT_NAME}_m0.elf ${PROJECT_NAME}_m0.bin
|
|
)
|
|
|
|
# Object files to be linked for SPI flash versions
|
|
add_library(${PROJECT_NAME}_objects OBJECT ${SRC_M4} m0_bin.s)
|
|
set_target_properties(${PROJECT_NAME}_objects PROPERTIES COMPILE_FLAGS "${CFLAGS_M4}")
|
|
add_dependencies(${PROJECT_NAME}_objects ${PROJECT_NAME}_m0.bin)
|
|
add_executable(${PROJECT_NAME}.elf $<TARGET_OBJECTS:${PROJECT_NAME}_objects>)
|
|
add_dependencies(${PROJECT_NAME}.elf libopencm3_${PROJECT_NAME})
|
|
|
|
target_link_libraries(
|
|
${PROJECT_NAME}.elf
|
|
c
|
|
nosys
|
|
opencm3_lpc43xx
|
|
m
|
|
)
|
|
|
|
set_target_properties(${PROJECT_NAME}.elf PROPERTIES LINK_FLAGS "${LDFLAGS_M4}")
|
|
|
|
add_custom_target(
|
|
${PROJECT_NAME}.bin ALL
|
|
DEPENDS ${PROJECT_NAME}.elf
|
|
COMMAND ${CMAKE_OBJCOPY} -Obinary ${PROJECT_NAME}.elf ${PROJECT_NAME}.bin
|
|
)
|
|
|
|
# DFU - using a differnet LD script to run directly from RAM
|
|
# Object files to be linked for DFU flash versions
|
|
add_library(${PROJECT_NAME}_dfu_objects OBJECT ${SRC_M4} m0_bin.s)
|
|
set_target_properties(${PROJECT_NAME}_dfu_objects PROPERTIES COMPILE_FLAGS "${CFLAGS_M4_DFU}")
|
|
add_dependencies(${PROJECT_NAME}_dfu_objects ${PROJECT_NAME}_m0.bin)
|
|
add_executable(${PROJECT_NAME}_dfu.elf $<TARGET_OBJECTS:${PROJECT_NAME}_dfu_objects>)
|
|
add_dependencies(${PROJECT_NAME}_dfu.elf libopencm3_${PROJECT_NAME})
|
|
|
|
target_link_libraries(
|
|
${PROJECT_NAME}_dfu.elf
|
|
c
|
|
nosys
|
|
opencm3_lpc43xx
|
|
m
|
|
)
|
|
|
|
set_target_properties(${PROJECT_NAME}_dfu.elf PROPERTIES LINK_FLAGS "${LDFLAGS_M4_DFU}")
|
|
|
|
add_custom_target(
|
|
${PROJECT_NAME}_dfu.bin
|
|
DEPENDS ${PROJECT_NAME}_dfu.elf
|
|
COMMAND ${CMAKE_OBJCOPY} -Obinary ${PROJECT_NAME}_dfu.elf ${PROJECT_NAME}_dfu.bin
|
|
)
|
|
|
|
add_custom_target(
|
|
${PROJECT_NAME}.dfu ${DFU_ALL}
|
|
DEPENDS ${PROJECT_NAME}_dfu.bin
|
|
COMMAND rm -f _tmp.dfu _header.bin
|
|
COMMAND cp ${PROJECT_NAME}_dfu.bin _tmp.dfu
|
|
COMMAND dfu-suffix --vid=0x1fc9 --pid=0x000c --did=0x0 -a _tmp.dfu
|
|
COMMAND python ${PATH_DFU_PY} ${PROJECT_NAME}
|
|
COMMAND cat _header.bin _tmp.dfu >${PROJECT_NAME}.dfu
|
|
COMMAND rm -f _tmp.dfu _header.bin
|
|
)
|
|
|
|
# Program / flash targets
|
|
add_custom_target(
|
|
${PROJECT_NAME}-flash
|
|
DEPENDS ${PROJECT_NAME}.bin
|
|
COMMAND hackrf_spiflash -Rw ${PROJECT_NAME}.bin
|
|
)
|
|
|
|
add_custom_target(
|
|
${PROJECT_NAME}-program
|
|
DEPENDS ${PROJECT_NAME}.dfu
|
|
COMMAND dfu-util --device 1fc9:000c --alt 0 --download ${PROJECT_NAME}.dfu
|
|
)
|
|
endmacro()
|