Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
Menu
Open sidebar
adam.huang
Arm Trusted Firmware
Commits
ba0248b5
Unverified
Commit
ba0248b5
authored
Jul 19, 2018
by
danh-arm
Committed by
GitHub
Jul 19, 2018
Browse files
Merge pull request #1450 from MISL-EBU-System-SW/marvell-support-v6
Marvell support for Armada 8K SoC family
parents
992a3536
23e0fe52
Changes
116
Hide whitespace changes
Inline
Side-by-side
include/drivers/marvell/mochi/ap_setup.h
0 → 100644
View file @
ba0248b5
/*
* Copyright (C) 2018 Marvell International Ltd.
*
* SPDX-License-Identifier: BSD-3-Clause
* https://spdx.org/licenses
*/
/* AP8xx Marvell SoC driver */
#ifndef __AP_SETUP_H__
#define __AP_SETUP_H__
void
ap_init
(
void
);
void
ap_ble_init
(
void
);
int
ap_get_count
(
void
);
#endif
/* __AP_SETUP_H__ */
include/drivers/marvell/mochi/cp110_setup.h
0 → 100644
View file @
ba0248b5
/*
* Copyright (C) 2018 Marvell International Ltd.
*
* SPDX-License-Identifier: BSD-3-Clause
* https://spdx.org/licenses
*/
/* CP110 Marvell SoC driver */
#ifndef __CP110_SETUP_H__
#define __CP110_SETUP_H__
#include <mmio.h>
#include <mvebu_def.h>
#define MVEBU_DEVICE_ID_REG (MVEBU_CP_DFX_OFFSET + 0x40)
#define MVEBU_DEVICE_ID_OFFSET (0)
#define MVEBU_DEVICE_ID_MASK (0xffff << MVEBU_DEVICE_ID_OFFSET)
#define MVEBU_DEVICE_REV_OFFSET (16)
#define MVEBU_DEVICE_REV_MASK (0xf << MVEBU_DEVICE_REV_OFFSET)
#define MVEBU_70X0_DEV_ID (0x7040)
#define MVEBU_70X0_CP115_DEV_ID (0x7045)
#define MVEBU_80X0_DEV_ID (0x8040)
#define MVEBU_80X0_CP115_DEV_ID (0x8045)
#define MVEBU_CP110_SA_DEV_ID (0x110)
#define MVEBU_CP110_REF_ID_A1 1
#define MVEBU_CP110_REF_ID_A2 2
#define MAX_STREAM_ID_PER_CP (0x10)
#define STREAM_ID_BASE (0x40)
static
inline
uint32_t
cp110_device_id_get
(
uintptr_t
base
)
{
/* Returns:
* - MVEBU_70X0_DEV_ID for A70X0 family
* - MVEBU_80X0_DEV_ID for A80X0 family
* - MVEBU_CP110_SA_DEV_ID for CP that connected stand alone
*/
return
(
mmio_read_32
(
base
+
MVEBU_DEVICE_ID_REG
)
>>
MVEBU_DEVICE_ID_OFFSET
)
&
MVEBU_DEVICE_ID_MASK
;
}
static
inline
uint32_t
cp110_rev_id_get
(
uintptr_t
base
)
{
return
(
mmio_read_32
(
base
+
MVEBU_DEVICE_ID_REG
)
&
MVEBU_DEVICE_REV_MASK
)
>>
MVEBU_DEVICE_REV_OFFSET
;
}
void
cp110_init
(
uintptr_t
cp110_base
,
uint32_t
stream_id
);
void
cp110_ble_init
(
uintptr_t
cp110_base
);
#endif
/* __CP110_SETUP_H__ */
include/drivers/marvell/thermal.h
0 → 100644
View file @
ba0248b5
/*
* Copyright (C) 2018 Marvell International Ltd.
*
* SPDX-License-Identifier: BSD-3-Clause
* https://spdx.org/licenses
*/
/* Driver for thermal unit located in Marvell ARMADA 8K and compatible SoCs */
#ifndef _THERMAL_H
#define _THERMAL_H
struct
tsen_config
{
/* thermal temperature parameters */
int
tsen_offset
;
int
tsen_gain
;
int
tsen_divisor
;
/* thermal data */
int
tsen_ready
;
void
*
regs_base
;
/* thermal functionality */
int
(
*
ptr_tsen_probe
)(
struct
tsen_config
*
cfg
);
int
(
*
ptr_tsen_read
)(
struct
tsen_config
*
cfg
,
int
*
temp
);
};
/* Thermal driver APIs */
int
marvell_thermal_init
(
struct
tsen_config
*
tsen_cfg
);
int
marvell_thermal_read
(
struct
tsen_config
*
tsen_cfg
,
int
*
temp
);
struct
tsen_config
*
marvell_thermal_config_get
(
void
);
#endif
/* _THERMAL_H */
include/lib/cpus/aarch64/cortex_a72.h
View file @
ba0248b5
...
...
@@ -37,6 +37,13 @@
#define CORTEX_A72_CPUACTLR_EL1_DCC_AS_DCCI (ULL(1) << 44)
#define CORTEX_A72_CPUACTLR_EL1_DIS_INSTR_PREFETCH (ULL(1) << 32)
/*******************************************************************************
* L2 Auxiliary Control register specific definitions.
******************************************************************************/
#define CORTEX_A72_L2ACTLR_EL1 S3_1_C15_C0_0
#define CORTEX_A72_L2ACTLR_ENABLE_UNIQUE_CLEAN (ULL(1) << 14)
/*******************************************************************************
* L2 Control register specific definitions.
******************************************************************************/
...
...
include/plat/marvell/a8k/common/a8k_common.h
0 → 100644
View file @
ba0248b5
/*
* Copyright (C) 2018 Marvell International Ltd.
*
* SPDX-License-Identifier: BSD-3-Clause
* https://spdx.org/licenses
*/
#ifndef __A8K_COMMON_H__
#define __A8K_COMMON_H__
#include <amb_adec.h>
#include <io_win.h>
#include <iob.h>
#include <ccu.h>
/*
* This struct supports skip image request
* detection_method: the method used to detect the request "signal".
* info:
* GPIO:
* detection_method: HIGH (pressed button), LOW (unpressed button),
* num (button mpp number).
* i2c:
* i2c_addr: the address of the i2c chosen.
* i2d_reg: the i2c register chosen.
* test:
* choose the DIE you picked the button in (AP or CP).
* in case of CP(cp_index = 0 if CP0, cp_index = 1 if CP1)
*/
struct
skip_image
{
enum
{
GPIO
,
I2C
,
USER_DEFINED
}
detection_method
;
struct
{
struct
{
int
num
;
enum
{
HIGH
,
LOW
}
button_state
;
}
gpio
;
struct
{
int
i2c_addr
;
int
i2c_reg
;
}
i2c
;
struct
{
enum
{
CP
,
AP
}
cp_ap
;
int
cp_index
;
}
test
;
}
info
;
};
/*
* This struct supports SoC power off method
* type: the method used to power off the SoC
* cfg:
* PMIC_GPIO:
* pin_count: current GPIO pin number used for toggling the signal for
* notifying external PMIC
* info: holds the GPIOs information, CP GPIO should be used and
* all GPIOs should be within same GPIO config. register
* step_count: current step number to toggle the GPIO for PMIC
* seq: GPIO toggling values in sequence, each bit represents a GPIO.
* For example, bit0 represents first GPIO used for toggling
* the GPIO the last step is used to trigger the power off
* signal
* delay_ms: transition interval for the GPIO setting to take effect
* in unit of ms
*/
/* Max GPIO number used to notify PMIC to power off the SoC */
#define PMIC_GPIO_MAX_NUMBER 8
/* Max GPIO toggling steps in sequence to power off the SoC */
#define PMIC_GPIO_MAX_TOGGLE_STEP 8
enum
gpio_output_state
{
GPIO_LOW
=
0
,
GPIO_HIGH
};
typedef
struct
gpio_info
{
int
cp_index
;
int
gpio_index
;
}
gpio_info_t
;
struct
power_off_method
{
enum
{
PMIC_GPIO
,
}
type
;
struct
{
struct
{
int
pin_count
;
struct
gpio_info
info
[
PMIC_GPIO_MAX_NUMBER
];
int
step_count
;
uint32_t
seq
[
PMIC_GPIO_MAX_TOGGLE_STEP
];
int
delay_ms
;
}
gpio
;
}
cfg
;
};
int
marvell_gpio_config
(
void
);
uint32_t
marvell_get_io_win_gcr_target
(
int
ap_idx
);
uint32_t
marvell_get_ccu_gcr_target
(
int
ap_idx
);
/*
* The functions below are defined as Weak and may be overridden
* in specific Marvell standard platform
*/
int
marvell_get_amb_memory_map
(
struct
addr_map_win
**
win
,
uint32_t
*
size
,
uintptr_t
base
);
int
marvell_get_io_win_memory_map
(
int
ap_idx
,
struct
addr_map_win
**
win
,
uint32_t
*
size
);
int
marvell_get_iob_memory_map
(
struct
addr_map_win
**
win
,
uint32_t
*
size
,
uintptr_t
base
);
int
marvell_get_ccu_memory_map
(
int
ap_idx
,
struct
addr_map_win
**
win
,
uint32_t
*
size
);
#endif
/* __A8K_COMMON_H__ */
include/plat/marvell/a8k/common/board_marvell_def.h
0 → 100644
View file @
ba0248b5
/*
* Copyright (C) 2018 Marvell International Ltd.
*
* SPDX-License-Identifier: BSD-3-Clause
* https://spdx.org/licenses
*/
#ifndef __BOARD_MARVELL_DEF_H__
#define __BOARD_MARVELL_DEF_H__
/*
* Required platform porting definitions common to all ARM
* development platforms
*/
/* Size of cacheable stacks */
#if DEBUG_XLAT_TABLE
# define PLATFORM_STACK_SIZE 0x800
#elif IMAGE_BL1
#if TRUSTED_BOARD_BOOT
# define PLATFORM_STACK_SIZE 0x1000
#else
# define PLATFORM_STACK_SIZE 0x440
#endif
#elif IMAGE_BL2
# if TRUSTED_BOARD_BOOT
# define PLATFORM_STACK_SIZE 0x1000
# else
# define PLATFORM_STACK_SIZE 0x400
# endif
#elif IMAGE_BL31
# define PLATFORM_STACK_SIZE 0x400
#elif IMAGE_BL32
# define PLATFORM_STACK_SIZE 0x440
#endif
/*
* PLAT_MARVELL_MMAP_ENTRIES depends on the number of entries in the
* plat_arm_mmap array defined for each BL stage.
*/
#if IMAGE_BLE
# define PLAT_MARVELL_MMAP_ENTRIES 3
#endif
#if IMAGE_BL1
# if TRUSTED_BOARD_BOOT
# define PLAT_MARVELL_MMAP_ENTRIES 7
# else
# define PLAT_MARVELL_MMAP_ENTRIES 6
# endif
/* TRUSTED_BOARD_BOOT */
#endif
#if IMAGE_BL2
# define PLAT_MARVELL_MMAP_ENTRIES 8
#endif
#if IMAGE_BL31
#define PLAT_MARVELL_MMAP_ENTRIES 5
#endif
/*
* Platform specific page table and MMU setup constants
*/
#if IMAGE_BL1
#define MAX_XLAT_TABLES 4
#elif IMAGE_BLE
# define MAX_XLAT_TABLES 4
#elif IMAGE_BL2
# define MAX_XLAT_TABLES 4
#elif IMAGE_BL31
# define MAX_XLAT_TABLES 4
#elif IMAGE_BL32
# define MAX_XLAT_TABLES 4
#endif
#define MAX_IO_DEVICES 3
#define MAX_IO_HANDLES 4
#define PLAT_MARVELL_TRUSTED_SRAM_SIZE 0x80000
/* 512 KB */
#endif
/* __BOARD_MARVELL_DEF_H__ */
include/plat/marvell/a8k/common/marvell_def.h
0 → 100644
View file @
ba0248b5
/*
* Copyright (C) 2018 Marvell International Ltd.
*
* SPDX-License-Identifier: BSD-3-Clause
* https://spdx.org/licenses
*/
#ifndef __MARVELL_DEF_H__
#define __MARVELL_DEF_H__
#include <arch.h>
#include <common_def.h>
#include <platform_def.h>
#include <tbbr_img_def.h>
#include <xlat_tables.h>
/******************************************************************************
* Definitions common to all MARVELL standard platforms
*****************************************************************************/
/* Special value used to verify platform parameters from BL2 to BL31 */
#define MARVELL_BL31_PLAT_PARAM_VAL 0x0f1e2d3c4b5a6978ULL
#define MARVELL_CACHE_WRITEBACK_SHIFT 6
/*
* Macros mapping the MPIDR Affinity levels to MARVELL Platform Power levels.
* The power levels have a 1:1 mapping with the MPIDR affinity levels.
*/
#define MARVELL_PWR_LVL0 MPIDR_AFFLVL0
#define MARVELL_PWR_LVL1 MPIDR_AFFLVL1
#define MARVELL_PWR_LVL2 MPIDR_AFFLVL2
/*
* Macros for local power states in Marvell platforms encoded by
* State-ID field within the power-state parameter.
*/
/* Local power state for power domains in Run state. */
#define MARVELL_LOCAL_STATE_RUN 0
/* Local power state for retention. Valid only for CPU power domains */
#define MARVELL_LOCAL_STATE_RET 1
/*
* Local power state for OFF/power-down. Valid for CPU
* and cluster power domains
*/
#define MARVELL_LOCAL_STATE_OFF 2
/* The first 4KB of Trusted SRAM are used as shared memory */
#define MARVELL_TRUSTED_SRAM_BASE PLAT_MARVELL_ATF_BASE
#define MARVELL_SHARED_RAM_BASE MARVELL_TRUSTED_SRAM_BASE
#define MARVELL_SHARED_RAM_SIZE 0x00001000
/* 4 KB */
/* The remaining Trusted SRAM is used to load the BL images */
#define MARVELL_BL_RAM_BASE (MARVELL_SHARED_RAM_BASE + \
MARVELL_SHARED_RAM_SIZE)
#define MARVELL_BL_RAM_SIZE (PLAT_MARVELL_TRUSTED_SRAM_SIZE - \
MARVELL_SHARED_RAM_SIZE)
/* Non-shared DRAM */
#define MARVELL_DRAM_BASE ULL(0x0)
#define MARVELL_DRAM_SIZE ULL(0x80000000)
#define MARVELL_DRAM_END (MARVELL_DRAM_BASE + \
MARVELL_DRAM_SIZE - 1)
#define MARVELL_IRQ_SEC_PHY_TIMER 29
#define MARVELL_IRQ_SEC_SGI_0 8
#define MARVELL_IRQ_SEC_SGI_1 9
#define MARVELL_IRQ_SEC_SGI_2 10
#define MARVELL_IRQ_SEC_SGI_3 11
#define MARVELL_IRQ_SEC_SGI_4 12
#define MARVELL_IRQ_SEC_SGI_5 13
#define MARVELL_IRQ_SEC_SGI_6 14
#define MARVELL_IRQ_SEC_SGI_7 15
#define MARVELL_MAP_SHARED_RAM MAP_REGION_FLAT( \
MARVELL_SHARED_RAM_BASE,\
MARVELL_SHARED_RAM_SIZE,\
MT_MEMORY | MT_RW | MT_SECURE)
#define MARVELL_MAP_DRAM MAP_REGION_FLAT( \
MARVELL_DRAM_BASE, \
MARVELL_DRAM_SIZE, \
MT_MEMORY | MT_RW | MT_NS)
/*
* The number of regions like RO(code), coherent and data required by
* different BL stages which need to be mapped in the MMU.
*/
#if USE_COHERENT_MEM
#define MARVELL_BL_REGIONS 3
#else
#define MARVELL_BL_REGIONS 2
#endif
#define MAX_MMAP_REGIONS (PLAT_MARVELL_MMAP_ENTRIES + \
MARVELL_BL_REGIONS)
#define MARVELL_CONSOLE_BAUDRATE 115200
/******************************************************************************
* Required platform porting definitions common to all MARVELL std. platforms
*****************************************************************************/
#define PLAT_PHY_ADDR_SPACE_SIZE (1ULL << 32)
#define PLAT_VIRT_ADDR_SPACE_SIZE (1ULL << 32)
/*
* This macro defines the deepest retention state possible. A higher state
* id will represent an invalid or a power down state.
*/
#define PLAT_MAX_RET_STATE MARVELL_LOCAL_STATE_RET
/*
* This macro defines the deepest power down states possible. Any state ID
* higher than this is invalid.
*/
#define PLAT_MAX_OFF_STATE MARVELL_LOCAL_STATE_OFF
#define PLATFORM_CORE_COUNT PLAT_MARVELL_CORE_COUNT
#define PLAT_NUM_PWR_DOMAINS (PLAT_MARVELL_CLUSTER_COUNT + \
PLATFORM_CORE_COUNT)
/*
* Some data must be aligned on the biggest cache line size in the platform.
* This is known only to the platform as it might have a combination of
* integrated and external caches.
*/
#define CACHE_WRITEBACK_GRANULE (1 << MARVELL_CACHE_WRITEBACK_SHIFT)
/*******************************************************************************
* BL1 specific defines.
* BL1 RW data is relocated from ROM to RAM at runtime so we need 2 sets of
* addresses.
******************************************************************************/
#define BL1_RO_BASE PLAT_MARVELL_TRUSTED_ROM_BASE
#define BL1_RO_LIMIT (PLAT_MARVELL_TRUSTED_ROM_BASE \
+ PLAT_MARVELL_TRUSTED_ROM_SIZE)
/*
* Put BL1 RW at the top of the Trusted SRAM.
*/
#define BL1_RW_BASE (MARVELL_BL_RAM_BASE + \
MARVELL_BL_RAM_SIZE - \
PLAT_MARVELL_MAX_BL1_RW_SIZE)
#define BL1_RW_LIMIT (MARVELL_BL_RAM_BASE + MARVELL_BL_RAM_SIZE)
/*******************************************************************************
* BLE specific defines.
******************************************************************************/
#define BLE_BASE PLAT_MARVELL_SRAM_BASE
#define BLE_LIMIT PLAT_MARVELL_SRAM_END
/*******************************************************************************
* BL2 specific defines.
******************************************************************************/
/*
* Put BL2 just below BL31.
*/
#define BL2_BASE (BL31_BASE - PLAT_MARVELL_MAX_BL2_SIZE)
#define BL2_LIMIT BL31_BASE
/*******************************************************************************
* BL31 specific defines.
******************************************************************************/
/*
* Put BL31 at the top of the Trusted SRAM.
*/
#define BL31_BASE (MARVELL_BL_RAM_BASE + \
MARVELL_BL_RAM_SIZE - \
PLAT_MARVEL_MAX_BL31_SIZE)
#define BL31_PROGBITS_LIMIT BL1_RW_BASE
#define BL31_LIMIT (MARVELL_BL_RAM_BASE + \
MARVELL_BL_RAM_SIZE)
#endif
/* __MARVELL_DEF_H__ */
include/plat/marvell/a8k/common/plat_marvell.h
0 → 100644
View file @
ba0248b5
/*
* Copyright (C) 2018 Marvell International Ltd.
*
* SPDX-License-Identifier: BSD-3-Clause
* https://spdx.org/licenses
*/
#ifndef __PLAT_MARVELL_H__
#define __PLAT_MARVELL_H__
#include <cassert.h>
#include <cpu_data.h>
#include <stdint.h>
#include <utils.h>
#include <xlat_tables.h>
/*
* Extern declarations common to Marvell standard platforms
*/
extern
const
mmap_region_t
plat_marvell_mmap
[];
#define MARVELL_CASSERT_MMAP \
CASSERT((ARRAY_SIZE(plat_marvell_mmap) + MARVELL_BL_REGIONS) \
<= MAX_MMAP_REGIONS, \
assert_max_mmap_regions)
/*
* Utility functions common to Marvell standard platforms
*/
void
marvell_setup_page_tables
(
uintptr_t
total_base
,
size_t
total_size
,
uintptr_t
code_start
,
uintptr_t
code_limit
,
uintptr_t
rodata_start
,
uintptr_t
rodata_limit
#if USE_COHERENT_MEM
,
uintptr_t
coh_start
,
uintptr_t
coh_limit
#endif
);
/* IO storage utility functions */
void
marvell_io_setup
(
void
);
/* Systimer utility function */
void
marvell_configure_sys_timer
(
void
);
/* Topology utility function */
int
marvell_check_mpidr
(
u_register_t
mpidr
);
/* BLE utility functions */
int
ble_plat_setup
(
int
*
skip
);
void
plat_marvell_dram_update_topology
(
void
);
void
ble_plat_pcie_ep_setup
(
void
);
struct
pci_hw_cfg
*
plat_get_pcie_hw_data
(
void
);
/* BL1 utility functions */
void
marvell_bl1_early_platform_setup
(
void
);
void
marvell_bl1_platform_setup
(
void
);
void
marvell_bl1_plat_arch_setup
(
void
);
/* BL2 utility functions */
void
marvell_bl2_early_platform_setup
(
meminfo_t
*
mem_layout
);
void
marvell_bl2_platform_setup
(
void
);
void
marvell_bl2_plat_arch_setup
(
void
);
uint32_t
marvell_get_spsr_for_bl32_entry
(
void
);
uint32_t
marvell_get_spsr_for_bl33_entry
(
void
);
/* BL31 utility functions */
void
marvell_bl31_early_platform_setup
(
bl31_params_t
*
from_bl2
,
void
*
plat_params_from_bl2
);
void
marvell_bl31_platform_setup
(
void
);
void
marvell_bl31_plat_runtime_setup
(
void
);
void
marvell_bl31_plat_arch_setup
(
void
);
/* Power management config to power off the SoC */
void
*
plat_marvell_get_pm_cfg
(
void
);
/* Check if MSS AP CM3 firmware contains PM support */
_Bool
is_pm_fw_running
(
void
);
/* Bootrom image recovery utility functions */
void
*
plat_marvell_get_skip_image_data
(
void
);
/* FIP TOC validity check */
int
marvell_io_is_toc_valid
(
void
);
/*
* PSCI functionality
*/
void
marvell_psci_arch_init
(
int
ap_idx
);
void
plat_marvell_system_reset
(
void
);
/*
* Optional functions required in Marvell standard platforms
*/
void
plat_marvell_io_setup
(
void
);
int
plat_marvell_get_alt_image_source
(
unsigned
int
image_id
,
uintptr_t
*
dev_handle
,
uintptr_t
*
image_spec
);
unsigned
int
plat_marvell_calc_core_pos
(
u_register_t
mpidr
);
const
mmap_region_t
*
plat_marvell_get_mmap
(
void
);
void
marvell_ble_prepare_exit
(
void
);
void
marvell_exit_bootrom
(
uintptr_t
base
);
int
plat_marvell_early_cpu_powerdown
(
void
);
#endif
/* __PLAT_MARVELL_H__ */
include/plat/marvell/a8k/common/plat_pm_trace.h
0 → 100644
View file @
ba0248b5
/*
* Copyright (C) 2018 Marvell International Ltd.
*
* SPDX-License-Identifier: BSD-3-Clause
* https://spdx.org/licenses
*/
#ifndef __PLAT_PM_TRACE_H
#define __PLAT_PM_TRACE_H
/*
* PM Trace is for Debug purpose only!!!
* It should not be enabled during System Run time
*/
#undef PM_TRACE_ENABLE
/* trace entry time */
struct
pm_trace_entry
{
/* trace entry time stamp */
unsigned
int
timestamp
;
/* trace info
* [16-31] - API Trace Id
* [00-15] - API Step Id
*/
unsigned
int
trace_info
;
};
struct
pm_trace_ctrl
{
/* trace pointer - points to next free entry in trace cyclic queue */
unsigned
int
trace_pointer
;
/* trace count - number of entries in the queue, clear upon read */
unsigned
int
trace_count
;
};
/* trace size definition */
#define AP_MSS_ATF_CORE_INFO_SIZE (256)
#define AP_MSS_ATF_CORE_ENTRY_SIZE (8)
#define AP_MSS_ATF_TRACE_SIZE_MASK (0xFF)
/* trace address definition */
#define AP_MSS_TIMER_BASE (MVEBU_REGS_BASE_MASK + 0x580110)
#define AP_MSS_ATF_CORE_0_CTRL_BASE (MVEBU_REGS_BASE_MASK + 0x520140)
#define AP_MSS_ATF_CORE_1_CTRL_BASE (MVEBU_REGS_BASE_MASK + 0x520150)
#define AP_MSS_ATF_CORE_2_CTRL_BASE (MVEBU_REGS_BASE_MASK + 0x520160)
#define AP_MSS_ATF_CORE_3_CTRL_BASE (MVEBU_REGS_BASE_MASK + 0x520170)
#define AP_MSS_ATF_CORE_CTRL_BASE (AP_MSS_ATF_CORE_0_CTRL_BASE)
#define AP_MSS_ATF_CORE_0_INFO_BASE (MVEBU_REGS_BASE_MASK + 0x5201C0)
#define AP_MSS_ATF_CORE_0_INFO_TRACE (MVEBU_REGS_BASE_MASK + 0x5201C4)
#define AP_MSS_ATF_CORE_1_INFO_BASE (MVEBU_REGS_BASE_MASK + 0x5209C0)
#define AP_MSS_ATF_CORE_1_INFO_TRACE (MVEBU_REGS_BASE_MASK + 0x5209C4)
#define AP_MSS_ATF_CORE_2_INFO_BASE (MVEBU_REGS_BASE_MASK + 0x5211C0)
#define AP_MSS_ATF_CORE_2_INFO_TRACE (MVEBU_REGS_BASE_MASK + 0x5211C4)
#define AP_MSS_ATF_CORE_3_INFO_BASE (MVEBU_REGS_BASE_MASK + 0x5219C0)
#define AP_MSS_ATF_CORE_3_INFO_TRACE (MVEBU_REGS_BASE_MASK + 0x5219C4)
#define AP_MSS_ATF_CORE_INFO_BASE (AP_MSS_ATF_CORE_0_INFO_BASE)
/* trace info definition */
#define TRACE_PWR_DOMAIN_OFF (0x10000)
#define TRACE_PWR_DOMAIN_SUSPEND (0x20000)
#define TRACE_PWR_DOMAIN_SUSPEND_FINISH (0x30000)
#define TRACE_PWR_DOMAIN_ON (0x40000)
#define TRACE_PWR_DOMAIN_ON_FINISH (0x50000)
#define TRACE_PWR_DOMAIN_ON_MASK (0xFF)
#ifdef PM_TRACE_ENABLE
/* trace API definition */
void
pm_core_0_trace
(
unsigned
int
trace
);
void
pm_core_1_trace
(
unsigned
int
trace
);
void
pm_core_2_trace
(
unsigned
int
trace
);
void
pm_core_3_trace
(
unsigned
int
trace
);
typedef
void
(
*
core_trace_func
)(
unsigned
int
);
extern
core_trace_func
funcTbl
[
PLATFORM_CORE_COUNT
];
#define PM_TRACE(trace) funcTbl[plat_my_core_pos()](trace)
#else
#define PM_TRACE(trace)
#endif
/*******************************************************************************
* pm_trace_add
*
* DESCRIPTION: Add PM trace
******************************************************************************
*/
void
pm_trace_add
(
unsigned
int
trace
,
unsigned
int
core
);
#endif
/* __PLAT_PM_TRACE_H */
include/plat/marvell/common/aarch64/cci_macros.S
0 → 100644
View file @
ba0248b5
/*
*
Copyright
(
C
)
2018
Marvell
International
Ltd
.
*
*
SPDX
-
License
-
Identifier
:
BSD
-
3
-
Clause
*
https
:
//
spdx
.
org
/
licenses
*/
#ifndef __CCI_MACROS_S__
#define __CCI_MACROS_S__
#include <cci.h>
#include <platform_def.h>
.
section
.
rodata.
cci_reg_name
,
"aS"
cci_iface_regs
:
.
asciz
"cci_snoop_ctrl_cluster0"
,
"cci_snoop_ctrl_cluster1"
,
""
/
*
------------------------------------------------
*
The
below
required
platform
porting
macro
prints
*
out
relevant
interconnect
registers
whenever
an
*
unhandled
exception
is
taken
in
BL31
.
*
Clobbers
:
x0
-
x9
,
sp
*
------------------------------------------------
*/
.
macro
print_cci_regs
adr
x6
,
cci_iface_regs
/
*
Store
in
x7
the
base
address
of
the
first
interface
*/
mov_imm
x7
,
(
PLAT_MARVELL_CCI_BASE
+
SLAVE_IFACE_OFFSET
(
\
PLAT_MARVELL_CCI_CLUSTER0_SL_IFACE_IX
))
ldr
w8
,
[
x7
,
#
SNOOP_CTRL_REG
]
/
*
Store
in
x7
the
base
address
of
the
second
interface
*/
mov_imm
x7
,
(
PLAT_MARVELL_CCI_BASE
+
SLAVE_IFACE_OFFSET
(
\
PLAT_MARVELL_CCI_CLUSTER1_SL_IFACE_IX
))
ldr
w9
,
[
x7
,
#
SNOOP_CTRL_REG
]
/
*
Store
to
the
crash
buf
and
print
to
console
*/
bl
str_in_crash_buf_print
.
endm
#endif /* __CCI_MACROS_S__ */
include/plat/marvell/common/aarch64/marvell_macros.S
0 → 100644
View file @
ba0248b5
/*
*
Copyright
(
C
)
2018
Marvell
International
Ltd
.
*
*
SPDX
-
License
-
Identifier
:
BSD
-
3
-
Clause
*
https
:
//
spdx
.
org
/
licenses
*/
#ifndef __MARVELL_MACROS_S__
#define __MARVELL_MACROS_S__
#include <cci.h>
#include <gic_common.h>
#include <gicv2.h>
#include <gicv3.h>
#include <platform_def.h>
/*
*
These
Macros
are
required
by
ATF
*/
.
section
.
rodata.
gic_reg_name
,
"aS"
/*
Applicable
only
to
GICv2
and
GICv3
with
SRE
disabled
(
legacy
mode
)
*/
gicc_regs
:
.
asciz
"gicc_hppir"
,
"gicc_ahppir"
,
"gicc_ctlr"
,
""
#ifdef USE_CCI
/*
Applicable
only
to
GICv3
with
SRE
enabled
*/
icc_regs
:
.
asciz
"icc_hppir0_el1"
,
"icc_hppir1_el1"
,
"icc_ctlr_el3"
,
""
#endif
/*
Registers
common
to
both
GICv2
and
GICv3
*/
gicd_pend_reg
:
.
asciz
"gicd_ispendr regs (Offsets 0x200 - 0x278)\n"
\
"
Offset
:\
t
\
t
\
tvalue
\
n
"
newline
:
.
asciz
"\n"
spacer
:
.
asciz
":\t\t0x"
/
*
---------------------------------------------
*
The
below
utility
macro
prints
out
relevant
GIC
*
registers
whenever
an
unhandled
exception
is
*
taken
in
BL31
on
ARM
standard
platforms
.
*
Expects
:
GICD
base
in
x16
,
GICC
base
in
x17
*
Clobbers
:
x0
-
x10
,
sp
*
---------------------------------------------
*/
.
macro
arm_print_gic_regs
/
*
Check
for
GICv3
system
register
access
*/
mrs
x7
,
id_aa64pfr0_el1
ubfx
x7
,
x7
,
#
ID_AA64PFR0_GIC_SHIFT
,
#
ID_AA64PFR0_GIC_WIDTH
cmp
x7
,
#
1
b.ne
print_gicv2
/
*
Check
for
SRE
enable
*/
mrs
x8
,
ICC_SRE_EL3
tst
x8
,
#
ICC_SRE_SRE_BIT
b.eq
print_gicv2
#ifdef USE_CCI
/
*
Load
the
icc
reg
list
to
x6
*/
adr
x6
,
icc_regs
/
*
Load
the
icc
regs
to
gp
regs
used
by
str_in_crash_buf_print
*/
mrs
x8
,
ICC_HPPIR0_EL1
mrs
x9
,
ICC_HPPIR1_EL1
mrs
x10
,
ICC_CTLR_EL3
/
*
Store
to
the
crash
buf
and
print
to
console
*/
bl
str_in_crash_buf_print
#endif
b
print_gic_common
print_gicv2
:
/
*
Load
the
gicc
reg
list
to
x6
*/
adr
x6
,
gicc_regs
/
*
Load
the
gicc
regs
to
gp
regs
used
by
str_in_crash_buf_print
*/
ldr
w8
,
[
x17
,
#
GICC_HPPIR
]
ldr
w9
,
[
x17
,
#
GICC_AHPPIR
]
ldr
w10
,
[
x17
,
#
GICC_CTLR
]
/
*
Store
to
the
crash
buf
and
print
to
console
*/
bl
str_in_crash_buf_print
print_gic_common
:
/
*
Print
the
GICD_ISPENDR
regs
*/
add
x7
,
x16
,
#
GICD_ISPENDR
adr
x4
,
gicd_pend_reg
bl
asm_print_str
gicd_ispendr_loop
:
sub
x4
,
x7
,
x16
cmp
x4
,
#
0x280
b.eq
exit_print_gic_regs
bl
asm_print_hex
adr
x4
,
spacer
bl
asm_print_str
ldr
x4
,
[
x7
],
#
8
bl
asm_print_hex
adr
x4
,
newline
bl
asm_print_str
b
gicd_ispendr_loop
exit_print_gic_regs
:
.
endm
.
section
.
rodata.
cci_reg_name
,
"aS"
cci_iface_regs
:
.
asciz
"cci_snoop_ctrl_cluster0"
,
"cci_snoop_ctrl_cluster1"
,
""
/
*
------------------------------------------------
*
The
below
required
platform
porting
macro
prints
*
out
relevant
interconnect
registers
whenever
an
*
unhandled
exception
is
taken
in
BL31
.
*
Clobbers
:
x0
-
x9
,
sp
*
------------------------------------------------
*/
.
macro
print_cci_regs
#ifdef USE_CCI
adr
x6
,
cci_iface_regs
/
*
Store
in
x7
the
base
address
of
the
first
interface
*/
mov_imm
x7
,
(
PLAT_MARVELL_CCI_BASE
+
SLAVE_IFACE_OFFSET
(
\
PLAT_MARVELL_CCI_CLUSTER0_SL_IFACE_IX
))
ldr
w8
,
[
x7
,
#
SNOOP_CTRL_REG
]
/
*
Store
in
x7
the
base
address
of
the
second
interface
*/
mov_imm
x7
,
(
PLAT_MARVELL_CCI_BASE
+
SLAVE_IFACE_OFFSET
(
\
PLAT_MARVELL_CCI_CLUSTER1_SL_IFACE_IX
))
ldr
w9
,
[
x7
,
#
SNOOP_CTRL_REG
]
/
*
Store
to
the
crash
buf
and
print
to
console
*/
bl
str_in_crash_buf_print
#endif
.
endm
#endif /* __MARVELL_MACROS_S__ */
include/plat/marvell/common/marvell_plat_priv.h
0 → 100644
View file @
ba0248b5
/*
* Copyright (C) 2018 Marvell International Ltd.
*
* SPDX-License-Identifier: BSD-3-Clause
* https://spdx.org/licenses
*/
#ifndef __MARVELL_PLAT_PRIV_H__
#define __MARVELL_PLAT_PRIV_H__
#include <utils.h>
/*****************************************************************************
* Function and variable prototypes
*****************************************************************************
*/
void
plat_delay_timer_init
(
void
);
uint64_t
mvebu_get_dram_size
(
uint64_t
ap_base_addr
);
/*
* GIC operation, mandatory functions required in Marvell standard platforms
*/
void
plat_marvell_gic_driver_init
(
void
);
void
plat_marvell_gic_init
(
void
);
void
plat_marvell_gic_cpuif_enable
(
void
);
void
plat_marvell_gic_cpuif_disable
(
void
);
void
plat_marvell_gic_pcpu_init
(
void
);
void
plat_marvell_gic_irq_save
(
void
);
void
plat_marvell_gic_irq_restore
(
void
);
void
plat_marvell_gic_irq_pcpu_save
(
void
);
void
plat_marvell_gic_irq_pcpu_restore
(
void
);
#endif
/* __MARVELL_PLAT_PRIV_H__ */
include/plat/marvell/common/marvell_pm.h
0 → 100644
View file @
ba0248b5
/*
* Copyright (C) 2018 Marvell International Ltd.
*
* SPDX-License-Identifier: BSD-3-Clause
* https://spdx.org/licenses
*/
#ifndef _MARVELL_PM_H_
#define _MARVELL_PM_H_
#define MVEBU_MAILBOX_MAGIC_NUM PLAT_MARVELL_MAILBOX_MAGIC_NUM
#define MVEBU_MAILBOX_SUSPEND_STATE 0xb007de7c
/* Mailbox entry indexes */
/* Magic number for validity check */
#define MBOX_IDX_MAGIC 0
/* Recovery from suspend entry point */
#define MBOX_IDX_SEC_ADDR 1
/* Suspend state magic number */
#define MBOX_IDX_SUSPEND_MAGIC 2
/* Recovery jump address for ROM bypass */
#define MBOX_IDX_ROM_EXIT_ADDR 3
/* BLE execution start counter value */
#define MBOX_IDX_START_CNT 4
#endif
/* _MARVELL_PM_H_ */
include/plat/marvell/common/mvebu.h
0 → 100644
View file @
ba0248b5
/*
* Copyright (C) 2018 Marvell International Ltd.
*
* SPDX-License-Identifier: BSD-3-Clause
* https://spdx.org/licenses
*/
#ifndef _MVEBU_H_
#define _MVEBU_H_
/* Use this functions only when printf is allowed */
#define debug_enter() VERBOSE("----> Enter %s\n", __func__)
#define debug_exit() VERBOSE("<---- Exit %s\n", __func__)
/* Macro for testing alignment. Positive if number is NOT aligned */
#define IS_NOT_ALIGN(number, align) ((number) & ((align) - 1))
/* Macro for alignment up. For example, ALIGN_UP(0x0330, 0x20) = 0x0340 */
#define ALIGN_UP(number, align) (((number) & ((align) - 1)) ? \
(((number) + (align)) & ~((align)-1)) : (number))
/* Macro for testing whether a number is a power of 2. Positive if so */
#define IS_POWER_OF_2(number) ((number) != 0 && \
(((number) & ((number) - 1)) == 0))
/*
* Macro for ronding up to next power of 2
* it is done by count leading 0 (clz assembly opcode) and see msb set bit.
* then you can shift it left and get number which power of 2
* Note: this Macro is for 32 bit number
*/
#define ROUND_UP_TO_POW_OF_2(number) (1 << \
(32 - __builtin_clz((number) - 1)))
#define _1MB_ (1024ULL*1024ULL)
#define _1GB_ (_1MB_*1024ULL)
#endif
/* MVEBU_H */
maintainers.rst
View file @
ba0248b5
...
...
@@ -66,6 +66,14 @@ MediaTek platform ports
:G: `mtk09422`_
:F: plat/mediatek/
Marvell platform ports and SoC drivers
--------------------------------------
:M: Konstantin Porotchkin <kostap@marvell.com>
:G: `kostapr`_
:F: docs/plat/marvell/
:F: plat/marvell/
:F: drivers/marvell/
NVidia platform ports
---------------------
:M: Varun Wadekar <vwadekar@nvidia.com>
...
...
@@ -165,6 +173,7 @@ Xilinx platform port
.. _glneo: https://github.com/glneo
.. _hzhuang1: https://github.com/hzhuang1
.. _jenswi-linaro: https://github.com/jenswi-linaro
.. _kostapr: https://github.com/kostapr
.. _masahir0y: https://github.com/masahir0y
.. _mtk09422: https://github.com/mtk09422
.. _qoriq-open-source: https://github.com/qoriq-open-source
...
...
make_helpers/build_macros.mk
View file @
ba0248b5
...
...
@@ -290,6 +290,7 @@ define MAKE_BL
$(eval DUMP
:
= $(call IMG_DUMP
,
$(1)))
$(eval BIN
:
= $(call IMG_BIN
,
$(1)))
$(eval BL_LINKERFILE
:
= $(BL$(call uppercase
,
$(1))_LINKERFILE))
$(eval BL_LIBS
:
= $(BL$(call uppercase
,
$(1))_LIBS))
# We use sort only to get a list of unique object directory names.
# ordering is not relevant but sort removes duplicates.
$(eval TEMP_OBJ_DIRS
:
= $(sort $(dir ${OBJS} ${LINKERFILE})))
...
...
@@ -312,7 +313,7 @@ bl${1}_dirs: | ${OBJ_DIRS}
$(eval
$(call
MAKE_OBJS,$(BUILD_DIR),$(SOURCES),$(1)))
$(eval
$(call
MAKE_LD,$(LINKERFILE),$(BL_LINKERFILE),$(1)))
$(ELF)
:
$(OBJS) $(LINKERFILE) | bl$(1)_dirs
$(ELF)
:
$(OBJS) $(LINKERFILE) | bl$(1)_dirs
$(BL_LIBS)
@
echo
" LD
$$
@"
ifdef
MAKE_BUILD_STRINGS
$(
call
MAKE_BUILD_STRINGS,
$(BUILD_DIR)
/build_message.o
)
...
...
@@ -322,7 +323,7 @@ else
$
$(CC)
$
$(TF_CFLAGS)
$
$(CFLAGS)
-xc
-c
-
-o
$(BUILD_DIR)
/build_message.o
endif
$
$(Q)
$
$(LD)
-o
$$
@
$
$(TF_LDFLAGS)
$
$(LDFLAGS)
-Map
=
$(MAPFILE)
\
--script
$(LINKERFILE)
$(BUILD_DIR)
/build_message.o
$(OBJS)
$(LDLIBS)
--script
$(LINKERFILE)
$(BUILD_DIR)
/build_message.o
$(OBJS)
$(LDLIBS)
$(BL_LIBS)
$(DUMP)
:
$(ELF)
@
echo
" OD
$$
@"
...
...
plat/marvell/a8k/a70x0/board/dram_port.c
0 → 100644
View file @
ba0248b5
/*
* Copyright (C) 2018 Marvell International Ltd.
*
* SPDX-License-Identifier: BSD-3-Clause
* https://spdx.org/licenses
*/
#include <arch_helpers.h>
#include <debug.h>
#include <mv_ddr_if.h>
#include <plat_marvell.h>
/*
* This function may modify the default DRAM parameters
* based on information received from SPD or bootloader
* configuration located on non volatile storage
*/
void
plat_marvell_dram_update_topology
(
void
)
{
}
/*
* This struct provides the DRAM training code with
* the appropriate board DRAM configuration
*/
static
struct
mv_ddr_topology_map
board_topology_map
=
{
/* FIXME: MISL board 2CS 4Gb x8 devices of micron - 2133P */
DEBUG_LEVEL_ERROR
,
0x1
,
/* active interfaces */
/* cs_mask, mirror, dqs_swap, ck_swap X subphys */
{
{
{
{
0x3
,
0x2
,
0
,
0
},
{
0x3
,
0x2
,
0
,
0
},
{
0x3
,
0x2
,
0
,
0
},
{
0x3
,
0x2
,
0
,
0
},
{
0x3
,
0x2
,
0
,
0
},
{
0x3
,
0x2
,
0
,
0
},
{
0x3
,
0x2
,
0
,
0
},
{
0x3
,
0x2
,
0
,
0
},
{
0x3
,
0x2
,
0
,
0
}
},
SPEED_BIN_DDR_2133P
,
/* speed_bin */
MV_DDR_DEV_WIDTH_8BIT
,
/* sdram device width */
MV_DDR_DIE_CAP_4GBIT
,
/* die capacity */
MV_DDR_FREQ_SAR
,
/* frequency */
0
,
0
,
/* cas_l, cas_wl */
MV_DDR_TEMP_LOW
}
},
/* temperature */
MV_DDR_32BIT_ECC_PUP8_BUS_MASK
,
/* subphys mask */
MV_DDR_CFG_DEFAULT
,
/* ddr configuration data source */
{
{
0
}
},
/* raw spd data */
{
0
},
/* timing parameters */
{
/* electrical configuration */
{
/* memory electrical configuration */
MV_DDR_RTT_NOM_PARK_RZQ_DISABLE
,
/* rtt_nom */
{
MV_DDR_RTT_NOM_PARK_RZQ_DIV4
,
/* rtt_park 1cs */
MV_DDR_RTT_NOM_PARK_RZQ_DIV1
/* rtt_park 2cs */
},
{
MV_DDR_RTT_WR_DYN_ODT_OFF
,
/* rtt_wr 1cs */
MV_DDR_RTT_WR_RZQ_DIV2
/* rtt_wr 2cs */
},
MV_DDR_DIC_RZQ_DIV7
/* dic */
},
{
/* phy electrical configuration */
MV_DDR_OHM_30
,
/* data_drv_p */
MV_DDR_OHM_30
,
/* data_drv_n */
MV_DDR_OHM_30
,
/* ctrl_drv_p */
MV_DDR_OHM_30
,
/* ctrl_drv_n */
{
MV_DDR_OHM_60
,
/* odt_p 1cs */
MV_DDR_OHM_120
/* odt_p 2cs */
},
{
MV_DDR_OHM_60
,
/* odt_n 1cs */
MV_DDR_OHM_120
/* odt_n 2cs */
},
},
{
/* mac electrical configuration */
MV_DDR_ODT_CFG_NORMAL
,
/* odtcfg_pattern */
MV_DDR_ODT_CFG_ALWAYS_ON
,
/* odtcfg_write */
MV_DDR_ODT_CFG_NORMAL
,
/* odtcfg_read */
},
}
};
struct
mv_ddr_topology_map
*
mv_ddr_topology_map_get
(
void
)
{
/* Return the board topology as defined in the board code */
return
&
board_topology_map
;
}
plat/marvell/a8k/a70x0/board/marvell_plat_config.c
0 → 100644
View file @
ba0248b5
/*
* Copyright (C) 2018 Marvell International Ltd.
*
* SPDX-License-Identifier: BSD-3-Clause
* https://spdx.org/licenses
*/
#include <a8k_common.h>
/*
* If bootrom is currently at BLE there's no need to include the memory
* maps structure at this point
*/
#include <mvebu_def.h>
#ifndef IMAGE_BLE
/*****************************************************************************
* AMB Configuration
*****************************************************************************
*/
struct
addr_map_win
amb_memory_map
[]
=
{
/* CP0 SPI1 CS0 Direct Mode access */
{
0xf900
,
0x1000000
,
AMB_SPI1_CS0_ID
},
};
int
marvell_get_amb_memory_map
(
struct
addr_map_win
**
win
,
uint32_t
*
size
,
uintptr_t
base
)
{
*
win
=
amb_memory_map
;
if
(
*
win
==
NULL
)
*
size
=
0
;
else
*
size
=
ARRAY_SIZE
(
amb_memory_map
);
return
0
;
}
#endif
/*****************************************************************************
* IO_WIN Configuration
*****************************************************************************
*/
struct
addr_map_win
io_win_memory_map
[]
=
{
#ifndef IMAGE_BLE
/* MCI 0 indirect window */
{
MVEBU_MCI_REG_BASE_REMAP
(
0
),
0x100000
,
MCI_0_TID
},
/* MCI 1 indirect window */
{
MVEBU_MCI_REG_BASE_REMAP
(
1
),
0x100000
,
MCI_1_TID
},
#endif
};
uint32_t
marvell_get_io_win_gcr_target
(
int
ap_index
)
{
return
PIDI_TID
;
}
int
marvell_get_io_win_memory_map
(
int
ap_index
,
struct
addr_map_win
**
win
,
uint32_t
*
size
)
{
*
win
=
io_win_memory_map
;
if
(
*
win
==
NULL
)
*
size
=
0
;
else
*
size
=
ARRAY_SIZE
(
io_win_memory_map
);
return
0
;
}
#ifndef IMAGE_BLE
/*****************************************************************************
* IOB Configuration
*****************************************************************************
*/
struct
addr_map_win
iob_memory_map
[]
=
{
/* PEX1_X1 window */
{
0x00000000f7000000
,
0x1000000
,
PEX1_TID
},
/* PEX2_X1 window */
{
0x00000000f8000000
,
0x1000000
,
PEX2_TID
},
/* PEX0_X4 window */
{
0x00000000f6000000
,
0x1000000
,
PEX0_TID
},
/* SPI1_CS0 (RUNIT) window */
{
0x00000000f9000000
,
0x1000000
,
RUNIT_TID
},
};
int
marvell_get_iob_memory_map
(
struct
addr_map_win
**
win
,
uint32_t
*
size
,
uintptr_t
base
)
{
*
win
=
iob_memory_map
;
*
size
=
ARRAY_SIZE
(
iob_memory_map
);
return
0
;
}
#endif
/*****************************************************************************
* CCU Configuration
*****************************************************************************
*/
struct
addr_map_win
ccu_memory_map
[]
=
{
/* IO window */
#ifdef IMAGE_BLE
{
0x00000000f2000000
,
0x4000000
,
IO_0_TID
},
/* IO window */
#else
{
0x00000000f2000000
,
0xe000000
,
IO_0_TID
},
#endif
};
uint32_t
marvell_get_ccu_gcr_target
(
int
ap
)
{
return
DRAM_0_TID
;
}
int
marvell_get_ccu_memory_map
(
int
ap_index
,
struct
addr_map_win
**
win
,
uint32_t
*
size
)
{
*
win
=
ccu_memory_map
;
*
size
=
ARRAY_SIZE
(
ccu_memory_map
);
return
0
;
}
#ifdef IMAGE_BLE
/*****************************************************************************
* SKIP IMAGE Configuration
*****************************************************************************
*/
#if PLAT_RECOVERY_IMAGE_ENABLE
struct
skip_image
skip_im
=
{
.
detection_method
=
GPIO
,
.
info
.
gpio
.
num
=
33
,
.
info
.
gpio
.
button_state
=
HIGH
,
.
info
.
test
.
cp_ap
=
CP
,
.
info
.
test
.
cp_index
=
0
,
};
void
*
plat_marvell_get_skip_image_data
(
void
)
{
/* Return the skip_image configurations */
return
&
skip_im
;
}
#endif
#endif
plat/marvell/a8k/a70x0/mvebu_def.h
0 → 100644
View file @
ba0248b5
/*
* Copyright (C) 2018 Marvell International Ltd.
*
* SPDX-License-Identifier: BSD-3-Clause
* https://spdx.org/licenses
*/
#ifndef __MVEBU_DEF_H__
#define __MVEBU_DEF_H__
#include <a8k_plat_def.h>
#define CP_COUNT 1
/* A70x0 has single CP0 */
#endif
/* __MVEBU_DEF_H__ */
plat/marvell/a8k/a70x0/platform.mk
0 → 100644
View file @
ba0248b5
#
# Copyright (C) 2018 Marvell International Ltd.
#
# SPDX-License-Identifier: BSD-3-Clause
# https://spdx.org/licenses
#
PCI_EP_SUPPORT
:=
0
DOIMAGE_SEC
:=
tools/doimage/secure/sec_img_7K.cfg
MARVELL_MOCHI_DRV
:=
drivers/marvell/mochi/apn806_setup.c
include
plat/marvell/a8k/common/a8k_common.mk
include
plat/marvell/common/marvell_common.mk
Prev
1
2
3
4
5
6
Next
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment