diff options
author | Patrick Boettcher <pb@linuxtv.org> | 2006-01-09 15:21:38 -0500 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@brturbo.com.br> | 2006-01-09 15:21:38 -0500 |
commit | f53737882e26ff08022fec6ad79f061c49dadda2 (patch) | |
tree | d07379f003fbb144790b24e845045edfb4f517be /drivers/media/dvb/dvb-usb/dvb-usb-firmware.c | |
parent | 5af0c8f6a09534ebc6c56b4e5d79d0d521364750 (diff) |
V4L/DVB (3327): Remove DViCO specific firmware hacks from the generic code.
- Move the code that patches bluebird firmware before upload from the
generic code into the cxusb driver itself.
Signed-off-by: Patrick Boettcher <pb@linuxtv.org>
Signed-off-by: Michael Krufky <mkrufky@m1k.net>
Signed-off-by: Chris Pascoe <c.pascoe@itee.uq.edu.au>
Signed-off-by: Mauro Carvalho Chehab <mchehab@brturbo.com.br>
Diffstat (limited to 'drivers/media/dvb/dvb-usb/dvb-usb-firmware.c')
-rw-r--r-- | drivers/media/dvb/dvb-usb/dvb-usb-firmware.c | 30 |
1 files changed, 2 insertions, 28 deletions
diff --git a/drivers/media/dvb/dvb-usb/dvb-usb-firmware.c b/drivers/media/dvb/dvb-usb/dvb-usb-firmware.c index b2670476c3f2..8535895819fb 100644 --- a/drivers/media/dvb/dvb-usb/dvb-usb-firmware.c +++ b/drivers/media/dvb/dvb-usb/dvb-usb-firmware.c | |||
@@ -33,7 +33,7 @@ static int usb_cypress_writemem(struct usb_device *udev,u16 addr,u8 *data, u8 le | |||
33 | 0xa0, USB_TYPE_VENDOR, addr, 0x00, data, len, 5000); | 33 | 0xa0, USB_TYPE_VENDOR, addr, 0x00, data, len, 5000); |
34 | } | 34 | } |
35 | 35 | ||
36 | static int usb_cypress_load_firmware(struct usb_device *udev, const struct firmware *fw, int type) | 36 | int usb_cypress_load_firmware(struct usb_device *udev, const struct firmware *fw, int type) |
37 | { | 37 | { |
38 | struct hexline hx; | 38 | struct hexline hx; |
39 | u8 reset; | 39 | u8 reset; |
@@ -73,27 +73,7 @@ static int usb_cypress_load_firmware(struct usb_device *udev, const struct firmw | |||
73 | 73 | ||
74 | return ret; | 74 | return ret; |
75 | } | 75 | } |
76 | 76 | EXPORT_SYMBOL(usb_cypress_load_firmware); | |
77 | /* | ||
78 | * DViCO bluebird firmware needs the "warm" product ID to be patched into the | ||
79 | * firmware file before download. | ||
80 | */ | ||
81 | #define BLUEBIRD_01_ID_OFFSET 6638 | ||
82 | static int dvb_usb_patch_dvico_firmware(struct usb_device *udev, const struct firmware *fw) | ||
83 | { | ||
84 | if (fw->size < BLUEBIRD_01_ID_OFFSET + 4) | ||
85 | return -EINVAL; | ||
86 | |||
87 | if (fw->data[BLUEBIRD_01_ID_OFFSET] == (USB_VID_DVICO & 0xff) && | ||
88 | fw->data[BLUEBIRD_01_ID_OFFSET + 1] == USB_VID_DVICO >> 8) { | ||
89 | fw->data[BLUEBIRD_01_ID_OFFSET + 2] = udev->descriptor.idProduct + 1; | ||
90 | fw->data[BLUEBIRD_01_ID_OFFSET + 3] = udev->descriptor.idProduct >> 8; | ||
91 | |||
92 | return 0; | ||
93 | } | ||
94 | |||
95 | return -EINVAL; | ||
96 | } | ||
97 | 77 | ||
98 | int dvb_usb_download_firmware(struct usb_device *udev, struct dvb_usb_properties *props) | 78 | int dvb_usb_download_firmware(struct usb_device *udev, struct dvb_usb_properties *props) |
99 | { | 79 | { |
@@ -109,12 +89,6 @@ int dvb_usb_download_firmware(struct usb_device *udev, struct dvb_usb_properties | |||
109 | 89 | ||
110 | info("downloading firmware from file '%s'",props->firmware); | 90 | info("downloading firmware from file '%s'",props->firmware); |
111 | 91 | ||
112 | if (le16_to_cpu(udev->descriptor.idVendor) == USB_VID_DVICO) { | ||
113 | ret = dvb_usb_patch_dvico_firmware(udev, fw); | ||
114 | if (ret != 0) | ||
115 | warn("this firmware file not recognised"); | ||
116 | } | ||
117 | |||
118 | switch (props->usb_ctrl) { | 92 | switch (props->usb_ctrl) { |
119 | case CYPRESS_AN2135: | 93 | case CYPRESS_AN2135: |
120 | case CYPRESS_AN2235: | 94 | case CYPRESS_AN2235: |