Thread (7 messages) 7 messages, 3 authors, 2012-05-31

Re: [PATCH] b43: ensure ext PA lines are enabled for BCM4331

From: Hauke Mehrtens <hauke@hauke-m.de>
Date: 2012-05-31 22:58:45

On 06/01/2012 12:06 AM, Seth Forshee wrote:
On Thu, May 31, 2012 at 06:23:25PM +0200, Hauke Mehrtens wrote:
quoted
On 05/31/2012 04:26 PM, Seth Forshee wrote:
quoted
On Thu, May 31, 2012 at 04:16:05PM +0200, Hauke Mehrtens wrote:
quoted
Hi Seth,

why don't you call this from bcma_pmu_workarounds() in
drivers/bcma/driver_chipcommon_pmu.c instead of calling this from b43? I
think it looks better to call some workarounds on chip common from bcma
and not from b43.
Arend recommended calling it from within b43's start op, but I'm not
sure of the reason. Arend?

Agreed though that if there's no need to run it every time the interface
is started then bcma_pmu_workarounds() would be a nicer place for it.
brcmsmac calls the chip specific the workarounds in ai_doattach(), but
the ones for BCM4313 and BCM43224 are also in bcma_pmu_workarounds(),
this should be cleaned up to have them just at one place. In some old
version of brcmsmac the workaround for the BCM4331 was also called from
ai_doattach() function, but later removed likely because this devices is
not supported by brcmsmac.
So if there is not better reason as, the proprietary Broadcom driver
does so, I would like to see this call in bcma_pmu_workarounds().
I found the SDK code from a router source package, and oddly that code
is clearing those bits in si_doattach(). In fact si_chipcontrl_epa4331()
is never called to enable the ext PA lines, only to disable them. The
sprom code reads the value before disabling them and restores it after
reading from the sprom. Enabling the ext PA pins is what fixes things
for me. Predictably, duplicating this in bcma makes wireless broken all
the time.
The open source SDK just contains some of the code, the wireless part is
closed source and I haven't seen any call which enables this in the open
part too. The initial commit of brcm80211 to the kernel staging area
contains a call to this function with true given.
It is commit a9533e7ea3c410fed2f4cd8b3e1e213e48529b75 if you are interested.
At any rate, it sounds like we're agreed to add the workaround in
bcma_pmu_workarounds(), so I'll redo the patch.
quoted
quoted
quoted
According to some Broadcom code this should also be called for chip_id
43431 when turning it on and in the sprom code.
I'm having trouble parsing this, specifically the "and in the sprom
code" part. Can you clarify?
In the Broadcom SDK code si_chipcontrl_epa4331(), the same function as
bcma_chipco_bcm4331_ext_pa_lines_ctl() in bcma, gets called for devices
with a chip id of 0x4331 and 43431, both seam to be BCM4331 devices. We
should also call our workarounds for both chip ids.
I'll fix this too.

Thanks,
Seth
  
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help