summaryrefslogtreecommitdiffstats
path: root/fs/xfs/xfs_error.c
diff options
context:
space:
mode:
authorPaul Gortmaker <paul.gortmaker@gmail.com>2009-05-07 16:18:40 +0100
committerRussell King <rmk+kernel@arm.linux.org.uk>2009-05-07 17:21:01 +0100
commitae51e609843f7d0aaeb1c2ad9f89d252a4899885 (patch)
treeaf632106715c1c3db9c974fdecf6903e86eef1ed /fs/xfs/xfs_error.c
parenta029b706d3b2d3a139bdeae84131d9a0f35f6478 (diff)
downloadop-kernel-dev-ae51e609843f7d0aaeb1c2ad9f89d252a4899885.zip
op-kernel-dev-ae51e609843f7d0aaeb1c2ad9f89d252a4899885.tar.gz
[ARM] 5507/1: support R_ARM_MOVW_ABS_NC and MOVT_ABS relocation types
From: Bruce Ashfield <bruce.ashfield@windriver.com> To fully support the armv7-a instruction set/optimizations, support for the R_ARM_MOVW_ABS_NC and R_ARM_MOVT_ABS relocation types is required. The MOVW and MOVT are both load-immediate instructions, MOVW loads 16 bits into the bottom half of a register, and MOVT loads 16 bits into the top half of a register. The relocation information for these instructions has a full 32 bit value, plus an addend which is stored in the 16 immediate bits in the instruction itself. The immediate bits in the instruction are not contiguous (the register # splits it into a 4 bit and 12 bit value), so the addend has to be extracted accordingly and added to the value. The value is then split and put into the instruction; a MOVW uses the bottom 16 bits of the value, and a MOVT uses the top 16 bits. Signed-off-by: David Borman <david.borman@windriver.com> Signed-off-by: Bruce Ashfield <bruce.ashfield@windriver.com> Signed-off-by: Paul Gortmaker <paul.gortmaker@windriver.com> Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'fs/xfs/xfs_error.c')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud