netup_unidvb.h 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. /*
  2. * netup_unidvb.h
  3. *
  4. * Data type definitions for NetUP Universal Dual DVB-CI
  5. *
  6. * Copyright (C) 2014 NetUP Inc.
  7. * Copyright (C) 2014 Sergey Kozlov <serjk@netup.ru>
  8. * Copyright (C) 2014 Abylay Ospan <aospan@netup.ru>
  9. *
  10. * This program is free software; you can redistribute it and/or modify
  11. * it under the terms of the GNU General Public License as published by
  12. * the Free Software Foundation; either version 2 of the License, or
  13. * (at your option) any later version.
  14. *
  15. * This program is distributed in the hope that it will be useful,
  16. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. * GNU General Public License for more details.
  19. */
  20. #include <linux/pci.h>
  21. #include <linux/i2c.h>
  22. #include <linux/workqueue.h>
  23. #include <media/v4l2-common.h>
  24. #include <media/v4l2-device.h>
  25. #include <media/videobuf2-dvb.h>
  26. #include <dvb_ca_en50221.h>
  27. #define NETUP_UNIDVB_NAME "netup_unidvb"
  28. #define NETUP_UNIDVB_VERSION "0.0.1"
  29. #define NETUP_VENDOR_ID 0x1b55
  30. #define NETUP_PCI_DEV_REVISION 0x2
  31. /* IRQ-related regisers */
  32. #define REG_ISR 0x4890
  33. #define REG_ISR_MASKED 0x4892
  34. #define REG_IMASK_SET 0x4894
  35. #define REG_IMASK_CLEAR 0x4896
  36. /* REG_ISR register bits */
  37. #define NETUP_UNIDVB_IRQ_SPI (1 << 0)
  38. #define NETUP_UNIDVB_IRQ_I2C0 (1 << 1)
  39. #define NETUP_UNIDVB_IRQ_I2C1 (1 << 2)
  40. #define NETUP_UNIDVB_IRQ_FRA0 (1 << 4)
  41. #define NETUP_UNIDVB_IRQ_FRA1 (1 << 5)
  42. #define NETUP_UNIDVB_IRQ_FRB0 (1 << 6)
  43. #define NETUP_UNIDVB_IRQ_FRB1 (1 << 7)
  44. #define NETUP_UNIDVB_IRQ_DMA1 (1 << 8)
  45. #define NETUP_UNIDVB_IRQ_DMA2 (1 << 9)
  46. #define NETUP_UNIDVB_IRQ_CI (1 << 10)
  47. #define NETUP_UNIDVB_IRQ_CAM0 (1 << 11)
  48. #define NETUP_UNIDVB_IRQ_CAM1 (1 << 12)
  49. /* NetUP Universal DVB card hardware revisions and it's PCI device id's:
  50. * 1.3 - CXD2841ER demod, ASCOT2E and HORUS3A tuners
  51. * 1.4 - CXD2854ER demod, HELENE tuner
  52. */
  53. enum netup_hw_rev {
  54. NETUP_HW_REV_1_3 = 0x18F6,
  55. NETUP_HW_REV_1_4 = 0x18F7
  56. };
  57. struct netup_dma {
  58. u8 num;
  59. spinlock_t lock;
  60. struct netup_unidvb_dev *ndev;
  61. struct netup_dma_regs __iomem *regs;
  62. u32 ring_buffer_size;
  63. u8 *addr_virt;
  64. dma_addr_t addr_phys;
  65. u64 addr_last;
  66. u32 high_addr;
  67. u32 data_offset;
  68. u32 data_size;
  69. struct list_head free_buffers;
  70. struct work_struct work;
  71. struct timer_list timeout;
  72. };
  73. enum netup_i2c_state {
  74. STATE_DONE,
  75. STATE_WAIT,
  76. STATE_WANT_READ,
  77. STATE_WANT_WRITE,
  78. STATE_ERROR
  79. };
  80. struct netup_i2c_regs;
  81. struct netup_i2c {
  82. spinlock_t lock;
  83. wait_queue_head_t wq;
  84. struct i2c_adapter adap;
  85. struct netup_unidvb_dev *dev;
  86. struct netup_i2c_regs __iomem *regs;
  87. struct i2c_msg *msg;
  88. enum netup_i2c_state state;
  89. u32 xmit_size;
  90. };
  91. struct netup_ci_state {
  92. struct dvb_ca_en50221 ca;
  93. u8 __iomem *membase8_config;
  94. u8 __iomem *membase8_io;
  95. struct netup_unidvb_dev *dev;
  96. int status;
  97. int nr;
  98. };
  99. struct netup_spi;
  100. struct netup_unidvb_dev {
  101. struct pci_dev *pci_dev;
  102. int pci_bus;
  103. int pci_slot;
  104. int pci_func;
  105. int board_num;
  106. int old_fw;
  107. u32 __iomem *lmmio0;
  108. u8 __iomem *bmmio0;
  109. u32 __iomem *lmmio1;
  110. u8 __iomem *bmmio1;
  111. u8 *dma_virt;
  112. dma_addr_t dma_phys;
  113. u32 dma_size;
  114. struct vb2_dvb_frontends frontends[2];
  115. struct netup_i2c i2c[2];
  116. struct workqueue_struct *wq;
  117. struct netup_dma dma[2];
  118. struct netup_ci_state ci[2];
  119. struct netup_spi *spi;
  120. enum netup_hw_rev rev;
  121. };
  122. int netup_i2c_register(struct netup_unidvb_dev *ndev);
  123. void netup_i2c_unregister(struct netup_unidvb_dev *ndev);
  124. irqreturn_t netup_ci_interrupt(struct netup_unidvb_dev *ndev);
  125. irqreturn_t netup_i2c_interrupt(struct netup_i2c *i2c);
  126. irqreturn_t netup_spi_interrupt(struct netup_spi *spi);
  127. int netup_unidvb_ci_register(struct netup_unidvb_dev *dev,
  128. int num, struct pci_dev *pci_dev);
  129. void netup_unidvb_ci_unregister(struct netup_unidvb_dev *dev, int num);
  130. int netup_spi_init(struct netup_unidvb_dev *ndev);
  131. void netup_spi_release(struct netup_unidvb_dev *ndev);