default.c 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  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. #define default_datacpy(dst, src, access, bank) pcilib_datacpy(dst, src, access, 1, bank->raw_endianess)
  8. int pcilib_default_read(pcilib_t *ctx, pcilib_register_bank_context_t *bank_ctx, pcilib_register_addr_t addr, pcilib_register_value_t *value) {
  9. char *ptr;
  10. pcilib_register_value_t val = 0;
  11. const pcilib_register_bank_description_t *b = bank_ctx->bank;
  12. int access = b->access / 8;
  13. ptr = pcilib_resolve_register_address(ctx, b->bar, b->read_addr + addr);
  14. default_datacpy(&val, ptr, access, b);
  15. // *value = val&BIT_MASK(bits);
  16. *value = val;
  17. return 0;
  18. }
  19. int pcilib_default_write(pcilib_t *ctx, pcilib_register_bank_context_t *bank_ctx, pcilib_register_addr_t addr, pcilib_register_value_t value) {
  20. char *ptr;
  21. const pcilib_register_bank_description_t *b = bank_ctx->bank;
  22. int access = b->access / 8;
  23. ptr = pcilib_resolve_register_address(ctx, b->bar, b->write_addr + addr);
  24. default_datacpy(ptr, &value, access, b);
  25. return 0;
  26. }