Hi Krzysztof:
> "Mark M. Hoffman" <[email protected]> writes:
> > SCL and SDA must be pulled high by hardware. If a driver inits to
> > setting them low, that's a bug in the driver.
* Krzysztof Halasa <[email protected]> [2006-06-11 00:27:14 +0200]:
> Thanks for your response.
>
> The question is rather who inits the lines: a) the hw driver,
> b) the I2C algorithm driver.
>
> With a) every hw driver has to know how to init them (duplicated
> code but there might be positive side).
>
> With b) I2C algorithm driver inits the lines and hw driver
> doesn't worry about but it might have some limitations such
> as unknown SCL state.
>
> I understand the current case is a) - right?
I think it should be, yes.
> The other question is _how_ to init the lines. There are 4 possible
> hardware initial conditions:
>
> SCL SDA
> a) 0 0 (outputs zeroed by default)
> b) 0 1 (uncommon but may be left in this state by previous operations)
> c) 1 0 (ditto)
> d) 1 1 (I/O lines configured as input by default)
>
> The internal state of devices connected to the bus is potentially
> unknown. Some implementations just start with STOP to eliminate
> this problem, I don't know what Linux driver is supposed to do.
If you can read the line state, then yes... I would detect which of
the above four states you're in, and generate a STOP condition for
a, b, and c:
a) setscl(1), setsda(1)
b) setsda(0), setscl(1), setsda(1)
c) setsda(1)
If you can't read the line state... well, that's not actually a proper
I2C bus anyway. At that point I suggest 'whatever works'.
But even if you need to generate a 'null transfer' (prohibited by spec)
to get reliable operation... that doesn't belong in the algorithm driver.
> (Other implementation I know are rather specialized and thus they
> know their hardware init state, Linux I2C algorithm handles many
> devices with potentially different initial state of hardware lines).
>
>
> To summarize questions:
> - is it the hw driver who has to init the bus
> - how to init the bus (depending on init state)
Regards,
--
Mark M. Hoffman
[email protected]
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
[Index of Archives]
[Kernel Newbies]
[Netfilter]
[Bugtraq]
[Photo]
[Stuff]
[Gimp]
[Yosemite News]
[MIPS Linux]
[ARM Linux]
[Linux Security]
[Linux RAID]
[Video 4 Linux]
[Linux for the blind]
[Linux Resources]