diff options
author | Mauro Carvalho Chehab <mchehab@redhat.com> | 2009-09-07 01:16:47 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@redhat.com> | 2009-09-12 11:20:15 -0400 |
commit | d2ebd0f806fdb6104903365e355675934eec22b2 (patch) | |
tree | 8455ec9d42ac4a8cff60a4b5261a88814bca5818 /drivers/pcmcia/sa1100_generic.c | |
parent | 4d708a5e9e5db74da28965fa00082d8c9323f523 (diff) |
V4L/DVB (12698): em28xx: ir-kbd-i2c init data needs a persistent object
ir-kbd-i2c's ir_probe() function can be called much later (i.e. at
ir-kbd-i2c module load), than the lifetime of a struct IR_i2c_init_data
allocated off of the stack in cx18_i2c_new_ir() at registration time.
Make sure we pass a pointer to a persistent IR_i2c_init_data object at
i2c registration time.
Thanks to Brian Rogers, Dustin Mitchell, Andy Walls and Jean Delvare to
rise this question.
Before this patch, if ir-kbd-i2c were probed after em28xx, trash data
were used. After the patch, no matter what order, it is properly
reported as tested by me:
input: i2c IR (i2c IR (EM2840 Hauppaug as /class/input/input10
ir-kbd-i2c: i2c IR (i2c IR (EM2840 Hauppaug detected at i2c-4/4-0030/ir0 [em28xx #0]
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/pcmcia/sa1100_generic.c')
0 files changed, 0 insertions, 0 deletions