aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/dvb/siano/smsdvb.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/media/dvb/siano/smsdvb.c')
-rw-r--r--drivers/media/dvb/siano/smsdvb.c70
1 files changed, 38 insertions, 32 deletions
diff --git a/drivers/media/dvb/siano/smsdvb.c b/drivers/media/dvb/siano/smsdvb.c
index 65b1db61ac15..b17696fcbbc6 100644
--- a/drivers/media/dvb/siano/smsdvb.c
+++ b/drivers/media/dvb/siano/smsdvb.c
@@ -29,15 +29,16 @@ DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr);
29struct list_head g_smsdvb_clients; 29struct list_head g_smsdvb_clients;
30kmutex_t g_smsdvb_clientslock; 30kmutex_t g_smsdvb_clientslock;
31 31
32int smsdvb_onresponse(void *context, smscore_buffer_t *cb) 32int smsdvb_onresponse(void *context, struct smscore_buffer_t *cb)
33{ 33{
34 smsdvb_client_t *client = (smsdvb_client_t *) context; 34 struct smsdvb_client_t *client = (struct smsdvb_client_t *) context;
35 SmsMsgHdr_ST *phdr = (SmsMsgHdr_ST *)(((u8 *) cb->p) + cb->offset); 35 struct SmsMsgHdr_ST *phdr =
36 (struct SmsMsgHdr_ST *)(((u8 *) cb->p) + cb->offset);
36 37
37 switch (phdr->msgType) { 38 switch (phdr->msgType) {
38 case MSG_SMS_DVBT_BDA_DATA: 39 case MSG_SMS_DVBT_BDA_DATA:
39 dvb_dmx_swfilter(&client->demux, (u8 *)(phdr + 1), 40 dvb_dmx_swfilter(&client->demux, (u8 *)(phdr + 1),
40 cb->size - sizeof(SmsMsgHdr_ST)); 41 cb->size - sizeof(struct SmsMsgHdr_ST));
41 break; 42 break;
42 43
43 case MSG_SMS_RF_TUNE_RES: 44 case MSG_SMS_RF_TUNE_RES:
@@ -46,8 +47,8 @@ int smsdvb_onresponse(void *context, smscore_buffer_t *cb)
46 47
47 case MSG_SMS_GET_STATISTICS_RES: 48 case MSG_SMS_GET_STATISTICS_RES:
48 { 49 {
49 SmsMsgStatisticsInfo_ST *p = 50 struct SmsMsgStatisticsInfo_ST *p =
50 (SmsMsgStatisticsInfo_ST *)(phdr + 1); 51 (struct SmsMsgStatisticsInfo_ST *)(phdr + 1);
51 52
52 if (p->Stat.IsDemodLocked) { 53 if (p->Stat.IsDemodLocked) {
53 client->fe_status = FE_HAS_SIGNAL | 54 client->fe_status = FE_HAS_SIGNAL |
@@ -82,7 +83,7 @@ int smsdvb_onresponse(void *context, smscore_buffer_t *cb)
82 return 0; 83 return 0;
83} 84}
84 85
85void smsdvb_unregister_client(smsdvb_client_t *client) 86void smsdvb_unregister_client(struct smsdvb_client_t *client)
86{ 87{
87 /* must be called under clientslock */ 88 /* must be called under clientslock */
88 89
@@ -100,16 +101,16 @@ void smsdvb_onremove(void *context)
100{ 101{
101 kmutex_lock(&g_smsdvb_clientslock); 102 kmutex_lock(&g_smsdvb_clientslock);
102 103
103 smsdvb_unregister_client((smsdvb_client_t *) context); 104 smsdvb_unregister_client((struct smsdvb_client_t *) context);
104 105
105 kmutex_unlock(&g_smsdvb_clientslock); 106 kmutex_unlock(&g_smsdvb_clientslock);
106} 107}
107 108
108static int smsdvb_start_feed(struct dvb_demux_feed *feed) 109static int smsdvb_start_feed(struct dvb_demux_feed *feed)
109{ 110{
110 smsdvb_client_t *client = 111 struct smsdvb_client_t *client =
111 container_of(feed->demux, smsdvb_client_t, demux); 112 container_of(feed->demux, struct smsdvb_client_t, demux);
112 SmsMsgData_ST PidMsg; 113 struct SmsMsgData_ST PidMsg;
113 114
114 printk(KERN_DEBUG "%s add pid %d(%x)\n", __func__, 115 printk(KERN_DEBUG "%s add pid %d(%x)\n", __func__,
115 feed->pid, feed->pid); 116 feed->pid, feed->pid);
@@ -127,9 +128,9 @@ static int smsdvb_start_feed(struct dvb_demux_feed *feed)
127 128
128static int smsdvb_stop_feed(struct dvb_demux_feed *feed) 129static int smsdvb_stop_feed(struct dvb_demux_feed *feed)
129{ 130{
130 smsdvb_client_t *client = 131 struct smsdvb_client_t *client =
131 container_of(feed->demux, smsdvb_client_t, demux); 132 container_of(feed->demux, struct smsdvb_client_t, demux);
132 SmsMsgData_ST PidMsg; 133 struct SmsMsgData_ST PidMsg;
133 134
134 printk(KERN_DEBUG "%s remove pid %d(%x)\n", __func__, 135 printk(KERN_DEBUG "%s remove pid %d(%x)\n", __func__,
135 feed->pid, feed->pid); 136 feed->pid, feed->pid);
@@ -145,7 +146,7 @@ static int smsdvb_stop_feed(struct dvb_demux_feed *feed)
145 &PidMsg, sizeof(PidMsg)); 146 &PidMsg, sizeof(PidMsg));
146} 147}
147 148
148static int smsdvb_sendrequest_and_wait(smsdvb_client_t *client, 149static int smsdvb_sendrequest_and_wait(struct smsdvb_client_t *client,
149 void *buffer, size_t size, 150 void *buffer, size_t size,
150 struct completion *completion) 151 struct completion *completion)
151{ 152{
@@ -158,18 +159,19 @@ static int smsdvb_sendrequest_and_wait(smsdvb_client_t *client,
158 0 : -ETIME; 159 0 : -ETIME;
159} 160}
160 161
161static int smsdvb_send_statistics_request(smsdvb_client_t *client) 162static int smsdvb_send_statistics_request(struct smsdvb_client_t *client)
162{ 163{
163 SmsMsgHdr_ST Msg = { MSG_SMS_GET_STATISTICS_REQ, 164 struct SmsMsgHdr_ST Msg = { MSG_SMS_GET_STATISTICS_REQ,
164 DVBT_BDA_CONTROL_MSG_ID, 165 DVBT_BDA_CONTROL_MSG_ID,
165 HIF_TASK, sizeof(SmsMsgHdr_ST), 0 }; 166 HIF_TASK, sizeof(struct SmsMsgHdr_ST), 0 };
166 return smsdvb_sendrequest_and_wait(client, &Msg, sizeof(Msg), 167 return smsdvb_sendrequest_and_wait(client, &Msg, sizeof(Msg),
167 &client->stat_done); 168 &client->stat_done);
168} 169}
169 170
170static int smsdvb_read_status(struct dvb_frontend *fe, fe_status_t *stat) 171static int smsdvb_read_status(struct dvb_frontend *fe, fe_status_t *stat)
171{ 172{
172 smsdvb_client_t *client = container_of(fe, smsdvb_client_t, frontend); 173 struct smsdvb_client_t *client =
174 container_of(fe, struct smsdvb_client_t, frontend);
173 int rc = smsdvb_send_statistics_request(client); 175 int rc = smsdvb_send_statistics_request(client);
174 176
175 if (!rc) 177 if (!rc)
@@ -180,7 +182,8 @@ static int smsdvb_read_status(struct dvb_frontend *fe, fe_status_t *stat)
180 182
181static int smsdvb_read_ber(struct dvb_frontend *fe, u32 *ber) 183static int smsdvb_read_ber(struct dvb_frontend *fe, u32 *ber)
182{ 184{
183 smsdvb_client_t *client = container_of(fe, smsdvb_client_t, frontend); 185 struct smsdvb_client_t *client =
186 container_of(fe, struct smsdvb_client_t, frontend);
184 int rc = smsdvb_send_statistics_request(client); 187 int rc = smsdvb_send_statistics_request(client);
185 188
186 if (!rc) 189 if (!rc)
@@ -191,7 +194,8 @@ static int smsdvb_read_ber(struct dvb_frontend *fe, u32 *ber)
191 194
192static int smsdvb_read_signal_strength(struct dvb_frontend *fe, u16 *strength) 195static int smsdvb_read_signal_strength(struct dvb_frontend *fe, u16 *strength)
193{ 196{
194 smsdvb_client_t *client = container_of(fe, smsdvb_client_t, frontend); 197 struct smsdvb_client_t *client =
198 container_of(fe, struct smsdvb_client_t, frontend);
195 int rc = smsdvb_send_statistics_request(client); 199 int rc = smsdvb_send_statistics_request(client);
196 200
197 if (!rc) 201 if (!rc)
@@ -202,7 +206,8 @@ static int smsdvb_read_signal_strength(struct dvb_frontend *fe, u16 *strength)
202 206
203static int smsdvb_read_snr(struct dvb_frontend *fe, u16 *snr) 207static int smsdvb_read_snr(struct dvb_frontend *fe, u16 *snr)
204{ 208{
205 smsdvb_client_t *client = container_of(fe, smsdvb_client_t, frontend); 209 struct smsdvb_client_t *client =
210 container_of(fe, struct smsdvb_client_t, frontend);
206 int rc = smsdvb_send_statistics_request(client); 211 int rc = smsdvb_send_statistics_request(client);
207 212
208 if (!rc) 213 if (!rc)
@@ -225,11 +230,11 @@ static int smsdvb_get_tune_settings(struct dvb_frontend *fe,
225static int smsdvb_set_frontend(struct dvb_frontend *fe, 230static int smsdvb_set_frontend(struct dvb_frontend *fe,
226 struct dvb_frontend_parameters *fep) 231 struct dvb_frontend_parameters *fep)
227{ 232{
228 smsdvb_client_t *client = container_of(fe, smsdvb_client_t, frontend); 233 struct smsdvb_client_t *client =
234 container_of(fe, struct smsdvb_client_t, frontend);
229 235
230 struct 236 struct {
231 { 237 struct SmsMsgHdr_ST Msg;
232 SmsMsgHdr_ST Msg;
233 u32 Data[3]; 238 u32 Data[3];
234 } Msg; 239 } Msg;
235 240
@@ -259,7 +264,8 @@ static int smsdvb_set_frontend(struct dvb_frontend *fe,
259static int smsdvb_get_frontend(struct dvb_frontend *fe, 264static int smsdvb_get_frontend(struct dvb_frontend *fe,
260 struct dvb_frontend_parameters *fep) 265 struct dvb_frontend_parameters *fep)
261{ 266{
262 smsdvb_client_t *client = container_of(fe, smsdvb_client_t, frontend); 267 struct smsdvb_client_t *client =
268 container_of(fe, struct smsdvb_client_t, frontend);
263 269
264 printk(KERN_DEBUG "%s\n", __func__); 270 printk(KERN_DEBUG "%s\n", __func__);
265 271
@@ -303,11 +309,11 @@ static struct dvb_frontend_ops smsdvb_fe_ops = {
303 .read_snr = smsdvb_read_snr, 309 .read_snr = smsdvb_read_snr,
304}; 310};
305 311
306int smsdvb_hotplug(smscore_device_t *coredev, 312int smsdvb_hotplug(struct smscore_device_t *coredev,
307 struct device *device, int arrival) 313 struct device *device, int arrival)
308{ 314{
309 smsclient_params_t params; 315 struct smsclient_params_t params;
310 smsdvb_client_t *client; 316 struct smsdvb_client_t *client;
311 int rc; 317 int rc;
312 318
313 /* device removal handled by onremove callback */ 319 /* device removal handled by onremove callback */
@@ -320,7 +326,7 @@ int smsdvb_hotplug(smscore_device_t *coredev,
320 return 0; 326 return 0;
321 } 327 }
322 328
323 client = kzalloc(sizeof(smsdvb_client_t), GFP_KERNEL); 329 client = kzalloc(sizeof(struct smsdvb_client_t), GFP_KERNEL);
324 if (!client) { 330 if (!client) {
325 printk(KERN_INFO "%s kmalloc() failed\n", __func__); 331 printk(KERN_INFO "%s kmalloc() failed\n", __func__);
326 return -ENOMEM; 332 return -ENOMEM;
@@ -439,7 +445,7 @@ void smsdvb_unregister(void)
439 445
440 while (!list_empty(&g_smsdvb_clients)) 446 while (!list_empty(&g_smsdvb_clients))
441 smsdvb_unregister_client( 447 smsdvb_unregister_client(
442 (smsdvb_client_t *) g_smsdvb_clients.next); 448 (struct smsdvb_client_t *) g_smsdvb_clients.next);
443 449
444 kmutex_unlock(&g_smsdvb_clientslock); 450 kmutex_unlock(&g_smsdvb_clientslock);
445} 451}