Commit ffce6266 authored by Istvan Varga's avatar Istvan Varga Committed by Mauro Carvalho Chehab

[media] xc4000: simplified load_scode

Removed unused code from load_scode() (all SCODE firmwares are
assumed to have the HAS_IF bit set).
Signed-off-by: default avatarIstvan Varga <istvan_v@mailbox.hu>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent 3db95704
...@@ -780,8 +780,7 @@ static int xc4000_fwupload(struct dvb_frontend *fe) ...@@ -780,8 +780,7 @@ static int xc4000_fwupload(struct dvb_frontend *fe)
p += sizeof(size); p += sizeof(size);
if (!size || size > endp - p) { if (!size || size > endp - p) {
printk("Firmware type "); printk("Firmware type (%x), id %llx is corrupted "
printk("(%x), id %llx is corrupted "
"(size=%d, expected %d)\n", "(size=%d, expected %d)\n",
type, (unsigned long long)id, type, (unsigned long long)id,
(unsigned)(endp - p), size); (unsigned)(endp - p), size);
...@@ -839,10 +838,10 @@ static int load_scode(struct dvb_frontend *fe, unsigned int type, ...@@ -839,10 +838,10 @@ static int load_scode(struct dvb_frontend *fe, unsigned int type,
v4l2_std_id *id, __u16 int_freq, int scode) v4l2_std_id *id, __u16 int_freq, int scode)
{ {
struct xc4000_priv *priv = fe->tuner_priv; struct xc4000_priv *priv = fe->tuner_priv;
int pos, rc; int pos, rc;
unsigned char *p; unsigned char *p;
u8 scode_buf[13]; u8 scode_buf[13];
u8 indirect_mode[5]; u8 indirect_mode[5];
dprintk(1, "%s called int_freq=%d\n", __func__, int_freq); dprintk(1, "%s called int_freq=%d\n", __func__, int_freq);
...@@ -862,18 +861,9 @@ static int load_scode(struct dvb_frontend *fe, unsigned int type, ...@@ -862,18 +861,9 @@ static int load_scode(struct dvb_frontend *fe, unsigned int type,
p = priv->firm[pos].ptr; p = priv->firm[pos].ptr;
if (priv->firm[pos].type & HAS_IF) { if (priv->firm[pos].size != 12 * 16 || scode >= 16)
if (priv->firm[pos].size != 12 * 16 || scode >= 16) return -EINVAL;
return -EINVAL; p += 12 * scode;
p += 12 * scode;
} else {
/* 16 SCODE entries per file; each SCODE entry is 12 bytes and
* has a 2-byte size header in the firmware format. */
if (priv->firm[pos].size != 14 * 16 || scode >= 16 ||
le16_to_cpu(*(__u16 *)(p + 14 * scode)) != 12)
return -EINVAL;
p += 14 * scode + 2;
}
tuner_info("Loading SCODE for type="); tuner_info("Loading SCODE for type=");
dump_firm_type_and_int_freq(priv->firm[pos].type, dump_firm_type_and_int_freq(priv->firm[pos].type,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment