From: Dan Williams <dcbw@redhat.com>
To: Holger Schurig <hs4233@mail.mn-solutions.de>
Cc: linux-wireless@vger.kernel.org, marvell8385-devel@linuxtogo.org,
frankh@marvell.com, rchokshi@marvell.com
Subject: Re: How to start with a Marvell driver (non-USB, non-OLPC)
Date: Fri, 09 Feb 2007 10:49:17 -0500 [thread overview]
Message-ID: <1171036157.2774.15.camel@localhost.localdomain> (raw)
In-Reply-To: <200702091524.52389.hs4233@mail.mn-solutions.de>
On Fri, 2007-02-09 at 15:24 +0100, Holger Schurig wrote:
> > > I think the biggest problem here is the firmware. The OLPC
> > > people have a special firmware for their USB dongle, which
> > > is not used in other chips, so a driver that has been
> > > heavily adapted to this firmware isn't easy to mangle to a
> > > different firmware.
> >
> > No, it really hasn't. The mesh-specific bits are a separate
> > code path, and we routinely run non-mesh firmware using this
> > driver. If there are places that are missing run-time
> > firmware version checks, then we need to fix those places.
>
> In the libertas mailing list someone published the "WLAN Firmware
> Spec v5.1" spec, so I guess that you're now using this firmware.
Right; I think that was an inadvertent error on Ronak's part; but the
document is out there now and there's no way it can be taken back.
> But the Windows driver that I got hold on (to extract the
> firmware) all had a 5.0 in their driver name, so I guess they
> have a v5.0 firmware.
The WLAN Firmware document has a changelog at the end, so that might
give you the ability to figure out what pieces had been added to the
v5.1 firmware.
> But I guess this can be handled with if (fw_version >=
> FW_VERSION_5_1) or something like this.
Exactly. The v5.1 firmware is available on Marvell's site here; perhaps
it would work for you? There's nothing really OLPC specific in this
particular firmware version AFAIK. But it might be USB-only, I'm not
sure. It would also be interesting figure out what the Boot2 firmware
version for your variant is.
http://marvell.com/drivers/driverDisplay.do?dId=160&pId=38
> > Again, why don't we work together? We are _not_ intentionally
> > screwing over anybody else, and if there are pieces that you
> > need, why don't we put those pieces back in?
>
> Based on the things you said, I see no reason NOT to work
> together.
Ok, great.
>
> > We are _not_ intentionally screwing over anybody else, and if
> > there are pieces that you need, why don't we put those pieces
> > back in?
>
> I did not say this. I just saw in GIT that you remove misc things
> or discussed the removed of things (e.g. CIS related code), so I
> guessed that you only go into the USB dongle direction. But
> maybe you weren't aware that other WLAN devices with similar
> chips, but different host interface are available.
Right; we knew of the existence of the 8385 chip, but not much seemed to
be happening (nobody had touched the tree after an import of
libertas.git in a few weeks last I looked). Plus arguing to keep the
ugly HAL code on the basis of future support for a chip which didn't
have any code yet doesn't fly as an argument upstream.
But that's OK, we should probably re-write the HAL bits anyway if we
need to. AFAIK there was no CIS support really in the GPL drop from
Marvell; only the abstraction layer that would allow an if_cf.c to be
plugged in. But trust me, it was _really_ hard to follow that code.
> > The original libertas hardware abstraction bits really sucked.
>
> Did they release them as GPL as well? Or do you refer to the
> copyrighted driver that is downloadable from some vendors?
Yes, there were abstraction bits. All the sbi_* functions were part of
the base hardware-independent layer, and the if_usb_* bits were
USB-specific. But having a hardware abstraction layer that supported
only _one_ chip variant doesn't fly upstream, and we were asked to
remove it as a condition of merge.
> I'm already in libertas-dev, so when I have time to look at the
And I or Marcelo should probably join 8385-devel or something too. The
libertas-dev list hasn't been very active because only a few people are
working on it. Who knows, if you have questions you might even get
Ronak to answer them by posting to libertas-dev :) It might be worth a
shot.
> driver, I'll post some patches there. Rigth now I don't have
> much, e.g. I just put the infrastructure in place so that the
> PCMCIA subsystem detects the card and loads my driver.
Hey, that's a start. I think the next step would be to figure out what
hardware-specific pieces need to be abstracted and to start rebuilding a
sane HAL, based on what other wireless drivers like airo & orinoco do
for the different variants (plx, pci, pcmcia, etc).
dan
next prev parent reply other threads:[~2007-02-09 15:46 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2007-02-09 7:58 How to start with a Marvell driver (non-USB, non-OLPC) Holger Schurig
2007-02-09 12:35 ` John W. Linville
2007-02-09 12:49 ` Dan Williams
2007-02-09 14:24 ` Holger Schurig
2007-02-09 15:49 ` Dan Williams [this message]
2007-02-15 8:40 ` Holger Schurig
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1171036157.2774.15.camel@localhost.localdomain \
--to=dcbw@redhat.com \
--cc=frankh@marvell.com \
--cc=hs4233@mail.mn-solutions.de \
--cc=linux-wireless@vger.kernel.org \
--cc=marvell8385-devel@linuxtogo.org \
--cc=rchokshi@marvell.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).