aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/staging/cxd2099/cxd2099.c75
-rw-r--r--drivers/staging/cxd2099/cxd2099.h6
2 files changed, 40 insertions, 41 deletions
diff --git a/drivers/staging/cxd2099/cxd2099.c b/drivers/staging/cxd2099/cxd2099.c
index 803a592b3507..6ec30c1fd4cb 100644
--- a/drivers/staging/cxd2099/cxd2099.c
+++ b/drivers/staging/cxd2099/cxd2099.c
@@ -64,7 +64,7 @@ static int i2c_write_reg(struct i2c_adapter *adapter, u8 adr,
64 u8 reg, u8 data) 64 u8 reg, u8 data)
65{ 65{
66 u8 m[2] = {reg, data}; 66 u8 m[2] = {reg, data};
67 struct i2c_msg msg = {.addr=adr, .flags=0, .buf=m, .len=2}; 67 struct i2c_msg msg = {.addr = adr, .flags = 0, .buf = m, .len = 2};
68 68
69 if (i2c_transfer(adapter, &msg, 1) != 1) { 69 if (i2c_transfer(adapter, &msg, 1) != 1) {
70 printk(KERN_ERR "Failed to write to I2C register %02x@%02x!\n", 70 printk(KERN_ERR "Failed to write to I2C register %02x@%02x!\n",
@@ -77,7 +77,7 @@ static int i2c_write_reg(struct i2c_adapter *adapter, u8 adr,
77static int i2c_write(struct i2c_adapter *adapter, u8 adr, 77static int i2c_write(struct i2c_adapter *adapter, u8 adr,
78 u8 *data, u8 len) 78 u8 *data, u8 len)
79{ 79{
80 struct i2c_msg msg = {.addr=adr, .flags=0, .buf=data, .len=len}; 80 struct i2c_msg msg = {.addr = adr, .flags = 0, .buf = data, .len = len};
81 81
82 if (i2c_transfer(adapter, &msg, 1) != 1) { 82 if (i2c_transfer(adapter, &msg, 1) != 1) {
83 printk(KERN_ERR "Failed to write to I2C!\n"); 83 printk(KERN_ERR "Failed to write to I2C!\n");
@@ -92,7 +92,7 @@ static int i2c_read_reg(struct i2c_adapter *adapter, u8 adr,
92 struct i2c_msg msgs[2] = {{.addr = adr, .flags = 0, 92 struct i2c_msg msgs[2] = {{.addr = adr, .flags = 0,
93 .buf = &reg, .len = 1}, 93 .buf = &reg, .len = 1},
94 {.addr = adr, .flags = I2C_M_RD, 94 {.addr = adr, .flags = I2C_M_RD,
95 .buf = val, .len = 1}}; 95 .buf = val, .len = 1} };
96 96
97 if (i2c_transfer(adapter, msgs, 2) != 2) { 97 if (i2c_transfer(adapter, msgs, 2) != 2) {
98 printk(KERN_ERR "error in i2c_read_reg\n"); 98 printk(KERN_ERR "error in i2c_read_reg\n");
@@ -107,7 +107,7 @@ static int i2c_read(struct i2c_adapter *adapter, u8 adr,
107 struct i2c_msg msgs[2] = {{.addr = adr, .flags = 0, 107 struct i2c_msg msgs[2] = {{.addr = adr, .flags = 0,
108 .buf = &reg, .len = 1}, 108 .buf = &reg, .len = 1},
109 {.addr = adr, .flags = I2C_M_RD, 109 {.addr = adr, .flags = I2C_M_RD,
110 .buf = data, .len = n}}; 110 .buf = data, .len = n} };
111 111
112 if (i2c_transfer(adapter, msgs, 2) != 2) { 112 if (i2c_transfer(adapter, msgs, 2) != 2) {
113 printk(KERN_ERR "error in i2c_read\n"); 113 printk(KERN_ERR "error in i2c_read\n");
@@ -139,7 +139,7 @@ static int read_pccard(struct cxd *ci, u16 address, u8 *data, u8 n)
139 int status; 139 int status;
140 u8 addr[3] = {2, address & 0xff, address >> 8}; 140 u8 addr[3] = {2, address & 0xff, address >> 8};
141 141
142 status=i2c_write(ci->i2c, ci->cfg.adr, addr, 3); 142 status = i2c_write(ci->i2c, ci->cfg.adr, addr, 3);
143 if (!status) 143 if (!status)
144 status = i2c_read(ci->i2c, ci->cfg.adr, 3, data, n); 144 status = i2c_read(ci->i2c, ci->cfg.adr, 3, data, n);
145 return status; 145 return status;
@@ -150,7 +150,7 @@ static int write_pccard(struct cxd *ci, u16 address, u8 *data, u8 n)
150 int status; 150 int status;
151 u8 addr[3] = {2, address & 0xff, address >> 8}; 151 u8 addr[3] = {2, address & 0xff, address >> 8};
152 152
153 status=i2c_write(ci->i2c, ci->cfg.adr, addr, 3); 153 status = i2c_write(ci->i2c, ci->cfg.adr, addr, 3);
154 if (!status) { 154 if (!status) {
155 u8 buf[256] = {3}; 155 u8 buf[256] = {3};
156 memcpy(buf+1, data, n); 156 memcpy(buf+1, data, n);
@@ -213,8 +213,8 @@ static int write_regm(struct cxd *ci, u8 reg, u8 val, u8 mask)
213{ 213{
214 int status; 214 int status;
215 215
216 status=i2c_write_reg(ci->i2c, ci->cfg.adr, 0, reg); 216 status = i2c_write_reg(ci->i2c, ci->cfg.adr, 0, reg);
217 if (!status && reg >= 6 && reg <=8 && mask != 0xff) 217 if (!status && reg >= 6 && reg <= 8 && mask != 0xff)
218 status = i2c_read_reg(ci->i2c, ci->cfg.adr, 1, &ci->regs[reg]); 218 status = i2c_read_reg(ci->i2c, ci->cfg.adr, 1, &ci->regs[reg]);
219 ci->regs[reg] = (ci->regs[reg] & (~mask)) | val; 219 ci->regs[reg] = (ci->regs[reg] & (~mask)) | val;
220 if (!status) { 220 if (!status) {
@@ -294,14 +294,14 @@ static void cam_mode(struct cxd *ci, int mode)
294 294
295 295
296 296
297#define CHK_ERROR(s) if( (status = s) ) break 297#define CHK_ERROR(s) if ((status = s)) break
298 298
299static int init(struct cxd *ci) 299static int init(struct cxd *ci)
300{ 300{
301 int status; 301 int status;
302 302
303 mutex_lock(&ci->lock); 303 mutex_lock(&ci->lock);
304 ci->mode=-1; 304 ci->mode = -1;
305 do { 305 do {
306 CHK_ERROR(write_reg(ci, 0x00, 0x00)); 306 CHK_ERROR(write_reg(ci, 0x00, 0x00));
307 CHK_ERROR(write_reg(ci, 0x01, 0x00)); 307 CHK_ERROR(write_reg(ci, 0x01, 0x00));
@@ -322,7 +322,7 @@ static int init(struct cxd *ci)
322 CHK_ERROR(write_regm(ci, 0x14, 0x00, 0x0F)); 322 CHK_ERROR(write_regm(ci, 0x14, 0x00, 0x0F));
323 CHK_ERROR(write_reg(ci, 0x15, ci->clk_reg_b)); 323 CHK_ERROR(write_reg(ci, 0x15, ci->clk_reg_b));
324 CHK_ERROR(write_regm(ci, 0x16, 0x00, 0x0F)); 324 CHK_ERROR(write_regm(ci, 0x16, 0x00, 0x0F));
325 CHK_ERROR(write_reg(ci, 0x17,ci->clk_reg_f)); 325 CHK_ERROR(write_reg(ci, 0x17, ci->clk_reg_f));
326 326
327 if (ci->cfg.clock_mode) { 327 if (ci->cfg.clock_mode) {
328 if (ci->cfg.polarity) { 328 if (ci->cfg.polarity) {
@@ -352,9 +352,9 @@ static int init(struct cxd *ci)
352 352
353 /* Put TS in bypass */ 353 /* Put TS in bypass */
354 CHK_ERROR(write_regm(ci, 0x09, 0x08, 0x08)); 354 CHK_ERROR(write_regm(ci, 0x09, 0x08, 0x08));
355 ci->cammode=-1; 355 ci->cammode = -1;
356 cam_mode(ci, 0); 356 cam_mode(ci, 0);
357 } while(0); 357 } while (0);
358 mutex_unlock(&ci->lock); 358 mutex_unlock(&ci->lock);
359 359
360 return 0; 360 return 0;
@@ -366,7 +366,7 @@ static int read_attribute_mem(struct dvb_ca_en50221 *ca,
366 struct cxd *ci = ca->data; 366 struct cxd *ci = ca->data;
367#if 0 367#if 0
368 if (ci->amem_read) { 368 if (ci->amem_read) {
369 if (address <=0 || address>1024) 369 if (address <= 0 || address > 1024)
370 return -EIO; 370 return -EIO;
371 return ci->amem[address]; 371 return ci->amem[address];
372 } 372 }
@@ -386,7 +386,7 @@ static int read_attribute_mem(struct dvb_ca_en50221 *ca,
386 set_mode(ci, 1); 386 set_mode(ci, 1);
387 read_pccard(ci, address, &val, 1); 387 read_pccard(ci, address, &val, 1);
388 mutex_unlock(&ci->lock); 388 mutex_unlock(&ci->lock);
389 //printk("%02x:%02x\n", address,val); 389 /* printk(KERN_INFO "%02x:%02x\n", address,val); */
390 return val; 390 return val;
391#endif 391#endif
392} 392}
@@ -448,19 +448,19 @@ static int slot_reset(struct dvb_ca_en50221 *ca, int slot)
448 write_reg(ci, 0x00, 0x31); 448 write_reg(ci, 0x00, 0x31);
449 write_regm(ci, 0x20, 0x80, 0x80); 449 write_regm(ci, 0x20, 0x80, 0x80);
450 write_reg(ci, 0x03, 0x02); 450 write_reg(ci, 0x03, 0x02);
451 ci->ready=0; 451 ci->ready = 0;
452#endif 452#endif
453#endif 453#endif
454 ci->mode=-1; 454 ci->mode = -1;
455 { 455 {
456 int i; 456 int i;
457#if 0 457#if 0
458 u8 val; 458 u8 val;
459#endif 459#endif
460 for (i=0; i<100;i++) { 460 for (i = 0; i < 100; i++) {
461 msleep(10); 461 msleep(10);
462#if 0 462#if 0
463 read_reg(ci, 0x06,&val); 463 read_reg(ci, 0x06, &val);
464 printk(KERN_INFO "%d:%02x\n", i, val); 464 printk(KERN_INFO "%d:%02x\n", i, val);
465 if (!(val&0x10)) 465 if (!(val&0x10))
466 break; 466 break;
@@ -514,7 +514,7 @@ static int campoll(struct cxd *ci)
514 write_reg(ci, 0x05, istat); 514 write_reg(ci, 0x05, istat);
515 515
516 if (istat&0x40) { 516 if (istat&0x40) {
517 ci->dr=1; 517 ci->dr = 1;
518 printk(KERN_INFO "DR\n"); 518 printk(KERN_INFO "DR\n");
519 } 519 }
520 if (istat&0x20) 520 if (istat&0x20)
@@ -526,21 +526,21 @@ static int campoll(struct cxd *ci)
526 read_reg(ci, 0x01, &slotstat); 526 read_reg(ci, 0x01, &slotstat);
527 if (!(2&slotstat)) { 527 if (!(2&slotstat)) {
528 if (!ci->slot_stat) { 528 if (!ci->slot_stat) {
529 ci->slot_stat|=DVB_CA_EN50221_POLL_CAM_PRESENT; 529 ci->slot_stat |= DVB_CA_EN50221_POLL_CAM_PRESENT;
530 write_regm(ci, 0x03, 0x08, 0x08); 530 write_regm(ci, 0x03, 0x08, 0x08);
531 } 531 }
532 532
533 } else { 533 } else {
534 if (ci->slot_stat) { 534 if (ci->slot_stat) {
535 ci->slot_stat=0; 535 ci->slot_stat = 0;
536 write_regm(ci, 0x03, 0x00, 0x08); 536 write_regm(ci, 0x03, 0x00, 0x08);
537 printk(KERN_INFO "NO CAM\n"); 537 printk(KERN_INFO "NO CAM\n");
538 ci->ready=0; 538 ci->ready = 0;
539 } 539 }
540 } 540 }
541 if (istat&8 && ci->slot_stat==DVB_CA_EN50221_POLL_CAM_PRESENT) { 541 if (istat&8 && ci->slot_stat == DVB_CA_EN50221_POLL_CAM_PRESENT) {
542 ci->ready=1; 542 ci->ready = 1;
543 ci->slot_stat|=DVB_CA_EN50221_POLL_CAM_READY; 543 ci->slot_stat |= DVB_CA_EN50221_POLL_CAM_READY;
544 } 544 }
545 } 545 }
546 return 0; 546 return 0;
@@ -561,7 +561,7 @@ static int poll_slot_status(struct dvb_ca_en50221 *ca, int slot, int open)
561} 561}
562 562
563#ifdef BUFFER_MODE 563#ifdef BUFFER_MODE
564static int read_data(struct dvb_ca_en50221* ca, int slot, u8 *ebuf, int ecount) 564static int read_data(struct dvb_ca_en50221 *ca, int slot, u8 *ebuf, int ecount)
565{ 565{
566 struct cxd *ci = ca->data; 566 struct cxd *ci = ca->data;
567 u8 msb, lsb; 567 u8 msb, lsb;
@@ -578,20 +578,20 @@ static int read_data(struct dvb_ca_en50221* ca, int slot, u8 *ebuf, int ecount)
578 mutex_lock(&ci->lock); 578 mutex_lock(&ci->lock);
579 read_reg(ci, 0x0f, &msb); 579 read_reg(ci, 0x0f, &msb);
580 read_reg(ci, 0x10, &lsb); 580 read_reg(ci, 0x10, &lsb);
581 len=(msb<<8)|lsb; 581 len = (msb<<8)|lsb;
582 read_block(ci, 0x12, ebuf, len); 582 read_block(ci, 0x12, ebuf, len);
583 ci->dr=0; 583 ci->dr = 0;
584 mutex_unlock(&ci->lock); 584 mutex_unlock(&ci->lock);
585 585
586 return len; 586 return len;
587} 587}
588 588
589static int write_data(struct dvb_ca_en50221* ca, int slot, u8 * ebuf, int ecount) 589static int write_data(struct dvb_ca_en50221 *ca, int slot, u8 *ebuf, int ecount)
590{ 590{
591 struct cxd *ci = ca->data; 591 struct cxd *ci = ca->data;
592 592
593 mutex_lock(&ci->lock); 593 mutex_lock(&ci->lock);
594 printk("write_data %d\n", ecount); 594 printk(kern_INFO "write_data %d\n", ecount);
595 write_reg(ci, 0x0d, ecount>>8); 595 write_reg(ci, 0x0d, ecount>>8);
596 write_reg(ci, 0x0e, ecount&0xff); 596 write_reg(ci, 0x0e, ecount&0xff);
597 write_block(ci, 0x11, ebuf, ecount); 597 write_block(ci, 0x11, ebuf, ecount);
@@ -623,8 +623,8 @@ struct dvb_ca_en50221 *cxd2099_attach(struct cxd2099_cfg *cfg,
623 struct cxd *ci = 0; 623 struct cxd *ci = 0;
624 u8 val; 624 u8 val;
625 625
626 if (i2c_read_reg(i2c, cfg->adr, 0, &val)<0) { 626 if (i2c_read_reg(i2c, cfg->adr, 0, &val) < 0) {
627 printk("No CXD2099 detected at %02x\n", cfg->adr); 627 printk(KERN_INFO "No CXD2099 detected at %02x\n", cfg->adr);
628 return 0; 628 return 0;
629 } 629 }
630 630
@@ -636,17 +636,16 @@ struct dvb_ca_en50221 *cxd2099_attach(struct cxd2099_cfg *cfg,
636 mutex_init(&ci->lock); 636 mutex_init(&ci->lock);
637 memcpy(&ci->cfg, cfg, sizeof(struct cxd2099_cfg)); 637 memcpy(&ci->cfg, cfg, sizeof(struct cxd2099_cfg));
638 ci->i2c = i2c; 638 ci->i2c = i2c;
639 ci->lastaddress=0xff; 639 ci->lastaddress = 0xff;
640 ci->clk_reg_b=0x4a; 640 ci->clk_reg_b = 0x4a;
641 ci->clk_reg_f=0x1b; 641 ci->clk_reg_f = 0x1b;
642 642
643 memcpy(&ci->en, &en_templ, sizeof(en_templ)); 643 memcpy(&ci->en, &en_templ, sizeof(en_templ));
644 ci->en.data=ci; 644 ci->en.data = ci;
645 init(ci); 645 init(ci);
646 printk(KERN_INFO "Attached CXD2099AR at %02x\n", ci->cfg.adr); 646 printk(KERN_INFO "Attached CXD2099AR at %02x\n", ci->cfg.adr);
647 return &ci->en; 647 return &ci->en;
648} 648}
649
650EXPORT_SYMBOL(cxd2099_attach); 649EXPORT_SYMBOL(cxd2099_attach);
651 650
652MODULE_DESCRIPTION("cxd2099"); 651MODULE_DESCRIPTION("cxd2099");
diff --git a/drivers/staging/cxd2099/cxd2099.h b/drivers/staging/cxd2099/cxd2099.h
index cf26c93de096..75459d41afc1 100644
--- a/drivers/staging/cxd2099/cxd2099.h
+++ b/drivers/staging/cxd2099/cxd2099.h
@@ -30,12 +30,12 @@
30struct cxd2099_cfg { 30struct cxd2099_cfg {
31 u32 bitrate; 31 u32 bitrate;
32 u8 adr; 32 u8 adr;
33 u8 polarity : 1; 33 u8 polarity:1;
34 u8 clock_mode : 1; 34 u8 clock_mode:1;
35}; 35};
36 36
37#if defined(CONFIG_DVB_CXD2099) || \ 37#if defined(CONFIG_DVB_CXD2099) || \
38 (defined(CONFIG_DVB_CXD2099_MODULE) && defined(MODULE)) 38 (defined(CONFIG_DVB_CXD2099_MODULE) && defined(MODULE))
39struct dvb_ca_en50221 *cxd2099_attach(struct cxd2099_cfg *cfg, 39struct dvb_ca_en50221 *cxd2099_attach(struct cxd2099_cfg *cfg,
40 void *priv, struct i2c_adapter *i2c); 40 void *priv, struct i2c_adapter *i2c);
41#else 41#else