ARM: API to Map Physical Address to Wipe Memory above 4GB
TEST=Booted nyan in normal and recovery mode. Created a map, filled it with some chars, then verified they can be read from the pointer returned. BUG=chrome-os-partner:25587 BRANCH=None Signed-off-by: Daisuke Nojiri <dnojiri@chromium.org> Tested-by: Daisuke Nojiri <dnojiri@chromium.org> Original-Change-Id: Id1f1be4f6d2d5734d87bf3452d4806d0fe3fda88 Original-Reviewed-on: https://chromium-review.googlesource.com/188894 Original-Reviewed-by: Julius Werner <jwerner@chromium.org> Original-Commit-Queue: Daisuke Nojiri <dnojiri@chromium.org> Original-Tested-by: Daisuke Nojiri <dnojiri@chromium.org> (cherry picked from commit 7fda3885f51c8d383585a80e99ab3df9c789d872) Signed-off-by: Marc Jones <marc.jones@se-eng.com> Change-Id: I6255d11396c87f40b0ae12ceab0fd152f2478529 Reviewed-on: http://review.coreboot.org/7658 Tested-by: build bot (Jenkins) Reviewed-by: Patrick Georgi <pgeorgi@google.com>
This commit is contained in:
committed by
Marc Jones
parent
97345dbc6c
commit
0341169761
@@ -117,6 +117,15 @@ static inline void write_ttbr0(uint32_t val)
|
||||
asm volatile ("mcr p15, 0, %0, c2, c0, 0" : : "r" (val) : "memory");
|
||||
}
|
||||
|
||||
/* read translation table base register 0 (TTBR0) */
|
||||
static inline uint64_t read_ttbr0(void)
|
||||
{
|
||||
uint32_t low, high;
|
||||
asm volatile ("mrrc p15, 0, %[low], %[high], c2" :
|
||||
[low] "=r" (low), [high] "=r" (high));
|
||||
return ((uint64_t)high << 32) | low;
|
||||
}
|
||||
|
||||
/* read translation table base control register (TTBCR) */
|
||||
static inline uint32_t read_ttbcr(void)
|
||||
{
|
||||
|
@@ -30,6 +30,8 @@
|
||||
#ifndef _ARCH_VIRTUAL_H
|
||||
#define _ARCH_VIRTUAL_H
|
||||
|
||||
#include <arch/cache.h>
|
||||
|
||||
extern unsigned long virtual_offset;
|
||||
|
||||
#define virt_to_phys(virt) ((unsigned long) (virt) + virtual_offset)
|
||||
@@ -38,4 +40,7 @@ extern unsigned long virtual_offset;
|
||||
#define virt_to_bus(addr) virt_to_phys(addr)
|
||||
#define bus_to_virt(addr) phys_to_virt(addr)
|
||||
|
||||
void *lpae_map_phys_addr(unsigned long pa_mb, enum dcache_policy policy);
|
||||
void lpae_restore_map(void);
|
||||
|
||||
#endif
|
||||
|
@@ -15,3 +15,7 @@ typedef __SIZE_TYPE__ ssize_t;
|
||||
|
||||
#define offsetof(TYPE, MEMBER) ((size_t) &((TYPE *) 0)->MEMBER)
|
||||
|
||||
/* Standard units. */
|
||||
#define KiB (1<<10)
|
||||
#define MiB (1<<20)
|
||||
#define GiB (1<<30)
|
||||
|
@@ -35,6 +35,11 @@
|
||||
#include <stddef.h>
|
||||
#include <string.h>
|
||||
|
||||
#define ALIGN(x,a) __ALIGN_MASK(x,(typeof(x))(a)-1UL)
|
||||
#define __ALIGN_MASK(x,mask) (((x)+(mask))&~(mask))
|
||||
#define ALIGN_UP(x,a) ALIGN((x),(a))
|
||||
#define ALIGN_DOWN(x,a) ((x) & ~((typeof(x))(a)-1UL))
|
||||
|
||||
/**
|
||||
* @defgroup malloc Memory allocation functions
|
||||
* @{
|
||||
|
Reference in New Issue
Block a user