mcp251xfd-ram.h 1.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. /* SPDX-License-Identifier: GPL-2.0
  2. *
  3. * mcp251xfd - Microchip MCP251xFD Family CAN controller driver
  4. *
  5. * Copyright (c) 2021, 2022 Pengutronix,
  6. * Marc Kleine-Budde <[email protected]>
  7. */
  8. #ifndef _MCP251XFD_RAM_H
  9. #define _MCP251XFD_RAM_H
  10. #include <linux/ethtool.h>
  11. #define CAN_RAM_NUM_MAX (-1)
  12. enum can_ram_mode {
  13. CAN_RAM_MODE_CAN,
  14. CAN_RAM_MODE_CANFD,
  15. __CAN_RAM_MODE_MAX
  16. };
  17. struct can_ram_obj_config {
  18. u8 size[__CAN_RAM_MODE_MAX];
  19. u8 def[__CAN_RAM_MODE_MAX];
  20. u8 min;
  21. u8 max;
  22. u8 fifo_num;
  23. u8 fifo_depth_min;
  24. u8 fifo_depth_coalesce_min;
  25. };
  26. struct can_ram_config {
  27. const struct can_ram_obj_config rx;
  28. const struct can_ram_obj_config tx;
  29. u16 size;
  30. u8 fifo_depth;
  31. };
  32. struct can_ram_layout {
  33. u8 default_rx;
  34. u8 default_tx;
  35. u8 max_rx;
  36. u8 max_tx;
  37. u8 cur_rx;
  38. u8 cur_tx;
  39. u8 rx_coalesce;
  40. u8 tx_coalesce;
  41. };
  42. void can_ram_get_layout(struct can_ram_layout *layout,
  43. const struct can_ram_config *config,
  44. const struct ethtool_ringparam *ring,
  45. const struct ethtool_coalesce *ec,
  46. const bool fd_mode);
  47. #endif