summaryrefslogtreecommitdiffstats
path: root/plat/rockchip/rk3288/include/plat_sp_min.ld.S
blob: 2878437687bf42d7d9d91e565a8aff82c590e188 (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
/*
 * Copyright (c) 2016, ARM Limited and Contributors. All rights reserved.
 *
 * SPDX-License-Identifier: BSD-3-Clause
 */
#ifndef ROCKCHIP_PLAT_LD_S
#define ROCKCHIP_PLAT_LD_S

#include <lib/xlat_tables/xlat_tables_defs.h>

MEMORY {
    SRAM (rwx): ORIGIN = SRAM_BASE, LENGTH = SRAM_SIZE
    PMUSRAM (rwx): ORIGIN = PMUSRAM_BASE, LENGTH = PMUSRAM_RSIZE
}

SECTIONS
{
	. = SRAM_BASE;
	ASSERT(. == ALIGN(PAGE_SIZE),
		"SRAM_BASE address is not aligned on a page boundary.")

	.text_sram : ALIGN(PAGE_SIZE) {
		__bl32_sram_text_start = .;
		*(.sram.text)
		*(.sram.rodata)
		__bl32_sram_text_real_end = .;
		. = ALIGN(PAGE_SIZE);
		__bl32_sram_text_end = .;
	} >SRAM
	ASSERT((__bl32_sram_text_real_end - __bl32_sram_text_start) <=
		SRAM_TEXT_LIMIT, ".text_sram has exceeded its limit")

	.data_sram : ALIGN(PAGE_SIZE) {
		__bl32_sram_data_start = .;
		*(.sram.data)
		__bl32_sram_data_real_end = .;
		. = ALIGN(PAGE_SIZE);
		__bl32_sram_data_end = .;
	} >SRAM
	ASSERT((__bl32_sram_data_real_end - __bl32_sram_data_start) <=
		SRAM_DATA_LIMIT, ".data_sram has exceeded its limit")

	.stack_sram : ALIGN(PAGE_SIZE) {
		__bl32_sram_stack_start = .;
		. += PAGE_SIZE;
		__bl32_sram_stack_end = .;
	} >SRAM

	. = PMUSRAM_BASE;

	/*
	 * pmu_cpuson_entrypoint request address
	 * align 64K when resume, so put it in the
	 * start of pmusram
	 */
	.pmusram : {
		ASSERT(. == ALIGN(64 * 1024),
			".pmusram.entry request 64K aligned.");
		*(.pmusram.entry)

		__bl32_pmusram_text_start = .;
		*(.pmusram.text)
		*(.pmusram.rodata)
		__bl32_pmusram_text_end = .;

		__bl32_pmusram_data_start = .;
		*(.pmusram.data)
		__bl32_pmusram_data_end = .;
	} >PMUSRAM
}

#endif /* ROCKCHIP_PLAT_LD_S */