aboutsummaryrefslogtreecommitdiffstats
path: root/mpm/lib/lmk04828/CMakeLists.txt
blob: b3621034a42339c709b9e45960a8bc2da8c7bcdd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
MACRO(ETTUS_PYTHON_GEN_SOURCE pyfile outfile)
    #ensure that the directory exists for outfile
    GET_FILENAME_COMPONENT(outfile_dir ${outfile} PATH)
    FILE(MAKE_DIRECTORY ${outfile_dir})
    IF(NOT PYTHON_EXECUTABLE)
        MESSAGE( FATAL_ERROR "No python executable found to generate ic_regmaps!" )
    ENDIF(NOT PYTHON_EXECUTABLE)
    #make the outfile depend on the python script
    ADD_CUSTOM_COMMAND(
        OUTPUT ${outfile} DEPENDS ${pyfile} ${ETTUS_PYTHON_GEN_SOURCE_DEPS}
        COMMAND ${PYTHON_EXECUTABLE} -B ${pyfile} ${outfile}
        COMMENT "Generating ${outfile}"
    )

    #make lmk04828 depend on the outfile
    LIST(APPEND lmk04828_srcs ${ARGV})
ENDMACRO(ETTUS_PYTHON_GEN_SOURCE)

####################################################
# LMK04828
####################################################

# Register definitions need to be generated
SET(UHD_HOST_ROOT ${CMAKE_SOURCE_DIR}/../host)
MESSAGE("uhd host root: ${UHD_HOST_ROOT}")
SET(UHD_IC_REG_MAP_PATH ${UHD_HOST_ROOT}/lib/ic_reg_maps)

SET(ETTUS_PYTHON_GEN_SOURCE_DEPS ${UHD_IC_REG_MAP_PATH}/common.py)
ETTUS_PYTHON_GEN_SOURCE(
    ${UHD_IC_REG_MAP_PATH}/gen_lmk04828_regs.py
    ${CMAKE_CURRENT_BINARY_DIR}/lmk04828_regs.hpp
)
SET(LIBUHD_PYTHON_GEN_SOURCE_DEPS)


# LMK04828 driver files
LIST(APPEND lmk04828_srcs
    ${UHD_HOST_ROOT}/lib/usrp/common/lmk04828.cpp
    ${UHD_HOST_ROOT}/lib/types/serial.cpp
    ${CMAKE_CURRENT_SOURCE_DIR}/lmk04828_spi_iface.cpp
    )

# Extra files needed
LIST(APPEND lmk04828_srcs ${UHD_HOST_ROOT}/lib/exception.cpp)

# For include/uhd/exception.hpp and include/uhd/config.h

USRP_PERIPHS_ADD_OBJECT(lmk04828 ${lmk04828_srcs})
TARGET_INCLUDE_DIRECTORIES(lmk04828 PUBLIC ${UHD_HOST_ROOT}/include ${CMAKE_CURRENT_BINARY_DIR} ${UHD_HOST_ROOT}/lib/usrp/common)