Re: s5h1411_readreg: readreg error (ret == -5)

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

 



On Thu, 11 Jun 2009, Steven Toth wrote:

> Mike Isely wrote:
> > On Sun, 7 Jun 2009, Roger wrote:
> > 
> > > >From looking at "linux/drivers/media/dvb/frontends/s5h1411.c",  The
> > > s5h1411_readreg wants to see "2" but is getting "-5" from the i2c bus.
> > > 
> > > --- Snip ---
> > > 
> > > s5h1411_readreg: readreg error (ret == -5)
> > > pvrusb2: unregistering DVB devices
> > > device: 'dvb0.net0': device_unregister
> > > 
> > > --- Snip ---
> > > 
> > > What exactly does this mean?
> > 
> > Roger:
> > 
> > It means that the module attempted an I2C transfer and the transfer failed.
> > The I2C adapter within the pvrusb2 driver will return either the number of
> > bytes that it transferred or a failure code.  The failure code, as is normal
> > convention in the kernel, will be a negated errno value.  Thus the expected
> > value of 2 would be the fact that it probably tried a 2 byte transfer, while
> > the actual value returned of -5 indicate an EIO error, which is what the
> > pvrusb2 driver will return when the underlying I2C transaction has failed.
> > 
> > Of course the real question is not that it failed but why it failed.  And
> > for that I unfortunately do not have an answer.  It's possible that the
> > s5h1411 driver did something that the chip didn't like and the chip
> > responded by going deaf on the I2C bus.  More than a few I2C-driven parts
> > can behave this way.  It's also possible that the part might have been busy
> > and unable to respond - but usually in that case the driver for such a part
> > will be written with this in mind and will know how / when to communicate
> > with the hardware.
> 
> Roger:
> 
> Another possibility, although I don't know the PVRUSB2 driver too well, the
> s5h1411 is being held in reset when the driver unloads _AFTER_ the last active
> use was analog video (assuming the s5h1411 is floated in reset as the FX2
> input port might be shared with the analog encoder)

Good point.  The pvrusb2 driver is not currently doing anything specific 
- or at least deliberate - via the FX2 to move that part in/out of 
reset.  (Of course, I am issuing FX2 commands to shift modes and that 
might in turn be triggering other things.)  But even if I did do 
something specific, what kind of impact is that likely to do on the 
corresponding, blissfully ignorant, driver?

This actually drives towards a larger issue - the pvrusb2 driver works 
with various V4L-only sub-devices, e.g. cx25840, which have no relevance 
in digital mode but I can't really control when that corresponding 
driver is enabled / disabled.  So if I have to take an extra step to 
physically disable a chip when in digital mode, then this might impact 
the sub-driver which otherwise is going to have no clue what is really 
going on.

  -Mike


-- 

Mike Isely
isely @ isely (dot) net
PGP: 03 54 43 4D 75 E5 CC 92 71 16 01 E2 B5 F5 C1 E8
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Input]     [Video for Linux]     [Gstreamer Embedded]     [Mplayer Users]     [Linux USB Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]
  Powered by Linux