Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 6dcdc19e authored by Harvey Harrison's avatar Harvey Harrison Committed by John W. Linville
Browse files

b43: use the bitrev helpers rather than rolling a private one



The 4-bit reversal flip_4bit is replaced with the bitrev helper
bitrev8 and a 4-bit shift.  The B43_WARN is moved to the location
where a register is read from for checking there.  The other caller
explicitly passes an array index which is guaranteed to be within range
and so a B43_WARN is not added there.

Signed-off-by: default avatarHarvey Harrison <harvey.harrison@gmail.com>
Reviewed-by: default avatarMichael Buesch <mb@bu3sch.de>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent d6894b5b
Loading
Loading
Loading
Loading
+6 −21
Original line number Original line Diff line number Diff line
@@ -28,6 +28,7 @@
#include <linux/delay.h>
#include <linux/delay.h>
#include <linux/io.h>
#include <linux/io.h>
#include <linux/types.h>
#include <linux/types.h>
#include <linux/bitrev.h>


#include "b43.h"
#include "b43.h"
#include "phy.h"
#include "phy.h"
@@ -83,25 +84,9 @@ const u8 b43_radio_channel_codes_bg[] = {
	72, 84,
	72, 84,
};
};


#define bitrev4(tmp) (bitrev8(tmp) >> 4)
static void b43_phy_initg(struct b43_wldev *dev);
static void b43_phy_initg(struct b43_wldev *dev);


/* Reverse the bits of a 4bit value.
 * Example:  1101 is flipped 1011
 */
static u16 flip_4bit(u16 value)
{
	u16 flipped = 0x0000;

	B43_WARN_ON(value & ~0x000F);

	flipped |= (value & 0x0001) << 3;
	flipped |= (value & 0x0002) << 1;
	flipped |= (value & 0x0004) >> 1;
	flipped |= (value & 0x0008) >> 3;

	return flipped;
}

static void generate_rfatt_list(struct b43_wldev *dev,
static void generate_rfatt_list(struct b43_wldev *dev,
				struct b43_rfatt_list *list)
				struct b43_rfatt_list *list)
{
{
@@ -2891,13 +2876,13 @@ b43_radio_interference_mitigation_enable(struct b43_wldev *dev, int mode)
		}
		}
		radio_stacksave(0x0078);
		radio_stacksave(0x0078);
		tmp = (b43_radio_read16(dev, 0x0078) & 0x001E);
		tmp = (b43_radio_read16(dev, 0x0078) & 0x001E);
		flipped = flip_4bit(tmp);
		B43_WARN_ON(tmp > 15);
		flipped = bitrev4(tmp);
		if (flipped < 10 && flipped >= 8)
		if (flipped < 10 && flipped >= 8)
			flipped = 7;
			flipped = 7;
		else if (flipped >= 10)
		else if (flipped >= 10)
			flipped -= 3;
			flipped -= 3;
		flipped = flip_4bit(flipped);
		flipped = (bitrev4(flipped) << 1) | 0x0020;
		flipped = (flipped << 1) | 0x0020;
		b43_radio_write16(dev, 0x0078, flipped);
		b43_radio_write16(dev, 0x0078, flipped);


		b43_calc_nrssi_threshold(dev);
		b43_calc_nrssi_threshold(dev);
@@ -3530,7 +3515,7 @@ u16 b43_radio_init2050(struct b43_wldev *dev)
	tmp1 >>= 9;
	tmp1 >>= 9;


	for (i = 0; i < 16; i++) {
	for (i = 0; i < 16; i++) {
		radio78 = ((flip_4bit(i) << 1) | 0x20);
		radio78 = (bitrev4(i) << 1) | 0x0020;
		b43_radio_write16(dev, 0x78, radio78);
		b43_radio_write16(dev, 0x78, radio78);
		udelay(10);
		udelay(10);
		for (j = 0; j < 16; j++) {
		for (j = 0; j < 16; j++) {