/*
* armv6 machine assist, definitions
*
* loader uses R11 as scratch.
*/
#include "mem.h"
#include "arm.h"
#define PADDR(va) (PHYSDRAM | ((va) & ~KSEGM))
#define L1X(va) (((((va))>>20) & 0x0fff)<<2)
#define PTEDRAM (Dom0|L1AP(Krw)|Section|Cached|Buffered)
/*
* new instructions
*/
#define ISB \
MOVW $0, R0; \
MCR P(CpSC), 0, R0, C(CpCACHE), C(CpCACHEinvi), CpCACHEwait
#define DSB \
MOVW $0, R0; \
MCR P(CpSC), 0, R0, C(CpCACHE), C(CpCACHEwb), CpCACHEwait
#define BARRIERS ISB; DSB
#define MCRR(coproc, op, rd, rn, crm) \
WORD $(0xec400000|(rn)<<16|(rd)<<12|(coproc)<<8|(op)<<4|(crm))
#define OKAY \
MOVW $0x7E200028,R2; \
MOVW $0x10000,R3; \
MOVW R3,(R2)
|