summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSuren A. Chilingaryan <csa@dside.dyndns.org>2011-12-05 09:54:19 +0100
committerSuren A. Chilingaryan <csa@dside.dyndns.org>2011-12-05 09:54:19 +0100
commit86ba81895fe7527650772c887984841082f3cf15 (patch)
tree66f39ca1819b05fe1949178ee5a8c996705f00dc
parenta80eec4346d5eca0dacc772aeaa5aa2094a660e2 (diff)
downloadpcitool-86ba81895fe7527650772c887984841082f3cf15.tar.gz
pcitool-86ba81895fe7527650772c887984841082f3cf15.tar.bz2
pcitool-86ba81895fe7527650772c887984841082f3cf15.tar.xz
pcitool-86ba81895fe7527650772c887984841082f3cf15.zip
Fix addressing for multiword register space reads
-rw-r--r--default.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/default.c b/default.c
index 15ae076..f072579 100644
--- a/default.c
+++ b/default.c
@@ -15,7 +15,7 @@ int pcilib_default_read(pcilib_t *ctx, pcilib_register_bank_description_t *bank,
pcilib_register_value_t val = 0;
int access = bank->access / 8;
- ptr = pcilib_resolve_register_address(ctx, bank->bar, bank->read_addr + addr);
+ ptr = pcilib_resolve_register_address(ctx, bank->bar, bank->read_addr + addr * access);
default_datacpy(&val, ptr, access, bank);
// *value = val&BIT_MASK(bits);
@@ -31,7 +31,7 @@ int pcilib_default_write(pcilib_t *ctx, pcilib_register_bank_description_t *bank
char *ptr;
int access = bank->access / 8;
- ptr = pcilib_resolve_register_address(ctx, bank->bar, bank->write_addr + addr);
+ ptr = pcilib_resolve_register_address(ctx, bank->bar, bank->write_addr + addr * access);
default_datacpy(ptr, &value, access, bank);
return 0;