1 /* SPDX-License-Identifier: GPL-2.0-or-later */
5 * Data type definitions for NetUP Universal Dual DVB-CI
7 * Copyright (C) 2014 NetUP Inc.
8 * Copyright (C) 2014 Sergey Kozlov <serjk@netup.ru>
9 * Copyright (C) 2014 Abylay Ospan <aospan@netup.ru>
12 #include <linux/pci.h>
13 #include <linux/i2c.h>
14 #include <linux/workqueue.h>
15 #include <media/v4l2-common.h>
16 #include <media/v4l2-device.h>
17 #include <media/videobuf2-dvb.h>
18 #include <media/dvb_ca_en50221.h>
20 #define NETUP_UNIDVB_NAME "netup_unidvb"
21 #define NETUP_UNIDVB_VERSION "0.0.1"
22 #define NETUP_VENDOR_ID 0x1b55
23 #define NETUP_PCI_DEV_REVISION 0x2
25 /* IRQ-related regisers */
26 #define REG_ISR 0x4890
27 #define REG_ISR_MASKED 0x4892
28 #define REG_IMASK_SET 0x4894
29 #define REG_IMASK_CLEAR 0x4896
30 /* REG_ISR register bits */
31 #define NETUP_UNIDVB_IRQ_SPI (1 << 0)
32 #define NETUP_UNIDVB_IRQ_I2C0 (1 << 1)
33 #define NETUP_UNIDVB_IRQ_I2C1 (1 << 2)
34 #define NETUP_UNIDVB_IRQ_FRA0 (1 << 4)
35 #define NETUP_UNIDVB_IRQ_FRA1 (1 << 5)
36 #define NETUP_UNIDVB_IRQ_FRB0 (1 << 6)
37 #define NETUP_UNIDVB_IRQ_FRB1 (1 << 7)
38 #define NETUP_UNIDVB_IRQ_DMA1 (1 << 8)
39 #define NETUP_UNIDVB_IRQ_DMA2 (1 << 9)
40 #define NETUP_UNIDVB_IRQ_CI (1 << 10)
41 #define NETUP_UNIDVB_IRQ_CAM0 (1 << 11)
42 #define NETUP_UNIDVB_IRQ_CAM1 (1 << 12)
44 /* NetUP Universal DVB card hardware revisions and it's PCI device id's:
45 * 1.3 - CXD2841ER demod, ASCOT2E and HORUS3A tuners
46 * 1.4 - CXD2854ER demod, HELENE tuner
49 NETUP_HW_REV_1_3
= 0x18F6,
50 NETUP_HW_REV_1_4
= 0x18F7
56 struct netup_unidvb_dev
*ndev
;
57 struct netup_dma_regs __iomem
*regs
;
65 struct list_head free_buffers
;
66 struct work_struct work
;
67 struct timer_list timeout
;
70 enum netup_i2c_state
{
78 struct netup_i2c_regs
;
83 struct i2c_adapter adap
;
84 struct netup_unidvb_dev
*dev
;
85 struct netup_i2c_regs __iomem
*regs
;
87 enum netup_i2c_state state
;
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
;
102 struct netup_unidvb_dev
{
103 struct pci_dev
*pci_dev
;
116 struct vb2_dvb_frontends frontends
[2];
117 struct netup_i2c i2c
[2];
118 struct workqueue_struct
*wq
;
119 struct netup_dma dma
[2];
120 struct netup_ci_state ci
[2];
121 struct netup_spi
*spi
;
122 enum netup_hw_rev rev
;
125 int netup_i2c_register(struct netup_unidvb_dev
*ndev
);
126 void netup_i2c_unregister(struct netup_unidvb_dev
*ndev
);
127 irqreturn_t
netup_ci_interrupt(struct netup_unidvb_dev
*ndev
);
128 irqreturn_t
netup_i2c_interrupt(struct netup_i2c
*i2c
);
129 irqreturn_t
netup_spi_interrupt(struct netup_spi
*spi
);
130 int netup_unidvb_ci_register(struct netup_unidvb_dev
*dev
,
131 int num
, struct pci_dev
*pci_dev
);
132 void netup_unidvb_ci_unregister(struct netup_unidvb_dev
*dev
, int num
);
133 int netup_spi_init(struct netup_unidvb_dev
*ndev
);
134 void netup_spi_release(struct netup_unidvb_dev
*ndev
);