1
2
3
4
5
6
7
8
9#include <linux/linkage.h>
10#include <asm/entry.h>
11#include <asm/cache.h>
12#include <plat/ctop.h>
13
14 .cpu A7
15
16 .section .init.text, "ax",@progbits
17 .align 1024 ; HW requierment for restart first PC
18
19ENTRY(res_service)
20
21 ; There is no work for HW thread id != 0
22 lr r3, [CTOP_AUX_THREAD_ID]
23 cmp r3, 0
24 jne stext
25#endif
26
27#ifdef CONFIG_ARC_HAS_DCACHE
28 ; With no cache coherency mechanism D$ need to be used very carefully.
29 ; Address space:
30 ; 0G-2G: We disable CONFIG_ARC_CACHE_PAGES.
31 ; 2G-3G: We disable D$ by setting this bit.
32 ; 3G-4G: D$ is disabled by architecture.
33 ; FMT are huge pages for user application reside at 0-2G.
34 ; Only FMT left as one who can use D$ where each such page got
35 ; disable/enable bit for cachability.
36 ; Programmer will use FMT pages for private data so cache coherency
37 ; would not be a problem.
38 ; First thing we invalidate D$
39 sr 1, [ARC_REG_DC_IVDC]
40 sr HW_COMPLY_KRN_NOT_D_CACHED, [CTOP_AUX_HW_COMPLY]
41#endif
42
43#ifdef CONFIG_SMP
44 ; We set logical cpuid to be used by GET_CPUID
45 ; We do not use physical cpuid since we want ids to be continious when
46 ; it comes to cpus on the same quad cluster.
47 ; This is useful for applications that used shared resources of a quad
48 ; cluster such SRAMS.
49 lr r3, [CTOP_AUX_CORE_ID]
50 sr r3, [CTOP_AUX_LOGIC_CORE_ID]
51 lr r3, [CTOP_AUX_CLUSTER_ID]
52 ; Set logical is acheived by swap of 2 middle bits of cluster id (4 bit)
53 ; r3 is used since we use short instruction and we need q-class reg
54 .short CTOP_INST_MOV2B_FLIP_R3_B1_B2_INST
55 .word CTOP_INST_MOV2B_FLIP_R3_B1_B2_LIMM
56 sr r3, [CTOP_AUX_LOGIC_CLUSTER_ID]
57#endif
58
59 j stext
60END(res_service)
61