Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 150880
b: refs/heads/master
c: 7308a0c
h: refs/heads/master
v: v3
  • Loading branch information
Dirk Brandewie authored and Inaky Perez-Gonzalez committed Jun 11, 2009
1 parent 3061cf9 commit 726feb3
Show file tree
Hide file tree
Showing 3 changed files with 42 additions and 33 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: ecddfd5ed73c070413f07a5251c16c10e69f35a2
refs/heads/master: 7308a0c23901f2a295265bb71d8521ef7d47bf4c
45 changes: 13 additions & 32 deletions trunk/drivers/net/wimax/i2400m/fw.c
Original file line number Diff line number Diff line change
Expand Up @@ -770,40 +770,21 @@ int i2400m_read_mac_addr(struct i2400m *i2400m)
static
int i2400m_dnload_init_nonsigned(struct i2400m *i2400m)
{
#define POKE(a, d) { \
.address = cpu_to_le32(a), \
.data = cpu_to_le32(d) \
}
static const struct {
__le32 address;
__le32 data;
} i2400m_pokes[] = {
POKE(0x081A58, 0xA7810230),
POKE(0x080040, 0x00000000),
POKE(0x080048, 0x00000082),
POKE(0x08004C, 0x0000081F),
POKE(0x080054, 0x00000085),
POKE(0x080058, 0x00000180),
POKE(0x08005C, 0x00000018),
POKE(0x080060, 0x00000010),
POKE(0x080574, 0x00000001),
POKE(0x080550, 0x00000005),
POKE(0xAE0000, 0x00000000),
};
#undef POKE
unsigned i;
int ret;
unsigned i = 0;
int ret = 0;
struct device *dev = i2400m_dev(i2400m);

dev_warn(dev, "WARNING!!! non-signed boot UNTESTED PATH!\n");

d_fnstart(5, dev, "(i2400m %p)\n", i2400m);
for (i = 0; i < ARRAY_SIZE(i2400m_pokes); i++) {
ret = i2400m_download_chunk(i2400m, &i2400m_pokes[i].data,
sizeof(i2400m_pokes[i].data),
i2400m_pokes[i].address, 1, 1);
if (ret < 0)
break;
if (i2400m->bus_bm_pokes_table) {
while (i2400m->bus_bm_pokes_table[i].address) {
ret = i2400m_download_chunk(
i2400m,
&i2400m->bus_bm_pokes_table[i].data,
sizeof(i2400m->bus_bm_pokes_table[i].data),
i2400m->bus_bm_pokes_table[i].address, 1, 1);
if (ret < 0)
break;
i++;
}
}
d_fnend(5, dev, "(i2400m %p) = %d\n", i2400m, ret);
return ret;
Expand Down
28 changes: 28 additions & 0 deletions trunk/drivers/net/wimax/i2400m/i2400m.h
Original file line number Diff line number Diff line change
Expand Up @@ -156,6 +156,27 @@ enum {
I2400M_BM_ACK_BUF_SIZE = 256,
};

/**
* struct i2400m_poke_table - Hardware poke table for the Intel 2400m
*
* This structure will be used to create a device specific poke table
* to put the device in a consistant state at boot time.
*
* @address: The device address to poke
*
* @data: The data value to poke to the device address
*
*/
struct i2400m_poke_table{
__le32 address;
__le32 data;
};

#define I2400M_FW_POKE(a, d) { \
.address = cpu_to_le32(a), \
.data = cpu_to_le32(d) \
}


/**
* i2400m_reset_type - methods to reset a device
Expand Down Expand Up @@ -264,6 +285,12 @@ struct i2400m_roq;
* address provided in boot mode is kind of broken and needs to
* be re-read later on.
*
* @bus_bm_pokes_table: [fill/optional] A table of device addresses
* and values that will be poked at device init time to move the
* device to the correct state for the type of boot/firmware being
* used. This table MUST be terminated with (0x000000,
* 0x00000000) or bad things will happen.
*
*
* @wimax_dev: WiMAX generic device for linkage into the kernel WiMAX
* stack. Due to the way a net_device is allocated, we need to
Expand Down Expand Up @@ -424,6 +451,7 @@ struct i2400m {
struct i2400m_bootrom_header *, size_t);
const char **bus_fw_names;
unsigned bus_bm_mac_addr_impaired:1;
const struct i2400m_poke_table *bus_bm_pokes_table;

spinlock_t tx_lock; /* protect TX state */
void *tx_buf;
Expand Down

0 comments on commit 726feb3

Please sign in to comment.