/* * Copyright (c) 2000-2008 Apple Inc. All rights reserved. * * @APPLE_LICENSE_HEADER_START@ * * This file contains Original Code and/or Modifications of Original Code * as defined in and that are subject to the Apple Public Source License * Version 2.0 (the 'License'). You may not use this file except in * compliance with the License. Please obtain a copy of the License at * http://www.opensource.apple.com/apsl/ and read it before using this * file. * * The Original Code and all software distributed under the License are * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. * Please see the License for the specific language governing rights and * limitations under the License. * * @APPLE_LICENSE_HEADER_END@ */ #ifndef _ARCH_ARM_REG_HELP_H_ #define _ARCH_ARM_REG_HELP_H_ /* Bitfield definition aid */ #define BITS_WIDTH(msb, lsb) ((msb)-(lsb)+1) #define BIT_WIDTH(pos) (1) /* mostly to record the position */ /* Mask creation */ #define MKMASK(width, offset) (((unsigned)-1)>>(32-(width))<<(offset)) #define BITSMASK(msb, lsb) MKMASK(BITS_WIDTH(msb, lsb), lsb & 0x1f) #define BITMASK(pos) MKMASK(BIT_WIDTH(pos), pos & 0x1f) /* Register addresses */ #if __ASSEMBLER__ # define REG_ADDR(type, addr) (addr) #else /* __ASSEMBLER__ */ # define REG_ADDR(type, addr) (*(volatile type *)(addr)) #endif /* __ASSEMBLER__ */ /* Cast a register to be an unsigned */ #if defined(__arm__) #define CONTENTS(foo) (*(unsigned*) &(foo)) /* Stack pointer must always be a multiple of 4 */ #define STACK_INCR 4 #else #error Unknown architecture. #endif #define ROUND_FRAME(x) ((((unsigned)(x)) + STACK_INCR - 1) & ~(STACK_INCR-1)) /* STRINGIFY -- perform all possible substitutions, then stringify */ #define __STR(x) #x /* just a helper macro */ #define STRINGIFY(x) __STR(x) #endif /* _ARCH_ARM_REG_HELP_H_ */