dct_v1.c 837 B

123456789101112131415161718192021222324252627282930313233343536
  1. // SPDX-License-Identifier: BSD-3-Clause
  2. /*
  3. * Copyright (c) 2020, MIPI Alliance, Inc.
  4. *
  5. * Author: Nicolas Pitre <[email protected]>
  6. */
  7. #include <linux/device.h>
  8. #include <linux/bitfield.h>
  9. #include <linux/i3c/master.h>
  10. #include <linux/io.h>
  11. #include "hci.h"
  12. #include "dct.h"
  13. /*
  14. * Device Characteristic Table
  15. */
  16. void i3c_hci_dct_get_val(struct i3c_hci *hci, unsigned int dct_idx,
  17. u64 *pid, unsigned int *dcr, unsigned int *bcr)
  18. {
  19. void __iomem *reg = hci->DCT_regs + dct_idx * 4 * 4;
  20. u32 dct_entry_data[4];
  21. unsigned int i;
  22. for (i = 0; i < 4; i++) {
  23. dct_entry_data[i] = readl(reg);
  24. reg += 4;
  25. }
  26. *pid = ((u64)dct_entry_data[0]) << (47 - 32 + 1) |
  27. FIELD_GET(W1_MASK(47, 32), dct_entry_data[1]);
  28. *dcr = FIELD_GET(W2_MASK(71, 64), dct_entry_data[2]);
  29. *bcr = FIELD_GET(W2_MASK(79, 72), dct_entry_data[2]);
  30. }