V4L/DVB (7286): limit stack usage of ir-kbd-i2c.c
ir_probe allocated struct i2c_client on stack; it's pretty big structure, so allocate it with kzalloc make checkstack output without this patch: x059d ir_probe [ir-kbd-i2c]: 1000 Signed-off-by: Marcin Slusarz <marcin.slusarz@gmail.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
This commit is contained in:
parent
1c3bf598cf
commit
a58858556d
1 changed files with 11 additions and 7 deletions
|
@ -509,9 +509,9 @@ static int ir_probe(struct i2c_adapter *adap)
|
|||
static const int probe_cx88[] = { 0x18, 0x6b, 0x71, -1 };
|
||||
static const int probe_cx23885[] = { 0x6b, -1 };
|
||||
const int *probe = NULL;
|
||||
struct i2c_client c;
|
||||
struct i2c_client *c;
|
||||
unsigned char buf;
|
||||
int i,rc;
|
||||
int i, rc;
|
||||
|
||||
switch (adap->id) {
|
||||
case I2C_HW_B_BT848:
|
||||
|
@ -536,19 +536,23 @@ static int ir_probe(struct i2c_adapter *adap)
|
|||
if (NULL == probe)
|
||||
return 0;
|
||||
|
||||
memset(&c,0,sizeof(c));
|
||||
c.adapter = adap;
|
||||
c = kzalloc(sizeof(*c), GFP_KERNEL);
|
||||
if (!c)
|
||||
return -ENOMEM;
|
||||
|
||||
c->adapter = adap;
|
||||
for (i = 0; -1 != probe[i]; i++) {
|
||||
c.addr = probe[i];
|
||||
rc = i2c_master_recv(&c,&buf,0);
|
||||
c->addr = probe[i];
|
||||
rc = i2c_master_recv(c, &buf, 0);
|
||||
dprintk(1,"probe 0x%02x @ %s: %s\n",
|
||||
probe[i], adap->name,
|
||||
(0 == rc) ? "yes" : "no");
|
||||
if (0 == rc) {
|
||||
ir_attach(adap,probe[i],0,0);
|
||||
ir_attach(adap, probe[i], 0, 0);
|
||||
break;
|
||||
}
|
||||
}
|
||||
kfree(c);
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue