softing.h 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /*
  3. * softing common interfaces
  4. *
  5. * by Kurt Van Dijck, 2008-2010
  6. */
  7. #include <linux/atomic.h>
  8. #include <linux/netdevice.h>
  9. #include <linux/ktime.h>
  10. #include <linux/mutex.h>
  11. #include <linux/spinlock.h>
  12. #include <linux/can.h>
  13. #include <linux/can/dev.h>
  14. #include "softing_platform.h"
  15. struct softing;
  16. struct softing_priv {
  17. struct can_priv can; /* must be the first member! */
  18. struct net_device *netdev;
  19. struct softing *card;
  20. struct {
  21. int pending;
  22. /* variables which hold the circular buffer */
  23. int echo_put;
  24. int echo_get;
  25. } tx;
  26. struct can_bittiming_const btr_const;
  27. int index;
  28. uint8_t output;
  29. uint16_t chip;
  30. };
  31. #define netdev2softing(netdev) ((struct softing_priv *)netdev_priv(netdev))
  32. struct softing {
  33. const struct softing_platform_data *pdat;
  34. struct platform_device *pdev;
  35. struct net_device *net[2];
  36. spinlock_t spin; /* protect this structure & DPRAM access */
  37. ktime_t ts_ref;
  38. ktime_t ts_overflow; /* timestamp overflow value, in ktime */
  39. struct {
  40. /* indication of firmware status */
  41. int up;
  42. /* protection of the 'up' variable */
  43. struct mutex lock;
  44. } fw;
  45. struct {
  46. int nr;
  47. int requested;
  48. int svc_count;
  49. unsigned int dpram_position;
  50. } irq;
  51. struct {
  52. int pending;
  53. int last_bus;
  54. /*
  55. * keep the bus that last tx'd a message,
  56. * in order to let every netdev queue resume
  57. */
  58. } tx;
  59. __iomem uint8_t *dpram;
  60. unsigned long dpram_phys;
  61. unsigned long dpram_size;
  62. struct {
  63. uint16_t fw_version, hw_version, license, serial;
  64. uint16_t chip[2];
  65. unsigned int freq; /* remote cpu's operating frequency */
  66. } id;
  67. };
  68. int softing_default_output(struct net_device *netdev);
  69. ktime_t softing_raw2ktime(struct softing *card, u32 raw);
  70. int softing_chip_poweron(struct softing *card);
  71. int softing_bootloader_command(struct softing *card, int16_t cmd,
  72. const char *msg);
  73. /* Load firmware after reset */
  74. int softing_load_fw(const char *file, struct softing *card,
  75. __iomem uint8_t *virt, unsigned int size, int offset);
  76. /* Load final application firmware after bootloader */
  77. int softing_load_app_fw(const char *file, struct softing *card);
  78. /*
  79. * enable or disable irq
  80. * only called with fw.lock locked
  81. */
  82. int softing_enable_irq(struct softing *card, int enable);
  83. /* start/stop 1 bus on card */
  84. int softing_startstop(struct net_device *netdev, int up);
  85. /* netif_rx() */
  86. int softing_netdev_rx(struct net_device *netdev, const struct can_frame *msg,
  87. ktime_t ktime);
  88. /* SOFTING DPRAM mappings */
  89. #define DPRAM_RX 0x0000
  90. #define DPRAM_RX_SIZE 32
  91. #define DPRAM_RX_CNT 16
  92. #define DPRAM_RX_RD 0x0201 /* uint8_t */
  93. #define DPRAM_RX_WR 0x0205 /* uint8_t */
  94. #define DPRAM_RX_LOST 0x0207 /* uint8_t */
  95. #define DPRAM_FCT_PARAM 0x0300 /* int16_t [20] */
  96. #define DPRAM_FCT_RESULT 0x0328 /* int16_t */
  97. #define DPRAM_FCT_HOST 0x032b /* uint16_t */
  98. #define DPRAM_INFO_BUSSTATE 0x0331 /* uint16_t */
  99. #define DPRAM_INFO_BUSSTATE2 0x0335 /* uint16_t */
  100. #define DPRAM_INFO_ERRSTATE 0x0339 /* uint16_t */
  101. #define DPRAM_INFO_ERRSTATE2 0x033d /* uint16_t */
  102. #define DPRAM_RESET 0x0341 /* uint16_t */
  103. #define DPRAM_CLR_RECV_FIFO 0x0345 /* uint16_t */
  104. #define DPRAM_RESET_TIME 0x034d /* uint16_t */
  105. #define DPRAM_TIME 0x0350 /* uint64_t */
  106. #define DPRAM_WR_START 0x0358 /* uint8_t */
  107. #define DPRAM_WR_END 0x0359 /* uint8_t */
  108. #define DPRAM_RESET_RX_FIFO 0x0361 /* uint16_t */
  109. #define DPRAM_RESET_TX_FIFO 0x0364 /* uint8_t */
  110. #define DPRAM_READ_FIFO_LEVEL 0x0365 /* uint8_t */
  111. #define DPRAM_RX_FIFO_LEVEL 0x0366 /* uint16_t */
  112. #define DPRAM_TX_FIFO_LEVEL 0x0366 /* uint16_t */
  113. #define DPRAM_TX 0x0400 /* uint16_t */
  114. #define DPRAM_TX_SIZE 16
  115. #define DPRAM_TX_CNT 32
  116. #define DPRAM_TX_RD 0x0601 /* uint8_t */
  117. #define DPRAM_TX_WR 0x0605 /* uint8_t */
  118. #define DPRAM_COMMAND 0x07e0 /* uint16_t */
  119. #define DPRAM_RECEIPT 0x07f0 /* uint16_t */
  120. #define DPRAM_IRQ_TOHOST 0x07fe /* uint8_t */
  121. #define DPRAM_IRQ_TOCARD 0x07ff /* uint8_t */
  122. #define DPRAM_V2_RESET 0x0e00 /* uint8_t */
  123. #define DPRAM_V2_IRQ_TOHOST 0x0e02 /* uint8_t */
  124. #define TXMAX (DPRAM_TX_CNT - 1)
  125. /* DPRAM return codes */
  126. #define RES_NONE 0
  127. #define RES_OK 1
  128. #define RES_NOK 2
  129. #define RES_UNKNOWN 3
  130. /* DPRAM flags */
  131. #define CMD_TX 0x01
  132. #define CMD_ACK 0x02
  133. #define CMD_XTD 0x04
  134. #define CMD_RTR 0x08
  135. #define CMD_ERR 0x10
  136. #define CMD_BUS2 0x80
  137. /* returned fifo entry bus state masks */
  138. #define SF_MASK_BUSOFF 0x80
  139. #define SF_MASK_EPASSIVE 0x60
  140. /* bus states */
  141. #define STATE_BUSOFF 2
  142. #define STATE_EPASSIVE 1
  143. #define STATE_EACTIVE 0