Search Linux Wireless

Re: [PATCH 1/2] Add 93cx6 eeprom library

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

 



On Sun, May 13, 2007 at 02:50:38PM -0400, Jeff Garzik wrote:
> On Sat, May 12, 2007 at 03:17:49PM -0400, John W. Linville wrote:
> > On Fri, May 11, 2007 at 03:59:40PM -0400, Michael Wu wrote:
> > 
> > > +static inline void eeprom_93cx6_pulse_high(struct eeprom_93cx6 *eeprom)
> > > +{
> > > +	eeprom->reg_data_clock = 1;
> > > +	eeprom->register_write(eeprom);
> > > +	udelay(1);
> > > +}
> > > +
> > > +static inline void eeprom_93cx6_pulse_low(struct eeprom_93cx6 *eeprom)
> > > +{
> > > +	eeprom->reg_data_clock = 0;
> > > +	eeprom->register_write(eeprom);
> > > +	udelay(1);
> > > +}
> > 
> > I'm with Jeff, these udelay's should go.  If they belong anywhere, it
> > would be in the write routines provided by the caller.  For example, the
> > routines provided by rtl8187 already have a delay in them.  Other
> > hardware might actually have a hardware timer to implement delays (hey,
> > it's possible).  Either way, this delay is superfluous.
> 
> I don't claim the delays were superfluous, I was just wondering if they
> were papering over write-posting bugs.

OK, let's straighten this out...datasheet here:

	http://ww1.microchip.com/downloads/en/DeviceDoc/21749F.pdf

Figure 1-1 and Table 1-2 on pages 4-5 indicate that both Clock High
Time and Clock Low Time have largest minimum times of 450ns.  So,
the udelay(1) here seems both appropriately sized and appropriately
placed here as part of the eeprom access protocol.

This does shift Jeff's original question re: write posting onto the
->register_write routines passed-in by rtl8187 instead.

John
-- 
John W. Linville
linville@xxxxxxxxxxxxx
-
To unsubscribe from this list: send the line "unsubscribe linux-wireless" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Host AP]     [ATH6KL]     [Linux Bluetooth]     [Linux Netdev]     [Kernel Newbies]     [Linux Kernel]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Samba]     [Device Mapper]
  Powered by Linux