Ryan Harkin | 25cff83 | 2014-01-13 12:37:03 +0000 | [diff] [blame] | 1 | # |
| 2 | # Copyright (c) 2013-2014, ARM Limited and Contributors. All rights reserved. |
| 3 | # |
| 4 | # Redistribution and use in source and binary forms, with or without |
| 5 | # modification, are permitted provided that the following conditions are met: |
| 6 | # |
| 7 | # Redistributions of source code must retain the above copyright notice, this |
| 8 | # list of conditions and the following disclaimer. |
| 9 | # |
| 10 | # Redistributions in binary form must reproduce the above copyright notice, |
| 11 | # this list of conditions and the following disclaimer in the documentation |
| 12 | # and/or other materials provided with the distribution. |
| 13 | # |
| 14 | # Neither the name of ARM nor the names of its contributors may be used |
| 15 | # to endorse or promote products derived from this software without specific |
| 16 | # prior written permission. |
| 17 | # |
| 18 | # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" |
| 19 | # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| 20 | # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
| 21 | # ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE |
| 22 | # LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR |
| 23 | # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
| 24 | # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
| 25 | # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN |
| 26 | # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) |
| 27 | # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
| 28 | # POSSIBILITY OF SUCH DAMAGE. |
| 29 | # |
| 30 | |
Juan Castillo | 48e84b3 | 2014-08-12 13:51:51 +0100 | [diff] [blame] | 31 | # Shared memory may be allocated at the top of Trusted SRAM (tsram) or at the |
| 32 | # base of Trusted SRAM (tdram) |
| 33 | FVP_SHARED_DATA_LOCATION := tsram |
| 34 | ifeq (${FVP_SHARED_DATA_LOCATION}, tsram) |
| 35 | FVP_SHARED_DATA_LOCATION_ID := FVP_IN_TRUSTED_SRAM |
| 36 | else ifeq (${FVP_SHARED_DATA_LOCATION}, tdram) |
| 37 | FVP_SHARED_DATA_LOCATION_ID := FVP_IN_TRUSTED_DRAM |
| 38 | else |
| 39 | $(error "Unsupported FVP_SHARED_DATA_LOCATION value") |
| 40 | endif |
| 41 | |
Sandrine Bailleux | e701e30 | 2014-05-20 17:28:25 +0100 | [diff] [blame] | 42 | # On FVP, the TSP can execute either from Trusted SRAM or Trusted DRAM. |
| 43 | # Trusted SRAM is the default. |
Juan Castillo | 0c70c57 | 2014-08-12 13:04:43 +0100 | [diff] [blame] | 44 | FVP_TSP_RAM_LOCATION := tsram |
| 45 | ifeq (${FVP_TSP_RAM_LOCATION}, tsram) |
| 46 | FVP_TSP_RAM_LOCATION_ID := FVP_IN_TRUSTED_SRAM |
| 47 | else ifeq (${FVP_TSP_RAM_LOCATION}, tdram) |
| 48 | FVP_TSP_RAM_LOCATION_ID := FVP_IN_TRUSTED_DRAM |
Sandrine Bailleux | e701e30 | 2014-05-20 17:28:25 +0100 | [diff] [blame] | 49 | else |
Juan Castillo | 0c70c57 | 2014-08-12 13:04:43 +0100 | [diff] [blame] | 50 | $(error "Unsupported FVP_TSP_RAM_LOCATION value") |
Sandrine Bailleux | e701e30 | 2014-05-20 17:28:25 +0100 | [diff] [blame] | 51 | endif |
| 52 | |
Juan Castillo | 48e84b3 | 2014-08-12 13:51:51 +0100 | [diff] [blame] | 53 | ifeq (${FVP_SHARED_DATA_LOCATION}, tsram) |
| 54 | ifeq (${FVP_TSP_RAM_LOCATION}, tdram) |
| 55 | $(error Shared data in Trusted SRAM and TSP in Trusted DRAM is not supported) |
| 56 | endif |
| 57 | endif |
| 58 | |
Juan Castillo | 0c70c57 | 2014-08-12 13:04:43 +0100 | [diff] [blame] | 59 | # Process flags |
Juan Castillo | 48e84b3 | 2014-08-12 13:51:51 +0100 | [diff] [blame] | 60 | $(eval $(call add_define,FVP_SHARED_DATA_LOCATION_ID)) |
Juan Castillo | 0c70c57 | 2014-08-12 13:04:43 +0100 | [diff] [blame] | 61 | $(eval $(call add_define,FVP_TSP_RAM_LOCATION_ID)) |
Sandrine Bailleux | e701e30 | 2014-05-20 17:28:25 +0100 | [diff] [blame] | 62 | |
Soby Mathew | 5e5c207 | 2014-04-07 15:28:55 +0100 | [diff] [blame] | 63 | PLAT_INCLUDES := -Iplat/fvp/include/ |
Ryan Harkin | 25cff83 | 2014-01-13 12:37:03 +0000 | [diff] [blame] | 64 | |
Soby Mathew | c389d77 | 2014-06-24 12:28:41 +0100 | [diff] [blame] | 65 | PLAT_BL_COMMON_SOURCES := drivers/arm/pl011/pl011_console.S \ |
Dan Handley | 176e7b4 | 2014-04-15 18:20:09 +0100 | [diff] [blame] | 66 | drivers/io/io_fip.c \ |
| 67 | drivers/io/io_memmap.c \ |
| 68 | drivers/io/io_semihosting.c \ |
Dan Handley | 7b83c44 | 2014-08-12 14:20:28 +0100 | [diff] [blame] | 69 | drivers/io/io_storage.c \ |
Dan Handley | 176e7b4 | 2014-04-15 18:20:09 +0100 | [diff] [blame] | 70 | lib/aarch64/xlat_tables.c \ |
| 71 | lib/semihosting/semihosting.c \ |
| 72 | lib/semihosting/aarch64/semihosting_call.S \ |
Dan Handley | b226a4d | 2014-05-16 14:08:45 +0100 | [diff] [blame] | 73 | plat/common/aarch64/plat_common.c \ |
Dan Handley | ea45157 | 2014-05-15 14:53:30 +0100 | [diff] [blame] | 74 | plat/fvp/fvp_io_storage.c |
Ryan Harkin | 25cff83 | 2014-01-13 12:37:03 +0000 | [diff] [blame] | 75 | |
Dan Handley | 176e7b4 | 2014-04-15 18:20:09 +0100 | [diff] [blame] | 76 | BL1_SOURCES += drivers/arm/cci400/cci400.c \ |
| 77 | plat/common/aarch64/platform_up_stack.S \ |
Dan Handley | ea45157 | 2014-05-15 14:53:30 +0100 | [diff] [blame] | 78 | plat/fvp/bl1_fvp_setup.c \ |
| 79 | plat/fvp/aarch64/fvp_common.c \ |
| 80 | plat/fvp/aarch64/fvp_helpers.S |
Ryan Harkin | 25cff83 | 2014-01-13 12:37:03 +0000 | [diff] [blame] | 81 | |
Dan Handley | 176e7b4 | 2014-04-15 18:20:09 +0100 | [diff] [blame] | 82 | BL2_SOURCES += drivers/arm/tzc400/tzc400.c \ |
| 83 | plat/common/aarch64/platform_up_stack.S \ |
Dan Handley | ea45157 | 2014-05-15 14:53:30 +0100 | [diff] [blame] | 84 | plat/fvp/bl2_fvp_setup.c \ |
| 85 | plat/fvp/fvp_security.c \ |
| 86 | plat/fvp/aarch64/fvp_common.c |
Ryan Harkin | 25cff83 | 2014-01-13 12:37:03 +0000 | [diff] [blame] | 87 | |
Vikram Kanigiri | cf79bf5 | 2014-06-02 14:59:00 +0100 | [diff] [blame] | 88 | BL31_SOURCES += drivers/arm/cci400/cci400.c \ |
Dan Handley | fb42b12 | 2014-06-20 09:43:15 +0100 | [diff] [blame] | 89 | drivers/arm/gic/arm_gic.c \ |
Vikram Kanigiri | cf79bf5 | 2014-06-02 14:59:00 +0100 | [diff] [blame] | 90 | drivers/arm/gic/gic_v2.c \ |
Dan Handley | 176e7b4 | 2014-04-15 18:20:09 +0100 | [diff] [blame] | 91 | drivers/arm/gic/gic_v3.c \ |
Vikram Kanigiri | cf79bf5 | 2014-06-02 14:59:00 +0100 | [diff] [blame] | 92 | drivers/arm/tzc400/tzc400.c \ |
Dan Handley | fb42b12 | 2014-06-20 09:43:15 +0100 | [diff] [blame] | 93 | plat/common/plat_gic.c \ |
Dan Handley | 176e7b4 | 2014-04-15 18:20:09 +0100 | [diff] [blame] | 94 | plat/common/aarch64/platform_mp_stack.S \ |
Dan Handley | ea45157 | 2014-05-15 14:53:30 +0100 | [diff] [blame] | 95 | plat/fvp/bl31_fvp_setup.c \ |
Dan Handley | ea45157 | 2014-05-15 14:53:30 +0100 | [diff] [blame] | 96 | plat/fvp/fvp_pm.c \ |
Vikram Kanigiri | cf79bf5 | 2014-06-02 14:59:00 +0100 | [diff] [blame] | 97 | plat/fvp/fvp_security.c \ |
Dan Handley | ea45157 | 2014-05-15 14:53:30 +0100 | [diff] [blame] | 98 | plat/fvp/fvp_topology.c \ |
| 99 | plat/fvp/aarch64/fvp_helpers.S \ |
| 100 | plat/fvp/aarch64/fvp_common.c \ |
Dan Handley | 176e7b4 | 2014-04-15 18:20:09 +0100 | [diff] [blame] | 101 | plat/fvp/drivers/pwrc/fvp_pwrc.c |