summaryrefslogtreecommitdiff
path: root/src/target/xscale.h
diff options
context:
space:
mode:
authorDavid Brownell <dbrownell@users.sourceforge.net>2009-11-05 22:04:25 -0800
committerDavid Brownell <dbrownell@users.sourceforge.net>2009-11-05 22:04:25 -0800
commit6a0af06bd9f66780d2c3e9f69c40f2b89ad90605 (patch)
tree82c3c0a0258d1e2548b8667bb13d4552ae973f31 /src/target/xscale.h
parent03ac53a2cfdb7d0715f7060cecf8719068f6fae1 (diff)
downloadopenocd+libswd-6a0af06bd9f66780d2c3e9f69c40f2b89ad90605.tar.gz
openocd+libswd-6a0af06bd9f66780d2c3e9f69c40f2b89ad90605.tar.bz2
openocd+libswd-6a0af06bd9f66780d2c3e9f69c40f2b89ad90605.tar.xz
openocd+libswd-6a0af06bd9f66780d2c3e9f69c40f2b89ad90605.zip
ARM: shrink offsets
Move various embedded target structs to the beginnings of their containers ... pretty much the way C++ or Obj-C would for single inheritance. This shrinks code that accesses those embedded structs by letting common offsets use smaller instructions. Sample before/after sizes (on amd64): 17181 312 0 17493 4455 arm920t.o 16810 312 0 17122 42e2 arm920t.o Where the "after" is the smaller number, with this patch over the ones leveraging that embedding knowledge. Signed-off-by: David Brownell <dbrownell@users.sourceforge.net>
Diffstat (limited to 'src/target/xscale.h')
-rw-r--r--src/target/xscale.h6
1 files changed, 3 insertions, 3 deletions
diff --git a/src/target/xscale.h b/src/target/xscale.h
index 56db1815..433ecfcf 100644
--- a/src/target/xscale.h
+++ b/src/target/xscale.h
@@ -80,6 +80,9 @@ typedef struct xscale_trace_s
typedef struct xscale_common_s
{
+ /* armv4/5 common stuff */
+ armv4_5_common_t armv4_5_common;
+
int common_magic;
/* XScale registers (CP15, DBG) */
@@ -121,9 +124,6 @@ typedef struct xscale_common_s
int arch_debug_reason;
- /* armv4/5 common stuff */
- armv4_5_common_t armv4_5_common;
-
/* MMU/Caches */
armv4_5_mmu_common_t armv4_5_mmu;
uint32_t cp15_control_reg;