summaryrefslogtreecommitdiffstats
path: root/stage1/CMakeLists.txt
blob: a42e71b629a3fcebfd835b1ec5b074e7dc2c5f08 (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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
################################################################################
###
### @file       CMakeLists.txt
###
### @project    bcm5719
###
### @brief      First binary stage for the bcm5719
###
################################################################################
###
################################################################################
###
### @copyright Copyright (c) 2018-2020, Evan Lojewski
### @cond
###
### All rights reserved.
###
### Redistribution and use in source and binary forms, with or without
### modification, are permitted provided that the following conditions are met:
### 1. Redistributions of source code must retain the above copyright notice,
### this list of conditions and the following disclaimer.
### 2. Redistributions in binary form must reproduce the above copyright notice,
### this list of conditions and the following disclaimer in the documentation
### and/or other materials provided with the distribution.
### 3. Neither the name of the copyright holder nor the
### names of its contributors may be used to endorse or promote products
### derived from this software without specific prior written permission.
###
################################################################################
###
### THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
### AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
### IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
### ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
### LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
### CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
### SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
### INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
### CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
### ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
### POSSIBILITY OF SUCH DAMAGE.
### @endcond
################################################################################


project(stage1)

# Firmware
set(LINKER_SCRIPT "${CMAKE_CURRENT_SOURCE_DIR}/stage1.ld")

function(stage1_firmware PORT)
    SET(TARGET ${PROJECT_NAME}-port${PORT})

    mips_add_executable(${TARGET}
                init_hw.c
                main.c
                crt.s)
    mips_linker_script(${TARGET} ${LINKER_SCRIPT})
    target_link_libraries(${TARGET}
        --defsym=NETWORK_PORT=${PORT}
        --defsym=VERSION_MAJOR=${VERSION_MAJOR}
        --defsym=VERSION_MINOR=${VERSION_MINOR}
        --defsym=VERSION_PATCH=${VERSION_PATCH})

    target_link_libraries(${TARGET} NVRam-mips MII-mips APE-mips Timer-mips printf-mips)
    target_link_libraries(${TARGET} bcm5719)
    target_compile_options(${TARGET} PRIVATE -nodefaultlibs)
    target_include_directories(${TARGET} PUBLIC ../libs/VPD/include .)
    target_compile_definitions(${TARGET} PRIVATE NETWORK_PORT=${PORT})

    install(TARGETS ${TARGET} DESTINATION fw RESOURCE)
endfunction(stage1_firmware)

stage1_firmware(0)
stage1_firmware(2)


# Simulator add_executable
simulator_add_executable(sim-${PROJECT_NAME}
            init_hw.c
            main.c)

target_link_libraries(sim-${PROJECT_NAME} simulator)
target_link_libraries(sim-${PROJECT_NAME} NVRam MII VPD APE Timer printf)
target_include_directories(sim-${PROJECT_NAME} PUBLIC  .)
target_compile_definitions(sim-${PROJECT_NAME} PRIVATE NETWORK_PORT=0)

format_target_sources(${PROJECT_NAME}-port0)
OpenPOWER on IntegriCloud