Re: [PATCH v5] EHCI bus glue for on-chip PMC MSP USB controller

From: Dan Carpenter
Date: Wed Feb 23 2011 - 12:02:34 EST


On Wed, Feb 23, 2011 at 06:52:23PM +0530, Anoop P A wrote:
> > Cannot find the msp_usb.h in linux-next. Doesn't compile.
> msp_usb.h has made it's way to linux-mips queue tree along with the
> platform code

Hm... Ralf is on the CC list. Ralf, why are the "Patches queued for
the next Linux kernel release." not included in linux-next?

> > > + val = ehci_readl(ehci, (u32 *)base);
> >
> > It doesn't compile so I can't test this, but I think that this will
> > cause a sparse warning. "base" should have an __iomem tag. Please
> > run sparse on this driver.
> Looks like mips platform build has been broken on linux-next ( unable to
> configure) . However I have tested code with linux-queue tree ( mips)
> and didn't see any such warnings

Sparse is an external tool. You have to install it and build with
make C=1 drivers/usb/file.o

> > > + temp = HCS_N_CC(ehci->hcs_params) * HCS_N_PCC(ehci->hcs_params);
> > > + temp &= 0x0f;
> >
> > companion HCs * ports per CC & 0xf?
> >
> > What's the &= 0x0f for? It's left out of the printk.
> Code got carried forward from ehci-pci.c . Is that says ehci-pci.c is
> uptodate? .

My guess is that ehci-pci.c is buggy. Anyway this is just a work around
to handle buggy hardware. Since the code here just prints some debug
output and doesn't do the work arounds we might as well remove the whole
thing? It seems unlikely that your mips hardware will have the same
bug.

> > > +static int ehci_msp_suspend(struct device *dev)
> > > +{
> > > + struct usb_hcd *hcd = dev_get_drvdata(dev);
> > > + struct ehci_hcd *ehci = hcd_to_ehci(hcd);
> > > + unsigned long flags;
> > > + int rc;
> > > +
> > > + return 0;
> > > + rc = 0;
> > > +
> > > + if (time_before(jiffies, ehci->next_statechange))
> > > + usleep(10000);
> >
> > Is there still a usleep() function? Either way, can you send us
> > something that compiles on linux-next?
> Again code got carried from ehci-pci.c .(changed msleep to usleep as
> checkpatch complained about it). I am unable to compile mips targets in
> linux-next tree . However this patch is tested with both linux-stable
> and linux-queue tree of l-m-o

checkpatch.pl complains because msleep() is not accurate for tiny
amounts of time. There is no usleep() function because trying to be
that accurate is a lot of work and causes a lot of interrupts. There
is a usleep_range() function instead which lets the scheduler group
wakeups together. This is documented in
Documentation/timers/timers-howto.txt

Also this is dead code. No one will complain, if you just delete it.

regards,
dan carpenter
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/