diff options
author | Jean-Francois Moine <moinejf@free.fr> | 2008-07-18 07:46:19 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@infradead.org> | 2008-07-23 18:00:23 -0400 |
commit | 600176176101fc6e0e0c7468efa83203e8d3e015 (patch) | |
tree | 8d28215d2bd92e2692716a4e50ac1a1260230004 /drivers/media | |
parent | 2864462eaf027ff10c1df1ce57d3518332e9083c (diff) |
V4L/DVB (8435): gspca: Delay after reset for ov7660 and USB traces in sonixj.
Signed-off-by: Jean-Francois Moine <moinejf@free.fr>
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
Diffstat (limited to 'drivers/media')
-rw-r--r-- | drivers/media/video/gspca/sonixj.c | 246 |
1 files changed, 118 insertions, 128 deletions
diff --git a/drivers/media/video/gspca/sonixj.c b/drivers/media/video/gspca/sonixj.c index 3e68b9926956..aa4d10b823ea 100644 --- a/drivers/media/video/gspca/sonixj.c +++ b/drivers/media/video/gspca/sonixj.c | |||
@@ -361,6 +361,7 @@ static const __u8 mo4000_sensor_init[][8] = { | |||
361 | }; | 361 | }; |
362 | static const __u8 ov7660_sensor_init[][8] = { | 362 | static const __u8 ov7660_sensor_init[][8] = { |
363 | {0xa1, 0x21, 0x12, 0x80, 0x00, 0x00, 0x00, 0x10}, /* reset SCCB */ | 363 | {0xa1, 0x21, 0x12, 0x80, 0x00, 0x00, 0x00, 0x10}, /* reset SCCB */ |
364 | /* (delay 20ms) */ | ||
364 | {0xa1, 0x21, 0x12, 0x05, 0x00, 0x00, 0x00, 0x10}, | 365 | {0xa1, 0x21, 0x12, 0x05, 0x00, 0x00, 0x00, 0x10}, |
365 | /* Outformat ?? rawRGB */ | 366 | /* Outformat ?? rawRGB */ |
366 | {0xa1, 0x21, 0x13, 0xb8, 0x00, 0x00, 0x00, 0x10}, /* init COM8 */ | 367 | {0xa1, 0x21, 0x13, 0xb8, 0x00, 0x00, 0x00, 0x10}, /* init COM8 */ |
@@ -539,13 +540,31 @@ static void reg_r(struct gspca_dev *gspca_dev, | |||
539 | value, 0, | 540 | value, 0, |
540 | gspca_dev->usb_buf, len, | 541 | gspca_dev->usb_buf, len, |
541 | 500); | 542 | 500); |
543 | PDEBUG(D_USBI, "reg_r [%02x] -> %02x", value, gspca_dev->usb_buf[0]); | ||
542 | } | 544 | } |
543 | 545 | ||
546 | static void reg_w1(struct gspca_dev *gspca_dev, | ||
547 | __u16 value, | ||
548 | __u8 data) | ||
549 | { | ||
550 | PDEBUG(D_USBO, "reg_w1 [%02x] = %02x", value, data); | ||
551 | gspca_dev->usb_buf[0] = data; | ||
552 | usb_control_msg(gspca_dev->dev, | ||
553 | usb_sndctrlpipe(gspca_dev->dev, 0), | ||
554 | 0x08, | ||
555 | USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_INTERFACE, | ||
556 | value, | ||
557 | 0, | ||
558 | gspca_dev->usb_buf, 1, | ||
559 | 500); | ||
560 | } | ||
544 | static void reg_w(struct gspca_dev *gspca_dev, | 561 | static void reg_w(struct gspca_dev *gspca_dev, |
545 | __u16 value, | 562 | __u16 value, |
546 | const __u8 *buffer, | 563 | const __u8 *buffer, |
547 | int len) | 564 | int len) |
548 | { | 565 | { |
566 | PDEBUG(D_USBO, "reg_w [%02x] = %02x %02x ..", | ||
567 | value, buffer[0], buffer[1]); | ||
549 | if (len <= sizeof gspca_dev->usb_buf) { | 568 | if (len <= sizeof gspca_dev->usb_buf) { |
550 | memcpy(gspca_dev->usb_buf, buffer, len); | 569 | memcpy(gspca_dev->usb_buf, buffer, len); |
551 | usb_control_msg(gspca_dev->dev, | 570 | usb_control_msg(gspca_dev->dev, |
@@ -571,31 +590,42 @@ static void reg_w(struct gspca_dev *gspca_dev, | |||
571 | } | 590 | } |
572 | } | 591 | } |
573 | 592 | ||
574 | /* I2C write 2 bytes */ | 593 | /* I2C write 1 byte */ |
575 | static void i2c_w2(struct gspca_dev *gspca_dev, | 594 | static void i2c_w1(struct gspca_dev *gspca_dev, __u8 reg, __u8 val) |
576 | const __u8 *buffer) | ||
577 | { | 595 | { |
578 | struct sd *sd = (struct sd *) gspca_dev; | 596 | struct sd *sd = (struct sd *) gspca_dev; |
579 | __u8 mode[8]; | ||
580 | 597 | ||
581 | /* is i2c ready */ | 598 | PDEBUG(D_USBO, "i2c_w2 [%02x] = %02x", reg, val); |
582 | mode[0] = 0x81 | (2 << 4); | 599 | gspca_dev->usb_buf[0] = 0x81 | (2 << 4); /* = a1 */ |
583 | mode[1] = sd->i2c_base; | 600 | gspca_dev->usb_buf[1] = sd->i2c_base; |
584 | mode[2] = buffer[0]; | 601 | gspca_dev->usb_buf[2] = reg; |
585 | mode[3] = buffer[1]; | 602 | gspca_dev->usb_buf[3] = val; |
586 | mode[4] = 0; | 603 | gspca_dev->usb_buf[4] = 0; |
587 | mode[5] = 0; | 604 | gspca_dev->usb_buf[5] = 0; |
588 | mode[6] = 0; | 605 | gspca_dev->usb_buf[6] = 0; |
589 | mode[7] = 0x10; | 606 | gspca_dev->usb_buf[7] = 0x10; |
590 | reg_w(gspca_dev, 0x08, mode, 8); | 607 | usb_control_msg(gspca_dev->dev, |
608 | usb_sndctrlpipe(gspca_dev->dev, 0), | ||
609 | 0x08, | ||
610 | USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_INTERFACE, | ||
611 | 0x08, /* value = i2c */ | ||
612 | 0, | ||
613 | gspca_dev->usb_buf, 8, | ||
614 | 500); | ||
591 | } | 615 | } |
592 | 616 | ||
593 | /* I2C write 8 bytes */ | 617 | /* I2C write 8 bytes */ |
594 | static void i2c_w8(struct gspca_dev *gspca_dev, | 618 | static void i2c_w8(struct gspca_dev *gspca_dev, |
595 | const __u8 *buffer) | 619 | const __u8 *buffer) |
596 | { | 620 | { |
597 | reg_w(gspca_dev, 0x08, buffer, 8); | 621 | memcpy(gspca_dev->usb_buf, buffer, 8); |
598 | msleep(1); | 622 | usb_control_msg(gspca_dev->dev, |
623 | usb_sndctrlpipe(gspca_dev->dev, 0), | ||
624 | 0x08, | ||
625 | USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_INTERFACE, | ||
626 | 0x08, 0, /* value, index */ | ||
627 | gspca_dev->usb_buf, 8, | ||
628 | 500); | ||
599 | } | 629 | } |
600 | 630 | ||
601 | /* read 5 bytes in gspca_dev->usb_buf */ | 631 | /* read 5 bytes in gspca_dev->usb_buf */ |
@@ -613,24 +643,21 @@ static void i2c_r5(struct gspca_dev *gspca_dev, __u8 reg) | |||
613 | mode[6] = 0; | 643 | mode[6] = 0; |
614 | mode[7] = 0x10; | 644 | mode[7] = 0x10; |
615 | i2c_w8(gspca_dev, mode); | 645 | i2c_w8(gspca_dev, mode); |
646 | msleep(2); | ||
616 | mode[0] = 0x81 | (5 << 4) | 0x02; | 647 | mode[0] = 0x81 | (5 << 4) | 0x02; |
617 | mode[2] = 0; | 648 | mode[2] = 0; |
618 | i2c_w8(gspca_dev, mode); | 649 | i2c_w8(gspca_dev, mode); |
650 | msleep(2); | ||
619 | reg_r(gspca_dev, 0x0a, 5); | 651 | reg_r(gspca_dev, 0x0a, 5); |
620 | } | 652 | } |
621 | 653 | ||
622 | static int probesensor(struct gspca_dev *gspca_dev) | 654 | static int probesensor(struct gspca_dev *gspca_dev) |
623 | { | 655 | { |
624 | struct sd *sd = (struct sd *) gspca_dev; | 656 | struct sd *sd = (struct sd *) gspca_dev; |
625 | __u8 reg02; | ||
626 | static const __u8 datasend[] = { 2, 0 }; | ||
627 | /* reg val1 val2 val3 val4 */ | ||
628 | 657 | ||
629 | i2c_w2(gspca_dev, datasend); | 658 | i2c_w1(gspca_dev, 0x02, 0); /* sensor wakeup */ |
630 | /* should write 0xa1 0x11 0x02 0x00 0x00 0x00 0x00 the 0x10 is add by i2cw */ | ||
631 | msleep(10); | 659 | msleep(10); |
632 | reg02 = 0x66; | 660 | reg_w1(gspca_dev, 0x02, 0x66); /* Gpio on */ |
633 | reg_w(gspca_dev, 0x02, ®02, 1); /* Gpio on */ | ||
634 | msleep(10); | 661 | msleep(10); |
635 | i2c_r5(gspca_dev, 0); /* read sensor id */ | 662 | i2c_r5(gspca_dev, 0); /* read sensor id */ |
636 | if (gspca_dev->usb_buf[0] == 0x02 | 663 | if (gspca_dev->usb_buf[0] == 0x02 |
@@ -642,7 +669,7 @@ static int probesensor(struct gspca_dev *gspca_dev) | |||
642 | sd->sensor = SENSOR_HV7131R; | 669 | sd->sensor = SENSOR_HV7131R; |
643 | return SENSOR_HV7131R; | 670 | return SENSOR_HV7131R; |
644 | } | 671 | } |
645 | PDEBUG(D_PROBE, "Find Sensor %d %d %d", | 672 | PDEBUG(D_PROBE, "Find Sensor 0x%02x 0x%02x 0x%02x", |
646 | gspca_dev->usb_buf[0], gspca_dev->usb_buf[1], | 673 | gspca_dev->usb_buf[0], gspca_dev->usb_buf[1], |
647 | gspca_dev->usb_buf[2]); | 674 | gspca_dev->usb_buf[2]); |
648 | PDEBUG(D_PROBE, "Sensor sn9c102P Not found"); | 675 | PDEBUG(D_PROBE, "Sensor sn9c102P Not found"); |
@@ -653,8 +680,6 @@ static int configure_gpio(struct gspca_dev *gspca_dev, | |||
653 | const __u8 *sn9c1xx) | 680 | const __u8 *sn9c1xx) |
654 | { | 681 | { |
655 | struct sd *sd = (struct sd *) gspca_dev; | 682 | struct sd *sd = (struct sd *) gspca_dev; |
656 | __u8 data; | ||
657 | __u8 regF1; | ||
658 | const __u8 *reg9a; | 683 | const __u8 *reg9a; |
659 | static const __u8 reg9a_def[] = | 684 | static const __u8 reg9a_def[] = |
660 | {0x08, 0x40, 0x20, 0x10, 0x00, 0x04}; | 685 | {0x08, 0x40, 0x20, 0x10, 0x00, 0x04}; |
@@ -663,15 +688,13 @@ static int configure_gpio(struct gspca_dev *gspca_dev, | |||
663 | static const __u8 reg9a_sn9c325[] = | 688 | static const __u8 reg9a_sn9c325[] = |
664 | {0x0a, 0x40, 0x38, 0x30, 0x00, 0x20}; | 689 | {0x0a, 0x40, 0x38, 0x30, 0x00, 0x20}; |
665 | 690 | ||
666 | 691 | reg_w1(gspca_dev, 0xf1, 0x00); | |
667 | regF1 = 0x00; | 692 | reg_w1(gspca_dev, 0x01, sn9c1xx[0]); /*fixme:jfm was [1] en v1*/ |
668 | reg_w(gspca_dev, 0xf1, ®F1, 1); | ||
669 | reg_w(gspca_dev, 0x01, &sn9c1xx[0], 1); /*fixme:jfm was [1] en v1*/ | ||
670 | 693 | ||
671 | /* configure gpio */ | 694 | /* configure gpio */ |
672 | reg_w(gspca_dev, 0x01, &sn9c1xx[1], 2); | 695 | reg_w(gspca_dev, 0x01, &sn9c1xx[1], 2); |
673 | reg_w(gspca_dev, 0x08, &sn9c1xx[8], 2); | 696 | reg_w(gspca_dev, 0x08, &sn9c1xx[8], 2); |
674 | reg_w(gspca_dev, 0x17, &sn9c1xx[0x17], 5); /* jfm was 3 */ | 697 | reg_w(gspca_dev, 0x17, &sn9c1xx[0x17], 5); /* jfm len was 3 */ |
675 | switch (sd->bridge) { | 698 | switch (sd->bridge) { |
676 | case BRIDGE_SN9C325: | 699 | case BRIDGE_SN9C325: |
677 | reg9a = reg9a_sn9c325; | 700 | reg9a = reg9a_sn9c325; |
@@ -685,35 +708,25 @@ static int configure_gpio(struct gspca_dev *gspca_dev, | |||
685 | } | 708 | } |
686 | reg_w(gspca_dev, 0x9a, reg9a, 6); | 709 | reg_w(gspca_dev, 0x9a, reg9a, 6); |
687 | 710 | ||
688 | data = 0x60; /*fixme:jfm 60 00 00 (3) */ | 711 | reg_w1(gspca_dev, 0xd4, 0x60); /*fixme:jfm 60 00 00 (3) ? */ |
689 | reg_w(gspca_dev, 0xd4, &data, 1); | ||
690 | 712 | ||
691 | reg_w(gspca_dev, 0x03, &sn9c1xx[3], 0x0f); | 713 | reg_w(gspca_dev, 0x03, &sn9c1xx[3], 0x0f); |
692 | 714 | ||
693 | switch (sd->bridge) { | 715 | switch (sd->bridge) { |
694 | case BRIDGE_SN9C120: /* from win trace */ | 716 | case BRIDGE_SN9C120: /* from win trace */ |
695 | data = 0x61; | 717 | reg_w1(gspca_dev, 0x01, 0x61); |
696 | reg_w(gspca_dev, 0x01, &data, 1); | 718 | reg_w1(gspca_dev, 0x17, 0x20); |
697 | data = 0x20; | 719 | reg_w1(gspca_dev, 0x01, 0x60); |
698 | reg_w(gspca_dev, 0x17, &data, 1); | ||
699 | data = 0x60; | ||
700 | reg_w(gspca_dev, 0x01, &data, 1); | ||
701 | break; | 720 | break; |
702 | case BRIDGE_SN9C325: | 721 | case BRIDGE_SN9C325: |
703 | data = 0x43; | 722 | reg_w1(gspca_dev, 0x01, 0x43); |
704 | reg_w(gspca_dev, 0x01, &data, 1); | 723 | reg_w1(gspca_dev, 0x17, 0xae); |
705 | data = 0xae; | 724 | reg_w1(gspca_dev, 0x01, 0x42); |
706 | reg_w(gspca_dev, 0x17, &data, 1); | ||
707 | data = 0x42; | ||
708 | reg_w(gspca_dev, 0x01, &data, 1); | ||
709 | break; | 725 | break; |
710 | default: | 726 | default: |
711 | data = 0x43; | 727 | reg_w1(gspca_dev, 0x01, 0x43); |
712 | reg_w(gspca_dev, 0x01, &data, 1); | 728 | reg_w1(gspca_dev, 0x17, 0x61); |
713 | data = 0x61; | 729 | reg_w1(gspca_dev, 0x01, 0x42); |
714 | reg_w(gspca_dev, 0x17, &data, 1); | ||
715 | data = 0x42; | ||
716 | reg_w(gspca_dev, 0x01, &data, 1); | ||
717 | } | 730 | } |
718 | 731 | ||
719 | if (sd->sensor == SENSOR_HV7131R) { | 732 | if (sd->sensor == SENSOR_HV7131R) { |
@@ -770,6 +783,9 @@ static void ov7660_InitSensor(struct gspca_dev *gspca_dev) | |||
770 | { | 783 | { |
771 | int i = 0; | 784 | int i = 0; |
772 | 785 | ||
786 | i2c_w8(gspca_dev, ov7660_sensor_init[i]); /* reset SCCB */ | ||
787 | i++; | ||
788 | msleep(20); | ||
773 | while (ov7660_sensor_init[i][0]) { | 789 | while (ov7660_sensor_init[i][0]) { |
774 | i2c_w8(gspca_dev, ov7660_sensor_init[i]); | 790 | i2c_w8(gspca_dev, ov7660_sensor_init[i]); |
775 | i++; | 791 | i++; |
@@ -782,13 +798,11 @@ static int sd_config(struct gspca_dev *gspca_dev, | |||
782 | { | 798 | { |
783 | struct sd *sd = (struct sd *) gspca_dev; | 799 | struct sd *sd = (struct sd *) gspca_dev; |
784 | struct cam *cam; | 800 | struct cam *cam; |
785 | __u16 vendor; | ||
786 | __u16 product; | 801 | __u16 product; |
787 | 802 | ||
788 | vendor = id->idVendor; | ||
789 | product = id->idProduct; | 803 | product = id->idProduct; |
790 | sd->sensor = -1; | 804 | sd->sensor = -1; |
791 | switch (vendor) { | 805 | switch (id->idVendor) { |
792 | case 0x0458: /* Genius */ | 806 | case 0x0458: /* Genius */ |
793 | /* switch (product) { | 807 | /* switch (product) { |
794 | case 0x7025: */ | 808 | case 0x7025: */ |
@@ -960,7 +974,7 @@ static int sd_config(struct gspca_dev *gspca_dev, | |||
960 | } | 974 | } |
961 | if (sd->sensor < 0) { | 975 | if (sd->sensor < 0) { |
962 | PDEBUG(D_ERR, "Invalid vendor/product %04x:%04x", | 976 | PDEBUG(D_ERR, "Invalid vendor/product %04x:%04x", |
963 | vendor, product); | 977 | id->idVendor, product); |
964 | return -EINVAL; | 978 | return -EINVAL; |
965 | } | 979 | } |
966 | 980 | ||
@@ -983,34 +997,26 @@ static int sd_open(struct gspca_dev *gspca_dev) | |||
983 | { | 997 | { |
984 | struct sd *sd = (struct sd *) gspca_dev; | 998 | struct sd *sd = (struct sd *) gspca_dev; |
985 | /* const __u8 *sn9c1xx; */ | 999 | /* const __u8 *sn9c1xx; */ |
986 | __u8 regF1; | ||
987 | __u8 regGpio[] = { 0x29, 0x74 }; | 1000 | __u8 regGpio[] = { 0x29, 0x74 }; |
1001 | __u8 regF1; | ||
988 | 1002 | ||
989 | /* setup a selector by bridge */ | 1003 | /* setup a selector by bridge */ |
990 | regF1 = 0x01; | 1004 | reg_w1(gspca_dev, 0xf1, 0x01); |
991 | reg_w(gspca_dev, 0xf1, ®F1, 1); | ||
992 | reg_r(gspca_dev, 0x00, 1); /* -> regF1 = 0x00 */ | 1005 | reg_r(gspca_dev, 0x00, 1); /* -> regF1 = 0x00 */ |
993 | regF1 = gspca_dev->usb_buf[0]; | 1006 | reg_w1(gspca_dev, 0xf1, gspca_dev->usb_buf[0]); |
994 | reg_w(gspca_dev, 0xf1, ®F1, 1); | ||
995 | reg_r(gspca_dev, 0x00, 1); | 1007 | reg_r(gspca_dev, 0x00, 1); |
996 | regF1 = gspca_dev->usb_buf[0]; | 1008 | regF1 = gspca_dev->usb_buf[0]; |
997 | switch (sd->bridge) { | 1009 | switch (sd->bridge) { |
998 | case BRIDGE_SN9C102P: | 1010 | case BRIDGE_SN9C102P: |
999 | if (regF1 != 0x11) | 1011 | if (regF1 != 0x11) |
1000 | return -ENODEV; | 1012 | return -ENODEV; |
1001 | reg_w(gspca_dev, 0x02, ®Gpio[1], 1); | 1013 | reg_w1(gspca_dev, 0x02, regGpio[1]); |
1002 | break; | 1014 | break; |
1003 | case BRIDGE_SN9C105: | 1015 | case BRIDGE_SN9C105: |
1004 | if (regF1 != 0x11) | 1016 | if (regF1 != 0x11) |
1005 | return -ENODEV; | 1017 | return -ENODEV; |
1006 | reg_w(gspca_dev, 0x02, regGpio, 2); | 1018 | reg_w(gspca_dev, 0x02, regGpio, 2); |
1007 | break; | 1019 | break; |
1008 | case BRIDGE_SN9C110: | ||
1009 | if (regF1 != 0x12) | ||
1010 | return -ENODEV; | ||
1011 | regGpio[1] = 0x62; | ||
1012 | reg_w(gspca_dev, 0x02, ®Gpio[1], 1); | ||
1013 | break; | ||
1014 | case BRIDGE_SN9C120: | 1020 | case BRIDGE_SN9C120: |
1015 | if (regF1 != 0x12) | 1021 | if (regF1 != 0x12) |
1016 | return -ENODEV; | 1022 | return -ENODEV; |
@@ -1018,16 +1024,15 @@ static int sd_open(struct gspca_dev *gspca_dev) | |||
1018 | reg_w(gspca_dev, 0x02, regGpio, 2); | 1024 | reg_w(gspca_dev, 0x02, regGpio, 2); |
1019 | break; | 1025 | break; |
1020 | default: | 1026 | default: |
1027 | /* case BRIDGE_SN9C110: */ | ||
1021 | /* case BRIDGE_SN9C325: */ | 1028 | /* case BRIDGE_SN9C325: */ |
1022 | if (regF1 != 0x12) | 1029 | if (regF1 != 0x12) |
1023 | return -ENODEV; | 1030 | return -ENODEV; |
1024 | regGpio[1] = 0x62; | 1031 | reg_w1(gspca_dev, 0x02, 0x62); |
1025 | reg_w(gspca_dev, 0x02, ®Gpio[1], 1); | ||
1026 | break; | 1032 | break; |
1027 | } | 1033 | } |
1028 | 1034 | ||
1029 | regF1 = 0x01; | 1035 | reg_w1(gspca_dev, 0xf1, 0x01); |
1030 | reg_w(gspca_dev, 0xf1, ®F1, 1); | ||
1031 | 1036 | ||
1032 | return 0; | 1037 | return 0; |
1033 | } | 1038 | } |
@@ -1123,7 +1128,7 @@ static void setbrightness(struct gspca_dev *gspca_dev) | |||
1123 | } | 1128 | } |
1124 | 1129 | ||
1125 | k2 = sd->brightness >> 10; | 1130 | k2 = sd->brightness >> 10; |
1126 | reg_w(gspca_dev, 0x96, &k2, 1); | 1131 | reg_w1(gspca_dev, 0x96, k2); |
1127 | } | 1132 | } |
1128 | 1133 | ||
1129 | static void setcontrast(struct gspca_dev *gspca_dev) | 1134 | static void setcontrast(struct gspca_dev *gspca_dev) |
@@ -1152,7 +1157,7 @@ static void setcolors(struct gspca_dev *gspca_dev) | |||
1152 | data = (colour + 32) & 0x7f; /* blue */ | 1157 | data = (colour + 32) & 0x7f; /* blue */ |
1153 | else | 1158 | else |
1154 | data = (-colour + 32) & 0x7f; /* red */ | 1159 | data = (-colour + 32) & 0x7f; /* red */ |
1155 | reg_w(gspca_dev, 0x05, &data, 1); | 1160 | reg_w1(gspca_dev, 0x05, data); |
1156 | } | 1161 | } |
1157 | 1162 | ||
1158 | /* -- start the camera -- */ | 1163 | /* -- start the camera -- */ |
@@ -1165,7 +1170,6 @@ static void sd_start(struct gspca_dev *gspca_dev) | |||
1165 | __u8 reg17; | 1170 | __u8 reg17; |
1166 | const __u8 *sn9c1xx; | 1171 | const __u8 *sn9c1xx; |
1167 | int mode; | 1172 | int mode; |
1168 | static const __u8 DC29[] = { 0x6a, 0x50, 0x00, 0x00, 0x50, 0x3c }; | ||
1169 | static const __u8 C0[] = { 0x2d, 0x2d, 0x3a, 0x05, 0x04, 0x3f }; | 1173 | static const __u8 C0[] = { 0x2d, 0x2d, 0x3a, 0x05, 0x04, 0x3f }; |
1170 | static const __u8 CA[] = { 0x28, 0xd8, 0x14, 0xec }; | 1174 | static const __u8 CA[] = { 0x28, 0xd8, 0x14, 0xec }; |
1171 | static const __u8 CA_sn9c120[] = | 1175 | static const __u8 CA_sn9c120[] = |
@@ -1179,21 +1183,20 @@ static void sd_start(struct gspca_dev *gspca_dev) | |||
1179 | 1183 | ||
1180 | /*fixme:jfm this sequence should appear at end of sd_start */ | 1184 | /*fixme:jfm this sequence should appear at end of sd_start */ |
1181 | /* with | 1185 | /* with |
1182 | data = 0x44; | 1186 | reg_w1(gspca_dev, 0x01, 0x44); */ |
1183 | reg_w(gspca_dev, 0x01, &data, 1); */ | 1187 | reg_w1(gspca_dev, 0x15, sn9c1xx[0x15]); |
1184 | reg_w(gspca_dev, 0x15, &sn9c1xx[0x15], 1); | 1188 | reg_w1(gspca_dev, 0x16, sn9c1xx[0x16]); |
1185 | reg_w(gspca_dev, 0x16, &sn9c1xx[0x16], 1); | 1189 | reg_w1(gspca_dev, 0x12, sn9c1xx[0x12]); |
1186 | reg_w(gspca_dev, 0x12, &sn9c1xx[0x12], 1); | 1190 | reg_w1(gspca_dev, 0x13, sn9c1xx[0x13]); |
1187 | reg_w(gspca_dev, 0x13, &sn9c1xx[0x13], 1); | 1191 | reg_w1(gspca_dev, 0x18, sn9c1xx[0x18]); |
1188 | reg_w(gspca_dev, 0x18, &sn9c1xx[0x18], 1); | 1192 | reg_w1(gspca_dev, 0xd2, 0x6a); /* DC29 */ |
1189 | reg_w(gspca_dev, 0xd2, &DC29[0], 1); | 1193 | reg_w1(gspca_dev, 0xd3, 0x50); |
1190 | reg_w(gspca_dev, 0xd3, &DC29[1], 1); | 1194 | reg_w1(gspca_dev, 0xc6, 0x00); |
1191 | reg_w(gspca_dev, 0xc6, &DC29[2], 1); | 1195 | reg_w1(gspca_dev, 0xc7, 0x00); |
1192 | reg_w(gspca_dev, 0xc7, &DC29[3], 1); | 1196 | reg_w1(gspca_dev, 0xc8, 0x50); |
1193 | reg_w(gspca_dev, 0xc8, &DC29[4], 1); | 1197 | reg_w1(gspca_dev, 0xc9, 0x3c); |
1194 | reg_w(gspca_dev, 0xc9, &DC29[5], 1); | ||
1195 | /*fixme:jfm end of ending sequence */ | 1198 | /*fixme:jfm end of ending sequence */ |
1196 | reg_w(gspca_dev, 0x18, &sn9c1xx[0x18], 1); | 1199 | reg_w1(gspca_dev, 0x18, sn9c1xx[0x18]); |
1197 | switch (sd->bridge) { | 1200 | switch (sd->bridge) { |
1198 | case BRIDGE_SN9C325: | 1201 | case BRIDGE_SN9C325: |
1199 | data = 0xae; | 1202 | data = 0xae; |
@@ -1205,11 +1208,11 @@ static void sd_start(struct gspca_dev *gspca_dev) | |||
1205 | data = 0x60; | 1208 | data = 0x60; |
1206 | break; | 1209 | break; |
1207 | } | 1210 | } |
1208 | reg_w(gspca_dev, 0x17, &data, 1); | 1211 | reg_w1(gspca_dev, 0x17, data); |
1209 | reg_w(gspca_dev, 0x05, &sn9c1xx[5], 1); | 1212 | reg_w1(gspca_dev, 0x05, sn9c1xx[5]); |
1210 | reg_w(gspca_dev, 0x07, &sn9c1xx[7], 1); | 1213 | reg_w1(gspca_dev, 0x07, sn9c1xx[7]); |
1211 | reg_w(gspca_dev, 0x06, &sn9c1xx[6], 1); | 1214 | reg_w1(gspca_dev, 0x06, sn9c1xx[6]); |
1212 | reg_w(gspca_dev, 0x14, &sn9c1xx[0x14], 1); | 1215 | reg_w1(gspca_dev, 0x14, sn9c1xx[0x14]); |
1213 | switch (sd->bridge) { | 1216 | switch (sd->bridge) { |
1214 | case BRIDGE_SN9C325: | 1217 | case BRIDGE_SN9C325: |
1215 | reg_w(gspca_dev, 0x20, regsn20_sn9c325, | 1218 | reg_w(gspca_dev, 0x20, regsn20_sn9c325, |
@@ -1217,10 +1220,8 @@ static void sd_start(struct gspca_dev *gspca_dev) | |||
1217 | for (i = 0; i < 8; i++) | 1220 | for (i = 0; i < 8; i++) |
1218 | reg_w(gspca_dev, 0x84, reg84_sn9c325, | 1221 | reg_w(gspca_dev, 0x84, reg84_sn9c325, |
1219 | sizeof reg84_sn9c325); | 1222 | sizeof reg84_sn9c325); |
1220 | data = 0x0a; | 1223 | reg_w1(gspca_dev, 0x9a, 0x0a); |
1221 | reg_w(gspca_dev, 0x9a, &data, 1); | 1224 | reg_w1(gspca_dev, 0x99, 0x60); |
1222 | data = 0x60; | ||
1223 | reg_w(gspca_dev, 0x99, &data, 1); | ||
1224 | break; | 1225 | break; |
1225 | case BRIDGE_SN9C120: | 1226 | case BRIDGE_SN9C120: |
1226 | reg_w(gspca_dev, 0x20, regsn20_sn9c120, | 1227 | reg_w(gspca_dev, 0x20, regsn20_sn9c120, |
@@ -1233,39 +1234,30 @@ static void sd_start(struct gspca_dev *gspca_dev) | |||
1233 | sizeof reg84_sn9c120_2); | 1234 | sizeof reg84_sn9c120_2); |
1234 | reg_w(gspca_dev, 0x84, reg84_sn9c120_3, | 1235 | reg_w(gspca_dev, 0x84, reg84_sn9c120_3, |
1235 | sizeof reg84_sn9c120_3); | 1236 | sizeof reg84_sn9c120_3); |
1236 | data = 0x05; | 1237 | reg_w1(gspca_dev, 0x9a, 0x05); |
1237 | reg_w(gspca_dev, 0x9a, &data, 1); | 1238 | reg_w1(gspca_dev, 0x99, 0x5b); |
1238 | data = 0x5b; | ||
1239 | reg_w(gspca_dev, 0x99, &data, 1); | ||
1240 | break; | 1239 | break; |
1241 | default: | 1240 | default: |
1242 | reg_w(gspca_dev, 0x20, regsn20, sizeof regsn20); | 1241 | reg_w(gspca_dev, 0x20, regsn20, sizeof regsn20); |
1243 | for (i = 0; i < 8; i++) | 1242 | for (i = 0; i < 8; i++) |
1244 | reg_w(gspca_dev, 0x84, reg84, sizeof reg84); | 1243 | reg_w(gspca_dev, 0x84, reg84, sizeof reg84); |
1245 | data = 0x08; | 1244 | reg_w1(gspca_dev, 0x9a, 0x08); |
1246 | reg_w(gspca_dev, 0x9a, &data, 1); | 1245 | reg_w1(gspca_dev, 0x99, 0x59); |
1247 | data = 0x59; | ||
1248 | reg_w(gspca_dev, 0x99, &data, 1); | ||
1249 | break; | 1246 | break; |
1250 | } | 1247 | } |
1251 | 1248 | ||
1252 | mode = gspca_dev->cam.cam_mode[(int) gspca_dev->curr_mode].priv; | 1249 | mode = gspca_dev->cam.cam_mode[(int) gspca_dev->curr_mode].priv; |
1253 | reg1 = 0x02; | 1250 | if (mode) |
1251 | reg1 = 0x46; /* 320 clk 48Mhz */ | ||
1252 | else | ||
1253 | reg1 = 0x06; /* 640 clk 24Mz */ | ||
1254 | reg17 = 0x61; | 1254 | reg17 = 0x61; |
1255 | switch (sd->sensor) { | 1255 | switch (sd->sensor) { |
1256 | case SENSOR_HV7131R: | 1256 | case SENSOR_HV7131R: |
1257 | hv7131R_InitSensor(gspca_dev); | 1257 | hv7131R_InitSensor(gspca_dev); |
1258 | if (mode) | ||
1259 | reg1 = 0x46; /* 320 clk 48Mhz */ | ||
1260 | else | ||
1261 | reg1 = 0x06; /* 640 clk 24Mz */ | ||
1262 | break; | 1258 | break; |
1263 | case SENSOR_MI0360: | 1259 | case SENSOR_MI0360: |
1264 | mi0360_InitSensor(gspca_dev); | 1260 | mi0360_InitSensor(gspca_dev); |
1265 | if (mode) | ||
1266 | reg1 = 0x46; /* 320 clk 48Mhz */ | ||
1267 | else | ||
1268 | reg1 = 0x06; /* 640 clk 24Mz */ | ||
1269 | break; | 1261 | break; |
1270 | case SENSOR_MO4000: | 1262 | case SENSOR_MO4000: |
1271 | mo4000_InitSensor(gspca_dev); | 1263 | mo4000_InitSensor(gspca_dev); |
@@ -1274,13 +1266,13 @@ static void sd_start(struct gspca_dev *gspca_dev) | |||
1274 | reg1 = 0x06; /* clk 24Mz */ | 1266 | reg1 = 0x06; /* clk 24Mz */ |
1275 | } else { | 1267 | } else { |
1276 | reg17 = 0x22; /* 640 MCKSIZE */ | 1268 | reg17 = 0x22; /* 640 MCKSIZE */ |
1277 | reg1 = 0x06; /* 640 clk 24Mz */ | 1269 | /* reg1 = 0x06; * 640 clk 24Mz (done) */ |
1278 | } | 1270 | } |
1279 | break; | 1271 | break; |
1280 | case SENSOR_OV7648: | 1272 | case SENSOR_OV7648: |
1273 | ov7648_InitSensor(gspca_dev); | ||
1281 | reg17 = 0xa2; | 1274 | reg17 = 0xa2; |
1282 | reg1 = 0x44; | 1275 | reg1 = 0x44; |
1283 | ov7648_InitSensor(gspca_dev); | ||
1284 | /* if (mode) | 1276 | /* if (mode) |
1285 | ; * 320x2... | 1277 | ; * 320x2... |
1286 | else | 1278 | else |
@@ -1292,7 +1284,7 @@ static void sd_start(struct gspca_dev *gspca_dev) | |||
1292 | if (mode) { | 1284 | if (mode) { |
1293 | /* reg17 = 0x21; * 320 */ | 1285 | /* reg17 = 0x21; * 320 */ |
1294 | /* reg1 = 0x44; */ | 1286 | /* reg1 = 0x44; */ |
1295 | reg1 = 0x46; | 1287 | /* reg1 = 0x46; (done) */ |
1296 | } else { | 1288 | } else { |
1297 | reg17 = 0xa2; /* 640 */ | 1289 | reg17 = 0xa2; /* 640 */ |
1298 | reg1 = 0x40; | 1290 | reg1 = 0x40; |
@@ -1321,16 +1313,16 @@ static void sd_start(struct gspca_dev *gspca_dev) | |||
1321 | 1313 | ||
1322 | /* here change size mode 0 -> VGA; 1 -> CIF */ | 1314 | /* here change size mode 0 -> VGA; 1 -> CIF */ |
1323 | data = 0x40 | sn9c1xx[0x18] | (mode << 4); | 1315 | data = 0x40 | sn9c1xx[0x18] | (mode << 4); |
1324 | reg_w(gspca_dev, 0x18, &data, 1); | 1316 | reg_w1(gspca_dev, 0x18, data); |
1325 | 1317 | ||
1326 | reg_w(gspca_dev, 0x100, qtable4, 0x40); | 1318 | reg_w(gspca_dev, 0x100, qtable4, 0x40); |
1327 | reg_w(gspca_dev, 0x140, qtable4 + 0x40, 0x40); | 1319 | reg_w(gspca_dev, 0x140, qtable4 + 0x40, 0x40); |
1328 | 1320 | ||
1329 | data = sn9c1xx[0x18] | (mode << 4); | 1321 | data = sn9c1xx[0x18] | (mode << 4); |
1330 | reg_w(gspca_dev, 0x18, &data, 1); | 1322 | reg_w1(gspca_dev, 0x18, data); |
1331 | 1323 | ||
1332 | reg_w(gspca_dev, 0x17, ®17, 1); | 1324 | reg_w1(gspca_dev, 0x17, reg17); |
1333 | reg_w(gspca_dev, 0x01, ®1, 1); | 1325 | reg_w1(gspca_dev, 0x01, reg1); |
1334 | setbrightness(gspca_dev); | 1326 | setbrightness(gspca_dev); |
1335 | setcontrast(gspca_dev); | 1327 | setcontrast(gspca_dev); |
1336 | } | 1328 | } |
@@ -1342,7 +1334,6 @@ static void sd_stopN(struct gspca_dev *gspca_dev) | |||
1342 | { 0xa1, 0x11, 0x02, 0x09, 0x00, 0x00, 0x00, 0x10 }; | 1334 | { 0xa1, 0x11, 0x02, 0x09, 0x00, 0x00, 0x00, 0x10 }; |
1343 | static const __u8 stopmi0360[] = | 1335 | static const __u8 stopmi0360[] = |
1344 | { 0xb1, 0x5d, 0x07, 0x00, 0x00, 0x00, 0x00, 0x10 }; | 1336 | { 0xb1, 0x5d, 0x07, 0x00, 0x00, 0x00, 0x00, 0x10 }; |
1345 | __u8 regF1; | ||
1346 | __u8 data; | 1337 | __u8 data; |
1347 | const __u8 *sn9c1xx; | 1338 | const __u8 *sn9c1xx; |
1348 | 1339 | ||
@@ -1366,12 +1357,11 @@ static void sd_stopN(struct gspca_dev *gspca_dev) | |||
1366 | break; | 1357 | break; |
1367 | } | 1358 | } |
1368 | sn9c1xx = sn_tb[(int) sd->sensor]; | 1359 | sn9c1xx = sn_tb[(int) sd->sensor]; |
1369 | reg_w(gspca_dev, 0x01, &sn9c1xx[1], 1); | 1360 | reg_w1(gspca_dev, 0x01, sn9c1xx[1]); |
1370 | reg_w(gspca_dev, 0x17, &sn9c1xx[0x17], 1); | 1361 | reg_w1(gspca_dev, 0x17, sn9c1xx[0x17]); |
1371 | reg_w(gspca_dev, 0x01, &sn9c1xx[1], 1); | 1362 | reg_w1(gspca_dev, 0x01, sn9c1xx[1]); |
1372 | reg_w(gspca_dev, 0x01, &data, 1); | 1363 | reg_w1(gspca_dev, 0x01, data); |
1373 | regF1 = 0x01; | 1364 | reg_w1(gspca_dev, 0xf1, 0x01); |
1374 | reg_w(gspca_dev, 0xf1, ®F1, 1); | ||
1375 | } | 1365 | } |
1376 | 1366 | ||
1377 | static void sd_stop0(struct gspca_dev *gspca_dev) | 1367 | static void sd_stop0(struct gspca_dev *gspca_dev) |