arm64: Introduce raw_{d,i}cache_line_size
On systems with mismatched i/d cache min line sizes, we need to use the smallest size possible across all CPUs. This will be done by fetching the system wide safe value from CPU feature infrastructure. However the some special users(e.g kexec, hibernate) would need the line size on the CPU (rather than the system wide), when either the system wide feature may not be accessible or it is guranteed that the caller executes with a gurantee of no migration. Provide another helper which will fetch cache line size on the current CPU. Cc: Mark Rutland <mark.rutland@arm.com> Cc: Will Deacon <will.deacon@arm.com> Cc: Catalin Marinas <catalin.marinas@arm.com> Acked-by: James Morse <james.morse@arm.com> Reviewed-by: Geoff Levand <geoff@infradead.org> Signed-off-by: Suzuki K Poulose <suzuki.poulose@arm.com> Signed-off-by: Will Deacon <will.deacon@arm.com>
This commit is contained in:

committed by
Will Deacon

parent
c831b2ae25
commit
072f0a6338
@@ -218,9 +218,10 @@ lr .req x30 // link register
|
||||
.endm
|
||||
|
||||
/*
|
||||
* dcache_line_size - get the minimum D-cache line size from the CTR register.
|
||||
* raw_dcache_line_size - get the minimum D-cache line size on this CPU
|
||||
* from the CTR register.
|
||||
*/
|
||||
.macro dcache_line_size, reg, tmp
|
||||
.macro raw_dcache_line_size, reg, tmp
|
||||
mrs \tmp, ctr_el0 // read CTR
|
||||
ubfm \tmp, \tmp, #16, #19 // cache line size encoding
|
||||
mov \reg, #4 // bytes per word
|
||||
@@ -228,15 +229,30 @@ lr .req x30 // link register
|
||||
.endm
|
||||
|
||||
/*
|
||||
* icache_line_size - get the minimum I-cache line size from the CTR register.
|
||||
* dcache_line_size - get the safe D-cache line size across all CPUs
|
||||
*/
|
||||
.macro icache_line_size, reg, tmp
|
||||
.macro dcache_line_size, reg, tmp
|
||||
raw_dcache_line_size \reg, \tmp
|
||||
.endm
|
||||
|
||||
/*
|
||||
* raw_icache_line_size - get the minimum I-cache line size on this CPU
|
||||
* from the CTR register.
|
||||
*/
|
||||
.macro raw_icache_line_size, reg, tmp
|
||||
mrs \tmp, ctr_el0 // read CTR
|
||||
and \tmp, \tmp, #0xf // cache line size encoding
|
||||
mov \reg, #4 // bytes per word
|
||||
lsl \reg, \reg, \tmp // actual cache line size
|
||||
.endm
|
||||
|
||||
/*
|
||||
* icache_line_size - get the safe I-cache line size across all CPUs
|
||||
*/
|
||||
.macro icache_line_size, reg, tmp
|
||||
raw_icache_line_size \reg, \tmp
|
||||
.endm
|
||||
|
||||
/*
|
||||
* tcr_set_idmap_t0sz - update TCR.T0SZ so that we can load the ID map
|
||||
*/
|
||||
|
Reference in New Issue
Block a user