Re: i2c_smbus_write_block_data vs scheduled routine calls (add_timer) - kernel crash

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



El Tue, Aug 04, 2009 at 09:42:41PM +0300 NiTr0 ha dit:

> I tried to improve voltage/FSB manipulation module for EeePC  
> (http://code.google.com/p/eeepc-linux) - and I found that  
> i2c_smbus_write_block_data will cause kernel panic when is called from  
> function called by timer. I can't see kernel panic message because  
> system print very long call trace. Also on EeePC there is no RS232 port  
> - but I have USB->RS232 dongle, can it be used as terminal for debug  
> messages?
>
> All variables are declared as static, all data is prepared correctly -  
> so IMHO trouble is outside of my driver.
> There is a part of code:
>
> static struct i2c_client eee_pll_smbus_client = {
>        .adapter = NULL,
>        .addr = 0x69,
>        .flags = 0,
> };
> static char eee_pll_data[I2C_SMBUS_BLOCK_MAX];
> static int eee_pll_datalen = 0;
> .......................
>        i2c_smbus_write_block_data(&eee_pll_smbus_client,0,  
> eee_pll_datalen, eee_pll_data);

a possible source of problems is that i2c_smbus_xfer() (invoked by
i2c_smbus_write_block_data()) tries to aquire a mutex if
adapter->algo->smbus_xfer is set.

http://lxr.linux.no/linux+v2.6.30/drivers/i2c/i2c-core.c#L1994

timers are executed in a softirq, ie in interrupt context, but mutexes
must not be used within interrupts.

i'm neither an i2c-core nor an kernel expert, but this point looks
conflictive to me and might be the reason for the kernel panic you
get.

-- 
Matthias Kaehlcke
Embedded Linux Engineer
Barcelona

        They that can give up essential liberty to obtain a little
           temporary safety deserve neither liberty nor safety
                         (Benjamin Franklin)
                                                                 .''`.
    using free software / Debian GNU/Linux | http://debian.org  : :'  :
                                                                `. `'`
gpg --keyserver pgp.mit.edu --recv-keys 47D8E5D4                  `-
--
To unsubscribe from this list: send the line "unsubscribe linux-i2c" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux GPIO]     [Linux SPI]     [Linux Hardward Monitoring]     [LM Sensors]     [Linux USB Devel]     [Linux Media]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux