Skip site navigation (1)Skip section navigation (2)
Date:      Sat, 12 Nov 2005 10:08:39 +0200
From:      Danny Braniss <danny@cs.huji.ac.il>
To:        wpaul@FreeBSD.ORG (Bill Paul)
Cc:        freebsd-current@freebsd.org, Vulpes Velox <v.velox@vvelox.net>
Subject:   Re: problems with NDIS driver and convertion for a Marvel Yukon  Gigabit chip
Message-ID:  <E1EaqRD-0001F7-PP@cs1.cs.huji.ac.il>
In-Reply-To: Message from wpaul@FreeBSD.ORG (Bill Paul) of "Sat, 12 Nov 2005 04:36:01 GMT." <20051112043601.9077C16A420@hub.freebsd.org>

next in thread | previous in thread | raw e-mail | index | archive | help
> > On Fri, 11 Nov 2005 05:42:07 +0000 (GMT)
> > wpaul@FreeBSD.ORG (Bill Paul) wrote:
> > 
> > > > Ran into a few problems with ndisgen today.
> > > > 
> > > > I have to edit every instance of the following out to get it to
> > > > convert.
> > > > Magic Packet = "Magic Packet"
> > > > Pattern Match = "Pattern Match"
> > > > Mag Pack Patt Match = "Magic Packet & Pattern Match"
> > > > Link Change = "Link Change"
> > > > 
> > > > 
> > > > Upon loading the driver I get...
> > > > no match for ExUnregisterCallback
> > > > no match for ZwPowerInformation
> > > > no match for ExRegisterCallback
> > > > no match for ExCreateCallback
> > > > no match for ZwUnmapViewOfSection
> > > > no match for ZwMapViewOfSection
> > > > no match for ZwOpenSection
> > > > no match for wcslen
> > > > 
> > > > Any chance of getting this working or any suggestions?
> > > > 
> > > 
> > > Ok, had I read the subject line of your mail fully I'd have known
> > > what driver it was. I'm a dolt and I've clearly had too long of a
> > > day.
> > > 
> > > Here are the problems:
> > > 
> > > - I don't know exactly what driver image you have. Unless you
> > >   provide the URL for where you got it to put a copy somewhere,
> > >   I can't really analyze it.
> > 
> > http://marvell.com/drivers/driverDisplay.do?dId=118&pId=6
> > 
> > IIRC the installer dumps it Program Files/Marvell  It is where I
> > grabbed the .sys and .
> 
> I can probably unscramble it with Wine. I've had pretty good luck
> with it with other driver distribution.
>  
> > > - The .inf parser is not perfect. It's actually much stricter
> > >   about syntax than Windows is. Stuff that works ok for Windows
> > >   may be flagged as a syntax error by ndiscvt. If someone wants
> > >   to help fix this, they're welcome to. (No kernel hacking
> > >   required.)
> > 
> > Cool, any suggested reads?
> 
> The Microsoft MSDN site is the canonical source for documentation,
> such as it is. I would start with something like:
> 
> http://www.microsoft.com/whdc/archive/W2inf.mspx
> 
> The .INF syntax is very subtle: it's evolved a lot over time and
> you can use it to produce many strange effects. For example, it's
> possible to create a .INF file that can figure out if you're on
> a Win98, Win2K or WinXP system and install a different driver for
> each one. Another major source of complication is registry key
> specifications. NDIS drivers tend to specify only a few keys that
> need to be created at install time, but it's possible to create
> large numbers of them for various purposes. I've seen a Conexant
> modem driver that uses its .INF file to store a bunch of special
> keys containing some kind of binary patch tables that are used by
> the driver at runtime. There's also different patch tables for
> different chipsets.
> 
> > > - I have no earthy idea why Marvell is referencing these functions
> > >   in their driver. They're totally outside the NDIS spec. I'd be
> > >   rather surprised that such a driver was able to get WHQL
> > >   certification. (Assuming it did.)
> 
> Some investigation shows that they're probably using ExRegisterCallback()
> and its ilk to obtain notification about power state events. And I
> think they're using ZwMapViewOfSection() to basically do 'vtophys(),'
> i.e. map a physical address to a virtual one, probably so they can
> access some card resident RAM that's mapped into the host. (Actually,
> ZwMapViewOfSection() lets you read from the \Devices\PhysicalMemory
> device, so really it's the equivalent of grovelling around in /dev/mem.)
> 
> I'm unsure why they're doing this. I was under the impression you
> were supposed to have a MiniportPnpEvent() method to handle power
> event notifications. As for the physical/virtual address translation
> thing, they could have used NdisMMapIoSpace() or maybe even
> MmMapIoSpace() instead. Who knows.
> 
> > > - This is Marvell. Given the rotten treatment I've had from them
> > >   in the past, I'm not inclined to do them any favors now, so I'm
> > >   not exactly inclined to fix this anytime soon.
> > 
> > Fun, what happened, if I may ask?
> 
> Back when the patches to support the Yukon with sk(4) were first
> merged in, and people were having problems with multicast, I asked
> one of my SysKonnect contacts (who had now been assimilated by Marvell)
> for the Yukon manuals so I could fix it. They told me that I would
> need to sign both an NDA, and a software license agreement. I thought
> this was strange since I wasn't licensing them my software and they
> weren't licensing me theirs, but I told them I wanted official
> recognition of the fact that this was an open source project and
> that's what they came up with. I said "ok, send me both documents so
> I can read them." They sent me the NDA, but not the software license
> agreement. I wanted both before I would sign anything, and kept
> prodding my contact to send the license agreement, but he kept begging
> off and promising to talk with the right people.
> 
> Finally after about a month of this, I finally got an e-mail from
> someone else telling me that they had decided they were going to produce
> their own binary driver (actually, they had been working on it all
> along) and because of that they saw no need to give me the manuals
> now. But they did offer me some free sample cards.
> 
> I told them I was terminating any further involvement with SysKonnect
> and Marvell and they could keep their cards.
> 
> I still have the e-mails from them archived somewhere.
> 
> Some time later (I'm not sure how long, maybe a month or two), I was
> contacted via e-mail by a SysKonnect/Marvell engineer in Germany who
> wanted to know if we could make the sk(4) driver optional so that their
> customers could use their binary only driver without having to recompile
> the kernel. I told him flatly that I wasn't on speaking terms with his
> company anymore and that he was out of luck.
> 
> I was startled to receive a phone call from him shortly after. He was
> rather taken aback and curious to know why I had become so unhappy
> with his company, so I explain to him how his Marvell overlords had
> stonewalled me earlier. He was very surprised and disappointed. He
> seemed like a nice fellow and I told him while I had nothing against
> him personally, but I was not about to make Marvell's life easier when
> they had made mine so miserable.
> 
> During our conversation, I found out that he had been tasked with
> developing the Yukon driver for FreeBSD. Then it was my turn to be
> taken aback, when he admitted to me that he hadn't actually read
> the Yukon manual: instead, he had been provided with an API library
> for communicating with the card and was essentially producing a
> wrapper for that library to interface it with FreeBSD. Now, this
> technique is not new: Broadcom and other vendors have been using it
> for a long time. But even so, I would like to think that library or
> no, the engineers writing the drivers are actually familiar with the
> hardware.
> 
> So you can understand why I'm not in any hurry to do anything nice
> for them.

some months ago, using some local contacts, i managed to get from them the
driver for the newer Yukon, after a long delay of QA. I tried it and it bombed.

So after some exchanges, it seems that QA did not check it under SMP, even
if the testing host was a dual cpu.
They promised to have a newer in a few weeks, it's been now more than a few
months.

	danny









Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?E1EaqRD-0001F7-PP>