default.c 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  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. #include "pci.h"
  10. #define default_datacpy(dst, src, access, bank) pcilib_datacpy(dst, src, access, 1, bank->raw_endianess)
  11. uintptr_t pcilib_default_resolve(pcilib_t *ctx, pcilib_register_bank_context_t *bank_ctx, pcilib_address_resolution_flags_t flags, pcilib_register_addr_t reg_addr) {
  12. uintptr_t addr;
  13. const pcilib_register_bank_description_t *b = bank_ctx->bank;
  14. if (reg_addr == PCILIB_REGISTER_ADDRESS_INVALID) reg_addr = 0;
  15. switch (flags&PCILIB_ADDRESS_RESOLUTION_MASK_ACCESS_MODE) {
  16. case 0:
  17. if (b->read_addr != b->write_addr)
  18. return PCILIB_ADDRESS_INVALID;
  19. case PCILIB_ADDRESS_RESOLUTION_FLAG_READ_ONLY:
  20. addr = b->read_addr + reg_addr;
  21. break;
  22. case PCILIB_ADDRESS_RESOLUTION_FLAG_WRITE_ONLY:
  23. addr = b->write_addr + reg_addr;
  24. default:
  25. return PCILIB_ADDRESS_INVALID;
  26. }
  27. switch (flags&PCILIB_ADDRESS_RESOLUTION_MASK_ADDRESS_TYPE) {
  28. case 0:
  29. return (uintptr_t)pcilib_resolve_bar_address(ctx, b->bar, addr);
  30. case PCILIB_ADDRESS_RESOLUTION_FLAG_BUS_ADDRESS:
  31. case PCILIB_ADDRESS_RESOLUTION_FLAG_PHYS_ADDRESS:
  32. return ctx->board_info.bar_start[b->bar] + addr;
  33. }
  34. return PCILIB_ADDRESS_INVALID;
  35. }
  36. int pcilib_default_read(pcilib_t *ctx, pcilib_register_bank_context_t *bank_ctx, pcilib_register_addr_t addr, pcilib_register_value_t *value) {
  37. char *ptr;
  38. pcilib_register_value_t val = 0;
  39. const pcilib_register_bank_description_t *b = bank_ctx->bank;
  40. int access = b->access / 8;
  41. ptr = pcilib_resolve_bar_address(ctx, b->bar, b->read_addr + addr);
  42. default_datacpy(&val, ptr, access, b);
  43. // *value = val&BIT_MASK(bits);
  44. *value = val;
  45. return 0;
  46. }
  47. int pcilib_default_write(pcilib_t *ctx, pcilib_register_bank_context_t *bank_ctx, pcilib_register_addr_t addr, pcilib_register_value_t value) {
  48. char *ptr;
  49. const pcilib_register_bank_description_t *b = bank_ctx->bank;
  50. int access = b->access / 8;
  51. ptr = pcilib_resolve_bar_address(ctx, b->bar, b->write_addr + addr);
  52. default_datacpy(ptr, &value, access, b);
  53. return 0;
  54. }