default.c 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. #include <sys/time.h>
  2. #include <arpa/inet.h>
  3. #include <assert.h>
  4. #include "tools.h"
  5. #include "model.h"
  6. #include "error.h"
  7. #include "bar.h"
  8. #include "datacpy.h"
  9. #define default_datacpy(dst, src, access, bank) pcilib_datacpy(dst, src, access, 1, bank->raw_endianess)
  10. int pcilib_default_read(pcilib_t *ctx, pcilib_register_bank_context_t *bank_ctx, pcilib_register_addr_t addr, pcilib_register_value_t *value) {
  11. char *ptr;
  12. pcilib_register_value_t val = 0;
  13. const pcilib_register_bank_description_t *b = bank_ctx->bank;
  14. int access = b->access / 8;
  15. ptr = pcilib_resolve_register_address(ctx, b->bar, b->read_addr + addr);
  16. default_datacpy(&val, ptr, access, b);
  17. // *value = val&BIT_MASK(bits);
  18. *value = val;
  19. return 0;
  20. }
  21. int pcilib_default_write(pcilib_t *ctx, pcilib_register_bank_context_t *bank_ctx, pcilib_register_addr_t addr, pcilib_register_value_t value) {
  22. char *ptr;
  23. const pcilib_register_bank_description_t *b = bank_ctx->bank;
  24. int access = b->access / 8;
  25. ptr = pcilib_resolve_register_address(ctx, b->bar, b->write_addr + addr);
  26. default_datacpy(ptr, &value, access, b);
  27. return 0;
  28. }