提交 daf4b805 编写于 作者: L Linus Torvalds

Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394-2.6

* 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394-2.6:
  firewire: reorder struct fw_card for better cache efficiency
  firewire: fix resetting of bus manager retry counter
  firewire: improve refcounting of fw_card
  firewire: typo in comment
  firewire: fix small memory leak at module removal
  firewire: fw-sbp2: remove unnecessary locking
  ieee1934: dv1394: interrupt enabling/disabling broken on big-endian
  ieee1394: dv1394: annotate frame input/output structs as little endian
  ieee1394: eth1394: trivial sparse annotations
  ieee1394: mark bus_info_data as a __be32 array
  ieee1394: replace CSR_SET_BUS_INFO_GENERATION macro
  ieee1394: pcilynx: trivial endian annotation
  ieee1394: ignore nonzero Bus_Info_Block.max_rom, fetch config ROM in quadlets
  ieee1394: consolidate uses of IEEE1934_BUSID_MAGIC
  ieee1394: ohci1394: flush MMIO writes before delay in initialization
  ieee1394: ohci1394: pass error codes from request_irq through
  ieee1394: ohci1394: don't leave interrupts enabled during suspend/resume
  ieee1394: mark all hpsb_address_ops instances as const
  ieee1394: replace a GFP_ATOMIC by GFP_KERNEL allocation
...@@ -75,7 +75,7 @@ generate_config_rom(struct fw_card *card, size_t *config_rom_length) ...@@ -75,7 +75,7 @@ generate_config_rom(struct fw_card *card, size_t *config_rom_length)
* controller, block reads to the config rom accesses the host * controller, block reads to the config rom accesses the host
* memory, but quadlet read access the hardware bus info block * memory, but quadlet read access the hardware bus info block
* registers. That's just crack, but it means we should make * registers. That's just crack, but it means we should make
* sure the contents of bus info block in host memory mathces * sure the contents of bus info block in host memory matches
* the version stored in the OHCI registers. * the version stored in the OHCI registers.
*/ */
...@@ -189,6 +189,17 @@ static const char gap_count_table[] = { ...@@ -189,6 +189,17 @@ static const char gap_count_table[] = {
63, 5, 7, 8, 10, 13, 16, 18, 21, 24, 26, 29, 32, 35, 37, 40 63, 5, 7, 8, 10, 13, 16, 18, 21, 24, 26, 29, 32, 35, 37, 40
}; };
void
fw_schedule_bm_work(struct fw_card *card, unsigned long delay)
{
int scheduled;
fw_card_get(card);
scheduled = schedule_delayed_work(&card->work, delay);
if (!scheduled)
fw_card_put(card);
}
static void static void
fw_card_bm_work(struct work_struct *work) fw_card_bm_work(struct work_struct *work)
{ {
...@@ -206,7 +217,7 @@ fw_card_bm_work(struct work_struct *work) ...@@ -206,7 +217,7 @@ fw_card_bm_work(struct work_struct *work)
if (local_node == NULL) { if (local_node == NULL) {
spin_unlock_irqrestore(&card->lock, flags); spin_unlock_irqrestore(&card->lock, flags);
return; goto out_put_card;
} }
fw_node_get(local_node); fw_node_get(local_node);
fw_node_get(root_node); fw_node_get(root_node);
...@@ -280,7 +291,7 @@ fw_card_bm_work(struct work_struct *work) ...@@ -280,7 +291,7 @@ fw_card_bm_work(struct work_struct *work)
* this task 100ms from now. * this task 100ms from now.
*/ */
spin_unlock_irqrestore(&card->lock, flags); spin_unlock_irqrestore(&card->lock, flags);
schedule_delayed_work(&card->work, DIV_ROUND_UP(HZ, 10)); fw_schedule_bm_work(card, DIV_ROUND_UP(HZ, 10));
goto out; goto out;
} }
...@@ -355,6 +366,8 @@ fw_card_bm_work(struct work_struct *work) ...@@ -355,6 +366,8 @@ fw_card_bm_work(struct work_struct *work)
fw_device_put(root_device); fw_device_put(root_device);
fw_node_put(root_node); fw_node_put(root_node);
fw_node_put(local_node); fw_node_put(local_node);
out_put_card:
fw_card_put(card);
} }
static void static void
...@@ -510,7 +523,6 @@ fw_core_remove_card(struct fw_card *card) ...@@ -510,7 +523,6 @@ fw_core_remove_card(struct fw_card *card)
fw_card_put(card); fw_card_put(card);
wait_for_completion(&card->done); wait_for_completion(&card->done);
cancel_delayed_work_sync(&card->work);
WARN_ON(!list_empty(&card->transaction_list)); WARN_ON(!list_empty(&card->transaction_list));
del_timer_sync(&card->flush_timer); del_timer_sync(&card->flush_timer);
} }
......
...@@ -617,7 +617,7 @@ static int shutdown_unit(struct device *device, void *data) ...@@ -617,7 +617,7 @@ static int shutdown_unit(struct device *device, void *data)
*/ */
DECLARE_RWSEM(fw_device_rwsem); DECLARE_RWSEM(fw_device_rwsem);
static DEFINE_IDR(fw_device_idr); DEFINE_IDR(fw_device_idr);
int fw_cdev_major; int fw_cdev_major;
struct fw_device *fw_device_get_by_devt(dev_t devt) struct fw_device *fw_device_get_by_devt(dev_t devt)
...@@ -689,7 +689,7 @@ static void fw_device_init(struct work_struct *work) ...@@ -689,7 +689,7 @@ static void fw_device_init(struct work_struct *work)
fw_notify("giving up on config rom for node id %x\n", fw_notify("giving up on config rom for node id %x\n",
device->node_id); device->node_id);
if (device->node == device->card->root_node) if (device->node == device->card->root_node)
schedule_delayed_work(&device->card->work, 0); fw_schedule_bm_work(device->card, 0);
fw_device_release(&device->device); fw_device_release(&device->device);
} }
return; return;
...@@ -758,7 +758,7 @@ static void fw_device_init(struct work_struct *work) ...@@ -758,7 +758,7 @@ static void fw_device_init(struct work_struct *work)
* pretty harmless. * pretty harmless.
*/ */
if (device->node == device->card->root_node) if (device->node == device->card->root_node)
schedule_delayed_work(&device->card->work, 0); fw_schedule_bm_work(device->card, 0);
return; return;
...@@ -892,7 +892,7 @@ static void fw_device_refresh(struct work_struct *work) ...@@ -892,7 +892,7 @@ static void fw_device_refresh(struct work_struct *work)
fw_device_shutdown(work); fw_device_shutdown(work);
out: out:
if (node_id == card->root_node->node_id) if (node_id == card->root_node->node_id)
schedule_delayed_work(&card->work, 0); fw_schedule_bm_work(card, 0);
} }
void fw_node_event(struct fw_card *card, struct fw_node *node, int event) void fw_node_event(struct fw_card *card, struct fw_node *node, int event)
......
...@@ -21,6 +21,7 @@ ...@@ -21,6 +21,7 @@
#include <linux/fs.h> #include <linux/fs.h>
#include <linux/cdev.h> #include <linux/cdev.h>
#include <linux/idr.h>
#include <linux/rwsem.h> #include <linux/rwsem.h>
#include <asm/atomic.h> #include <asm/atomic.h>
...@@ -99,6 +100,7 @@ void fw_device_cdev_update(struct fw_device *device); ...@@ -99,6 +100,7 @@ void fw_device_cdev_update(struct fw_device *device);
void fw_device_cdev_remove(struct fw_device *device); void fw_device_cdev_remove(struct fw_device *device);
extern struct rw_semaphore fw_device_rwsem; extern struct rw_semaphore fw_device_rwsem;
extern struct idr fw_device_idr;
extern int fw_cdev_major; extern int fw_cdev_major;
/* /*
......
...@@ -670,17 +670,6 @@ static void sbp2_agent_reset_no_wait(struct sbp2_logical_unit *lu) ...@@ -670,17 +670,6 @@ static void sbp2_agent_reset_no_wait(struct sbp2_logical_unit *lu)
&d, sizeof(d), complete_agent_reset_write_no_wait, t); &d, sizeof(d), complete_agent_reset_write_no_wait, t);
} }
static void sbp2_set_generation(struct sbp2_logical_unit *lu, int generation)
{
struct fw_card *card = fw_device(lu->tgt->unit->device.parent)->card;
unsigned long flags;
/* serialize with comparisons of lu->generation and card->generation */
spin_lock_irqsave(&card->lock, flags);
lu->generation = generation;
spin_unlock_irqrestore(&card->lock, flags);
}
static inline void sbp2_allow_block(struct sbp2_logical_unit *lu) static inline void sbp2_allow_block(struct sbp2_logical_unit *lu)
{ {
/* /*
...@@ -884,7 +873,7 @@ static void sbp2_login(struct work_struct *work) ...@@ -884,7 +873,7 @@ static void sbp2_login(struct work_struct *work)
goto out; goto out;
generation = device->generation; generation = device->generation;
smp_rmb(); /* node_id must not be older than generation */ smp_rmb(); /* node IDs must not be older than generation */
node_id = device->node_id; node_id = device->node_id;
local_node_id = device->card->node_id; local_node_id = device->card->node_id;
...@@ -908,7 +897,8 @@ static void sbp2_login(struct work_struct *work) ...@@ -908,7 +897,8 @@ static void sbp2_login(struct work_struct *work)
tgt->node_id = node_id; tgt->node_id = node_id;
tgt->address_high = local_node_id << 16; tgt->address_high = local_node_id << 16;
sbp2_set_generation(lu, generation); smp_wmb(); /* node IDs must not be older than generation */
lu->generation = generation;
lu->command_block_agent_address = lu->command_block_agent_address =
((u64)(be32_to_cpu(response.command_block_agent.high) & 0xffff) ((u64)(be32_to_cpu(response.command_block_agent.high) & 0xffff)
...@@ -1201,7 +1191,7 @@ static void sbp2_reconnect(struct work_struct *work) ...@@ -1201,7 +1191,7 @@ static void sbp2_reconnect(struct work_struct *work)
goto out; goto out;
generation = device->generation; generation = device->generation;
smp_rmb(); /* node_id must not be older than generation */ smp_rmb(); /* node IDs must not be older than generation */
node_id = device->node_id; node_id = device->node_id;
local_node_id = device->card->node_id; local_node_id = device->card->node_id;
...@@ -1228,7 +1218,8 @@ static void sbp2_reconnect(struct work_struct *work) ...@@ -1228,7 +1218,8 @@ static void sbp2_reconnect(struct work_struct *work)
tgt->node_id = node_id; tgt->node_id = node_id;
tgt->address_high = local_node_id << 16; tgt->address_high = local_node_id << 16;
sbp2_set_generation(lu, generation); smp_wmb(); /* node IDs must not be older than generation */
lu->generation = generation;
fw_notify("%s: reconnected to LUN %04x (%d retries)\n", fw_notify("%s: reconnected to LUN %04x (%d retries)\n",
tgt->bus_id, lu->lun, lu->retries); tgt->bus_id, lu->lun, lu->retries);
......
...@@ -355,6 +355,9 @@ report_lost_node(struct fw_card *card, ...@@ -355,6 +355,9 @@ report_lost_node(struct fw_card *card,
{ {
fw_node_event(card, node, FW_NODE_DESTROYED); fw_node_event(card, node, FW_NODE_DESTROYED);
fw_node_put(node); fw_node_put(node);
/* Topology has changed - reset bus manager retry counter */
card->bm_retries = 0;
} }
static void static void
...@@ -374,6 +377,9 @@ report_found_node(struct fw_card *card, ...@@ -374,6 +377,9 @@ report_found_node(struct fw_card *card,
} }
fw_node_event(card, node, FW_NODE_CREATED); fw_node_event(card, node, FW_NODE_CREATED);
/* Topology has changed - reset bus manager retry counter */
card->bm_retries = 0;
} }
void fw_destroy_nodes(struct fw_card *card) void fw_destroy_nodes(struct fw_card *card)
...@@ -514,14 +520,6 @@ fw_core_handle_bus_reset(struct fw_card *card, ...@@ -514,14 +520,6 @@ fw_core_handle_bus_reset(struct fw_card *card,
spin_lock_irqsave(&card->lock, flags); spin_lock_irqsave(&card->lock, flags);
/*
* If the new topology has a different self_id_count the topology
* changed, either nodes were added or removed. In that case we
* reset the IRM reset counter.
*/
if (card->self_id_count != self_id_count)
card->bm_retries = 0;
card->node_id = node_id; card->node_id = node_id;
/* /*
* Update node_id before generation to prevent anybody from using * Update node_id before generation to prevent anybody from using
...@@ -530,7 +528,7 @@ fw_core_handle_bus_reset(struct fw_card *card, ...@@ -530,7 +528,7 @@ fw_core_handle_bus_reset(struct fw_card *card,
smp_wmb(); smp_wmb();
card->generation = generation; card->generation = generation;
card->reset_jiffies = jiffies; card->reset_jiffies = jiffies;
schedule_delayed_work(&card->work, 0); fw_schedule_bm_work(card, 0);
local_node = build_tree(card, self_ids, self_id_count); local_node = build_tree(card, self_ids, self_id_count);
......
...@@ -19,6 +19,7 @@ ...@@ -19,6 +19,7 @@
*/ */
#include <linux/completion.h> #include <linux/completion.h>
#include <linux/idr.h>
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/kref.h> #include <linux/kref.h>
#include <linux/module.h> #include <linux/module.h>
...@@ -971,6 +972,7 @@ static void __exit fw_core_cleanup(void) ...@@ -971,6 +972,7 @@ static void __exit fw_core_cleanup(void)
{ {
unregister_chrdev(fw_cdev_major, "firewire"); unregister_chrdev(fw_cdev_major, "firewire");
bus_unregister(&fw_bus_type); bus_unregister(&fw_bus_type);
idr_destroy(&fw_device_idr);
} }
module_init(fw_core_init); module_init(fw_core_init);
......
...@@ -237,14 +237,6 @@ struct fw_card { ...@@ -237,14 +237,6 @@ struct fw_card {
int link_speed; int link_speed;
int config_rom_generation; int config_rom_generation;
/*
* We need to store up to 4 self ID for a maximum of 63
* devices plus 3 words for the topology map header.
*/
int self_id_count;
u32 topology_map[252 + 3];
u32 broadcast_channel;
spinlock_t lock; /* Take this lock when handling the lists in spinlock_t lock; /* Take this lock when handling the lists in
* this struct. */ * this struct. */
struct fw_node *local_node; struct fw_node *local_node;
...@@ -262,6 +254,9 @@ struct fw_card { ...@@ -262,6 +254,9 @@ struct fw_card {
struct delayed_work work; struct delayed_work work;
int bm_retries; int bm_retries;
int bm_generation; int bm_generation;
u32 broadcast_channel;
u32 topology_map[(CSR_TOPOLOGY_MAP_END - CSR_TOPOLOGY_MAP) / 4];
}; };
static inline struct fw_card *fw_card_get(struct fw_card *card) static inline struct fw_card *fw_card_get(struct fw_card *card)
...@@ -278,6 +273,8 @@ static inline void fw_card_put(struct fw_card *card) ...@@ -278,6 +273,8 @@ static inline void fw_card_put(struct fw_card *card)
kref_put(&card->kref, fw_card_release); kref_put(&card->kref, fw_card_release);
} }
extern void fw_schedule_bm_work(struct fw_card *card, unsigned long delay);
/* /*
* The iso packet format allows for an immediate header/payload part * The iso packet format allows for an immediate header/payload part
* stored in 'header' immediately after the packet info plus an * stored in 'header' immediately after the packet info plus an
......
...@@ -68,22 +68,22 @@ static struct hpsb_highlevel csr_highlevel = { ...@@ -68,22 +68,22 @@ static struct hpsb_highlevel csr_highlevel = {
.host_reset = host_reset, .host_reset = host_reset,
}; };
static struct hpsb_address_ops map_ops = { const static struct hpsb_address_ops map_ops = {
.read = read_maps, .read = read_maps,
}; };
static struct hpsb_address_ops fcp_ops = { const static struct hpsb_address_ops fcp_ops = {
.write = write_fcp, .write = write_fcp,
}; };
static struct hpsb_address_ops reg_ops = { const static struct hpsb_address_ops reg_ops = {
.read = read_regs, .read = read_regs,
.write = write_regs, .write = write_regs,
.lock = lock_regs, .lock = lock_regs,
.lock64 = lock64_regs, .lock64 = lock64_regs,
}; };
static struct hpsb_address_ops config_rom_ops = { const static struct hpsb_address_ops config_rom_ops = {
.read = read_config_rom, .read = read_config_rom,
}; };
...@@ -217,7 +217,7 @@ static void add_host(struct hpsb_host *host) ...@@ -217,7 +217,7 @@ static void add_host(struct hpsb_host *host)
host->csr.generation = 2; host->csr.generation = 2;
bus_info[1] = __constant_cpu_to_be32(0x31333934); bus_info[1] = IEEE1394_BUSID_MAGIC;
bus_info[2] = cpu_to_be32((hpsb_disable_irm ? 0 : 1 << CSR_IRMC_SHIFT) | bus_info[2] = cpu_to_be32((hpsb_disable_irm ? 0 : 1 << CSR_IRMC_SHIFT) |
(1 << CSR_CMC_SHIFT) | (1 << CSR_CMC_SHIFT) |
(1 << CSR_ISC_SHIFT) | (1 << CSR_ISC_SHIFT) |
...@@ -250,7 +250,7 @@ static void remove_host(struct hpsb_host *host) ...@@ -250,7 +250,7 @@ static void remove_host(struct hpsb_host *host)
{ {
quadlet_t bus_info[CSR_BUS_INFO_SIZE]; quadlet_t bus_info[CSR_BUS_INFO_SIZE];
bus_info[1] = __constant_cpu_to_be32(0x31333934); bus_info[1] = IEEE1394_BUSID_MAGIC;
bus_info[2] = cpu_to_be32((0 << CSR_IRMC_SHIFT) | bus_info[2] = cpu_to_be32((0 << CSR_IRMC_SHIFT) |
(0 << CSR_CMC_SHIFT) | (0 << CSR_CMC_SHIFT) |
(0 << CSR_ISC_SHIFT) | (0 << CSR_ISC_SHIFT) |
......
...@@ -50,11 +50,11 @@ ...@@ -50,11 +50,11 @@
#define CSR_MAX_ROM_SHIFT 8 #define CSR_MAX_ROM_SHIFT 8
#define CSR_GENERATION_SHIFT 4 #define CSR_GENERATION_SHIFT 4
#define CSR_SET_BUS_INFO_GENERATION(csr, gen) \ static inline void csr_set_bus_info_generation(struct csr1212_csr *csr, u8 gen)
((csr)->bus_info_data[2] = \ {
cpu_to_be32((be32_to_cpu((csr)->bus_info_data[2]) & \ csr->bus_info_data[2] &= ~cpu_to_be32(0xf << CSR_GENERATION_SHIFT);
~(0xf << CSR_GENERATION_SHIFT)) | \ csr->bus_info_data[2] |= cpu_to_be32((u32)gen << CSR_GENERATION_SHIFT);
(gen) << CSR_GENERATION_SHIFT)) }
struct csr_control { struct csr_control {
spinlock_t lock; spinlock_t lock;
......
...@@ -1077,15 +1077,10 @@ static int csr1212_parse_bus_info_block(struct csr1212_csr *csr) ...@@ -1077,15 +1077,10 @@ static int csr1212_parse_bus_info_block(struct csr1212_csr *csr)
int i; int i;
int ret; int ret;
/* IEEE 1212 says that the entire bus info block should be readable in
* a single transaction regardless of the max_rom value.
* Unfortunately, many IEEE 1394 devices do not abide by that, so the
* bus info block will be read 1 quadlet at a time. The rest of the
* ConfigROM will be read according to the max_rom field. */
for (i = 0; i < csr->bus_info_len; i += sizeof(u32)) { for (i = 0; i < csr->bus_info_len; i += sizeof(u32)) {
ret = csr->ops->bus_read(csr, CSR1212_CONFIG_ROM_SPACE_BASE + i, ret = csr->ops->bus_read(csr, CSR1212_CONFIG_ROM_SPACE_BASE + i,
sizeof(u32), &csr->cache_head->data[bytes_to_quads(i)], &csr->cache_head->data[bytes_to_quads(i)],
csr->private); csr->private);
if (ret != CSR1212_SUCCESS) if (ret != CSR1212_SUCCESS)
return ret; return ret;
...@@ -1104,8 +1099,8 @@ static int csr1212_parse_bus_info_block(struct csr1212_csr *csr) ...@@ -1104,8 +1099,8 @@ static int csr1212_parse_bus_info_block(struct csr1212_csr *csr)
* a time. */ * a time. */
for (i = csr->bus_info_len; i <= csr->crc_len; i += sizeof(u32)) { for (i = csr->bus_info_len; i <= csr->crc_len; i += sizeof(u32)) {
ret = csr->ops->bus_read(csr, CSR1212_CONFIG_ROM_SPACE_BASE + i, ret = csr->ops->bus_read(csr, CSR1212_CONFIG_ROM_SPACE_BASE + i,
sizeof(u32), &csr->cache_head->data[bytes_to_quads(i)], &csr->cache_head->data[bytes_to_quads(i)],
csr->private); csr->private);
if (ret != CSR1212_SUCCESS) if (ret != CSR1212_SUCCESS)
return ret; return ret;
} }
...@@ -1289,7 +1284,7 @@ csr1212_read_keyval(struct csr1212_csr *csr, struct csr1212_keyval *kv) ...@@ -1289,7 +1284,7 @@ csr1212_read_keyval(struct csr1212_csr *csr, struct csr1212_keyval *kv)
if (csr->ops->bus_read(csr, if (csr->ops->bus_read(csr,
CSR1212_REGISTER_SPACE_BASE + kv->offset, CSR1212_REGISTER_SPACE_BASE + kv->offset,
sizeof(u32), &q, csr->private)) &q, csr->private))
return -EIO; return -EIO;
kv->value.leaf.len = be32_to_cpu(q) >> 16; kv->value.leaf.len = be32_to_cpu(q) >> 16;
...@@ -1372,17 +1367,8 @@ csr1212_read_keyval(struct csr1212_csr *csr, struct csr1212_keyval *kv) ...@@ -1372,17 +1367,8 @@ csr1212_read_keyval(struct csr1212_csr *csr, struct csr1212_keyval *kv)
addr = (CSR1212_CSR_ARCH_REG_SPACE_BASE + cache->offset + addr = (CSR1212_CSR_ARCH_REG_SPACE_BASE + cache->offset +
cr->offset_end) & ~(csr->max_rom - 1); cr->offset_end) & ~(csr->max_rom - 1);
if (csr->ops->bus_read(csr, addr, csr->max_rom, cache_ptr, if (csr->ops->bus_read(csr, addr, cache_ptr, csr->private))
csr->private)) { return -EIO;
if (csr->max_rom == 4)
/* We've got problems! */
return -EIO;
/* Apperently the max_rom value was a lie, set it to
* do quadlet reads and try again. */
csr->max_rom = 4;
continue;
}
cr->offset_end += csr->max_rom - (cr->offset_end & cr->offset_end += csr->max_rom - (cr->offset_end &
(csr->max_rom - 1)); (csr->max_rom - 1));
...@@ -1433,7 +1419,6 @@ csr1212_get_keyval(struct csr1212_csr *csr, struct csr1212_keyval *kv) ...@@ -1433,7 +1419,6 @@ csr1212_get_keyval(struct csr1212_csr *csr, struct csr1212_keyval *kv)
int csr1212_parse_csr(struct csr1212_csr *csr) int csr1212_parse_csr(struct csr1212_csr *csr)
{ {
static const int mr_map[] = { 4, 64, 1024, 0 };
struct csr1212_dentry *dentry; struct csr1212_dentry *dentry;
int ret; int ret;
...@@ -1443,15 +1428,13 @@ int csr1212_parse_csr(struct csr1212_csr *csr) ...@@ -1443,15 +1428,13 @@ int csr1212_parse_csr(struct csr1212_csr *csr)
if (ret != CSR1212_SUCCESS) if (ret != CSR1212_SUCCESS)
return ret; return ret;
if (!csr->ops->get_max_rom) { /*
csr->max_rom = mr_map[0]; /* default value */ * There has been a buggy firmware with bus_info_block.max_rom > 0
} else { * spotted which actually only supported quadlet read requests to the
int i = csr->ops->get_max_rom(csr->bus_info_data, * config ROM. Therefore read everything quadlet by quadlet regardless
csr->private); * of what the bus info block says.
if (i & ~0x3) */
return -EINVAL; csr->max_rom = 4;
csr->max_rom = mr_map[i];
}
csr->cache_head->layout_head = csr->root_kv; csr->cache_head->layout_head = csr->root_kv;
csr->cache_head->layout_tail = csr->root_kv; csr->cache_head->layout_tail = csr->root_kv;
......
...@@ -181,7 +181,7 @@ struct csr1212_csr_rom_cache { ...@@ -181,7 +181,7 @@ struct csr1212_csr_rom_cache {
struct csr1212_csr { struct csr1212_csr {
size_t bus_info_len; /* bus info block length in bytes */ size_t bus_info_len; /* bus info block length in bytes */
size_t crc_len; /* crc length in bytes */ size_t crc_len; /* crc length in bytes */
u32 *bus_info_data; /* bus info data incl bus name and EUI */ __be32 *bus_info_data; /* bus info data incl bus name and EUI */
void *private; /* private, bus specific data */ void *private; /* private, bus specific data */
struct csr1212_bus_ops *ops; struct csr1212_bus_ops *ops;
...@@ -200,7 +200,7 @@ struct csr1212_bus_ops { ...@@ -200,7 +200,7 @@ struct csr1212_bus_ops {
* entries located in the Units Space. Must return 0 on success * entries located in the Units Space. Must return 0 on success
* anything else indicates an error. */ * anything else indicates an error. */
int (*bus_read) (struct csr1212_csr *csr, u64 addr, int (*bus_read) (struct csr1212_csr *csr, u64 addr,
u16 length, void *buffer, void *private); void *buffer, void *private);
/* This function is used by csr1212 to allocate a region in units space /* This function is used by csr1212 to allocate a region in units space
* in the event that Config ROM entries don't all fit in the predefined * in the event that Config ROM entries don't all fit in the predefined
...@@ -211,11 +211,6 @@ struct csr1212_bus_ops { ...@@ -211,11 +211,6 @@ struct csr1212_bus_ops {
/* This function is used by csr1212 to release a region in units space /* This function is used by csr1212 to release a region in units space
* that is no longer needed. */ * that is no longer needed. */
void (*release_addr) (u64 addr, void *private); void (*release_addr) (u64 addr, void *private);
/* This function is used by csr1212 to determine the max read request
* supported by a remote node when reading the ConfigROM space. Must
* return 0, 1, or 2 per IEEE 1212. */
int (*get_max_rom) (u32 *bus_info, void *private);
}; };
......
...@@ -77,11 +77,11 @@ static inline void fill_cip_header(struct CIP_header *cip, ...@@ -77,11 +77,11 @@ static inline void fill_cip_header(struct CIP_header *cip,
See the Texas Instruments OHCI 1394 chipset documentation. See the Texas Instruments OHCI 1394 chipset documentation.
*/ */
struct output_more_immediate { u32 q[8]; }; struct output_more_immediate { __le32 q[8]; };
struct output_more { u32 q[4]; }; struct output_more { __le32 q[4]; };
struct output_last { u32 q[4]; }; struct output_last { __le32 q[4]; };
struct input_more { u32 q[4]; }; struct input_more { __le32 q[4]; };
struct input_last { u32 q[4]; }; struct input_last { __le32 q[4]; };
/* outputs */ /* outputs */
...@@ -92,9 +92,9 @@ static inline void fill_output_more_immediate(struct output_more_immediate *omi, ...@@ -92,9 +92,9 @@ static inline void fill_output_more_immediate(struct output_more_immediate *omi,
unsigned int payload_size) unsigned int payload_size)
{ {
omi->q[0] = cpu_to_le32(0x02000000 | 8); /* OUTPUT_MORE_IMMEDIATE; 8 is the size of the IT header */ omi->q[0] = cpu_to_le32(0x02000000 | 8); /* OUTPUT_MORE_IMMEDIATE; 8 is the size of the IT header */
omi->q[1] = 0; omi->q[1] = cpu_to_le32(0);
omi->q[2] = 0; omi->q[2] = cpu_to_le32(0);
omi->q[3] = 0; omi->q[3] = cpu_to_le32(0);
/* IT packet header */ /* IT packet header */
omi->q[4] = cpu_to_le32( (0x0 << 16) /* IEEE1394_SPEED_100 */ omi->q[4] = cpu_to_le32( (0x0 << 16) /* IEEE1394_SPEED_100 */
...@@ -106,8 +106,8 @@ static inline void fill_output_more_immediate(struct output_more_immediate *omi, ...@@ -106,8 +106,8 @@ static inline void fill_output_more_immediate(struct output_more_immediate *omi,
/* reserved field; mimic behavior of my Sony DSR-40 */ /* reserved field; mimic behavior of my Sony DSR-40 */
omi->q[5] = cpu_to_le32((payload_size << 16) | (0x7F << 8) | 0xA0); omi->q[5] = cpu_to_le32((payload_size << 16) | (0x7F << 8) | 0xA0);
omi->q[6] = 0; omi->q[6] = cpu_to_le32(0);
omi->q[7] = 0; omi->q[7] = cpu_to_le32(0);
} }
static inline void fill_output_more(struct output_more *om, static inline void fill_output_more(struct output_more *om,
...@@ -116,8 +116,8 @@ static inline void fill_output_more(struct output_more *om, ...@@ -116,8 +116,8 @@ static inline void fill_output_more(struct output_more *om,
{ {
om->q[0] = cpu_to_le32(data_size); om->q[0] = cpu_to_le32(data_size);
om->q[1] = cpu_to_le32(data_phys_addr); om->q[1] = cpu_to_le32(data_phys_addr);
om->q[2] = 0; om->q[2] = cpu_to_le32(0);
om->q[3] = 0; om->q[3] = cpu_to_le32(0);
} }
static inline void fill_output_last(struct output_last *ol, static inline void fill_output_last(struct output_last *ol,
...@@ -140,8 +140,8 @@ static inline void fill_output_last(struct output_last *ol, ...@@ -140,8 +140,8 @@ static inline void fill_output_last(struct output_last *ol,
ol->q[0] = cpu_to_le32(temp); ol->q[0] = cpu_to_le32(temp);
ol->q[1] = cpu_to_le32(data_phys_addr); ol->q[1] = cpu_to_le32(data_phys_addr);
ol->q[2] = 0; ol->q[2] = cpu_to_le32(0);
ol->q[3] = 0; ol->q[3] = cpu_to_le32(0);
} }
/* inputs */ /* inputs */
...@@ -161,8 +161,8 @@ static inline void fill_input_more(struct input_more *im, ...@@ -161,8 +161,8 @@ static inline void fill_input_more(struct input_more *im,
im->q[0] = cpu_to_le32(temp); im->q[0] = cpu_to_le32(temp);
im->q[1] = cpu_to_le32(data_phys_addr); im->q[1] = cpu_to_le32(data_phys_addr);
im->q[2] = 0; /* branchAddress and Z not use in packet-per-buffer mode */ im->q[2] = cpu_to_le32(0); /* branchAddress and Z not use in packet-per-buffer mode */
im->q[3] = 0; /* xferStatus & resCount, resCount must be initialize to data_size */ im->q[3] = cpu_to_le32(0); /* xferStatus & resCount, resCount must be initialize to data_size */
} }
static inline void fill_input_last(struct input_last *il, static inline void fill_input_last(struct input_last *il,
...@@ -331,7 +331,7 @@ struct frame { ...@@ -331,7 +331,7 @@ struct frame {
/* points to status/timestamp field of first DMA packet */ /* points to status/timestamp field of first DMA packet */
/* (we'll check it later to monitor timestamp accuracy) */ /* (we'll check it later to monitor timestamp accuracy) */
u32 *frame_begin_timestamp; __le32 *frame_begin_timestamp;
/* the timestamp we assigned to the first packet in the frame */ /* the timestamp we assigned to the first packet in the frame */
u32 assigned_timestamp; u32 assigned_timestamp;
...@@ -348,15 +348,15 @@ struct frame { ...@@ -348,15 +348,15 @@ struct frame {
that can cause interrupts. We'll check these from the that can cause interrupts. We'll check these from the
interrupt handler. interrupt handler.
*/ */
u32 *mid_frame_timestamp; __le32 *mid_frame_timestamp;
u32 *frame_end_timestamp; __le32 *frame_end_timestamp;
/* branch address field of final packet. This is effectively /* branch address field of final packet. This is effectively
the "tail" in the chain of DMA descriptor blocks. the "tail" in the chain of DMA descriptor blocks.
We will fill it with the address of the first DMA descriptor We will fill it with the address of the first DMA descriptor
block in the subsequent frame, once it is ready. block in the subsequent frame, once it is ready.
*/ */
u32 *frame_end_branch; __le32 *frame_end_branch;
/* the number of descriptors in the first descriptor block /* the number of descriptors in the first descriptor block
of the frame. Needed to start DMA */ of the frame. Needed to start DMA */
...@@ -365,10 +365,10 @@ struct frame { ...@@ -365,10 +365,10 @@ struct frame {
struct packet { struct packet {
u16 timestamp; __le16 timestamp;
u16 invalid; u16 invalid;
u16 iso_header; u16 iso_header;
u16 data_length; __le16 data_length;
u32 cip_h1; u32 cip_h1;
u32 cip_h2; u32 cip_h2;
unsigned char data[480]; unsigned char data[480];
......
...@@ -265,7 +265,7 @@ static void frame_prepare(struct video_card *video, unsigned int this_frame) ...@@ -265,7 +265,7 @@ static void frame_prepare(struct video_card *video, unsigned int this_frame)
/* these flags denote packets that need special attention */ /* these flags denote packets that need special attention */
int empty_packet, first_packet, last_packet, mid_packet; int empty_packet, first_packet, last_packet, mid_packet;
u32 *branch_address, *last_branch_address = NULL; __le32 *branch_address, *last_branch_address = NULL;
unsigned long data_p; unsigned long data_p;
int first_packet_empty = 0; int first_packet_empty = 0;
u32 cycleTimer, ct_sec, ct_cyc, ct_off; u32 cycleTimer, ct_sec, ct_cyc, ct_off;
...@@ -848,7 +848,7 @@ static void receive_packets(struct video_card *video) ...@@ -848,7 +848,7 @@ static void receive_packets(struct video_card *video)
dma_addr_t block_dma = 0; dma_addr_t block_dma = 0;
struct packet *data = NULL; struct packet *data = NULL;
dma_addr_t data_dma = 0; dma_addr_t data_dma = 0;
u32 *last_branch_address = NULL; __le32 *last_branch_address = NULL;
unsigned long irq_flags; unsigned long irq_flags;
int want_interrupt = 0; int want_interrupt = 0;
struct frame *f = NULL; struct frame *f = NULL;
...@@ -2110,17 +2110,17 @@ static void ir_tasklet_func(unsigned long data) ...@@ -2110,17 +2110,17 @@ static void ir_tasklet_func(unsigned long data)
f = video->frames[next_i / MAX_PACKETS]; f = video->frames[next_i / MAX_PACKETS];
next = &(f->descriptor_pool[next_i % MAX_PACKETS]); next = &(f->descriptor_pool[next_i % MAX_PACKETS]);
next_dma = ((unsigned long) block - (unsigned long) f->descriptor_pool) + f->descriptor_pool_dma; next_dma = ((unsigned long) block - (unsigned long) f->descriptor_pool) + f->descriptor_pool_dma;
next->u.in.il.q[0] |= 3 << 20; /* enable interrupt */ next->u.in.il.q[0] |= cpu_to_le32(3 << 20); /* enable interrupt */
next->u.in.il.q[2] = 0; /* disable branch */ next->u.in.il.q[2] = cpu_to_le32(0); /* disable branch */
/* link previous to next */ /* link previous to next */
prev_i = (next_i == 0) ? (MAX_PACKETS * video->n_frames - 1) : (next_i - 1); prev_i = (next_i == 0) ? (MAX_PACKETS * video->n_frames - 1) : (next_i - 1);
f = video->frames[prev_i / MAX_PACKETS]; f = video->frames[prev_i / MAX_PACKETS];
prev = &(f->descriptor_pool[prev_i % MAX_PACKETS]); prev = &(f->descriptor_pool[prev_i % MAX_PACKETS]);
if (prev_i % (MAX_PACKETS/2)) { if (prev_i % (MAX_PACKETS/2)) {
prev->u.in.il.q[0] &= ~(3 << 20); /* no interrupt */ prev->u.in.il.q[0] &= ~cpu_to_le32(3 << 20); /* no interrupt */
} else { } else {
prev->u.in.il.q[0] |= 3 << 20; /* enable interrupt */ prev->u.in.il.q[0] |= cpu_to_le32(3 << 20); /* enable interrupt */
} }
prev->u.in.il.q[2] = cpu_to_le32(next_dma | 1); /* set Z=1 */ prev->u.in.il.q[2] = cpu_to_le32(next_dma | 1); /* set Z=1 */
wmb(); wmb();
......
...@@ -92,7 +92,7 @@ struct partial_datagram { ...@@ -92,7 +92,7 @@ struct partial_datagram {
struct list_head list; struct list_head list;
u16 dgl; u16 dgl;
u16 dg_size; u16 dg_size;
u16 ether_type; __be16 ether_type;
struct sk_buff *skb; struct sk_buff *skb;
char *pbuf; char *pbuf;
struct list_head frag_info; struct list_head frag_info;
...@@ -181,7 +181,7 @@ static void ether1394_remove_host(struct hpsb_host *host); ...@@ -181,7 +181,7 @@ static void ether1394_remove_host(struct hpsb_host *host);
static void ether1394_host_reset(struct hpsb_host *host); static void ether1394_host_reset(struct hpsb_host *host);
/* Function for incoming 1394 packets */ /* Function for incoming 1394 packets */
static struct hpsb_address_ops addr_ops = { const static struct hpsb_address_ops addr_ops = {
.write = ether1394_write, .write = ether1394_write,
}; };
...@@ -767,7 +767,7 @@ static int ether1394_header_parse(const struct sk_buff *skb, ...@@ -767,7 +767,7 @@ static int ether1394_header_parse(const struct sk_buff *skb,
static int ether1394_header_cache(const struct neighbour *neigh, static int ether1394_header_cache(const struct neighbour *neigh,
struct hh_cache *hh) struct hh_cache *hh)
{ {
unsigned short type = hh->hh_type; __be16 type = hh->hh_type;
struct net_device *dev = neigh->dev; struct net_device *dev = neigh->dev;
struct eth1394hdr *eth = struct eth1394hdr *eth =
(struct eth1394hdr *)((u8 *)hh->hh_data + 16 - ETH1394_HLEN); (struct eth1394hdr *)((u8 *)hh->hh_data + 16 - ETH1394_HLEN);
...@@ -795,7 +795,7 @@ static void ether1394_header_cache_update(struct hh_cache *hh, ...@@ -795,7 +795,7 @@ static void ether1394_header_cache_update(struct hh_cache *hh,
******************************************/ ******************************************/
/* Copied from net/ethernet/eth.c */ /* Copied from net/ethernet/eth.c */
static u16 ether1394_type_trans(struct sk_buff *skb, struct net_device *dev) static __be16 ether1394_type_trans(struct sk_buff *skb, struct net_device *dev)
{ {
struct eth1394hdr *eth; struct eth1394hdr *eth;
unsigned char *rawp; unsigned char *rawp;
...@@ -829,17 +829,17 @@ static u16 ether1394_type_trans(struct sk_buff *skb, struct net_device *dev) ...@@ -829,17 +829,17 @@ static u16 ether1394_type_trans(struct sk_buff *skb, struct net_device *dev)
/* Parse an encapsulated IP1394 header into an ethernet frame packet. /* Parse an encapsulated IP1394 header into an ethernet frame packet.
* We also perform ARP translation here, if need be. */ * We also perform ARP translation here, if need be. */
static u16 ether1394_parse_encap(struct sk_buff *skb, struct net_device *dev, static __be16 ether1394_parse_encap(struct sk_buff *skb, struct net_device *dev,
nodeid_t srcid, nodeid_t destid, nodeid_t srcid, nodeid_t destid,
u16 ether_type) __be16 ether_type)
{ {
struct eth1394_priv *priv = netdev_priv(dev); struct eth1394_priv *priv = netdev_priv(dev);
u64 dest_hw; __be64 dest_hw;
unsigned short ret = 0; __be16 ret = 0;
/* Setup our hw addresses. We use these to build the ethernet header. */ /* Setup our hw addresses. We use these to build the ethernet header. */
if (destid == (LOCAL_BUS | ALL_NODES)) if (destid == (LOCAL_BUS | ALL_NODES))
dest_hw = ~0ULL; /* broadcast */ dest_hw = ~cpu_to_be64(0); /* broadcast */
else else
dest_hw = cpu_to_be64((u64)priv->host->csr.guid_hi << 32 | dest_hw = cpu_to_be64((u64)priv->host->csr.guid_hi << 32 |
priv->host->csr.guid_lo); priv->host->csr.guid_lo);
...@@ -873,7 +873,7 @@ static u16 ether1394_parse_encap(struct sk_buff *skb, struct net_device *dev, ...@@ -873,7 +873,7 @@ static u16 ether1394_parse_encap(struct sk_buff *skb, struct net_device *dev,
node = eth1394_find_node_guid(&priv->ip_node_list, node = eth1394_find_node_guid(&priv->ip_node_list,
be64_to_cpu(guid)); be64_to_cpu(guid));
if (!node) if (!node)
return 0; return cpu_to_be16(0);
node_info = node_info =
(struct eth1394_node_info *)node->ud->device.driver_data; (struct eth1394_node_info *)node->ud->device.driver_data;
...@@ -1063,7 +1063,7 @@ static int ether1394_data_handler(struct net_device *dev, int srcid, int destid, ...@@ -1063,7 +1063,7 @@ static int ether1394_data_handler(struct net_device *dev, int srcid, int destid,
unsigned long flags; unsigned long flags;
struct eth1394_priv *priv = netdev_priv(dev); struct eth1394_priv *priv = netdev_priv(dev);
union eth1394_hdr *hdr = (union eth1394_hdr *)buf; union eth1394_hdr *hdr = (union eth1394_hdr *)buf;
u16 ether_type = 0; /* initialized to clear warning */ __be16 ether_type = cpu_to_be16(0); /* initialized to clear warning */
int hdr_len; int hdr_len;
struct unit_directory *ud = priv->ud_list[NODEID_TO_NODE(srcid)]; struct unit_directory *ud = priv->ud_list[NODEID_TO_NODE(srcid)];
struct eth1394_node_info *node_info; struct eth1394_node_info *node_info;
...@@ -1259,7 +1259,7 @@ static int ether1394_write(struct hpsb_host *host, int srcid, int destid, ...@@ -1259,7 +1259,7 @@ static int ether1394_write(struct hpsb_host *host, int srcid, int destid,
static void ether1394_iso(struct hpsb_iso *iso) static void ether1394_iso(struct hpsb_iso *iso)
{ {
quadlet_t *data; __be32 *data;
char *buf; char *buf;
struct eth1394_host_info *hi; struct eth1394_host_info *hi;
struct net_device *dev; struct net_device *dev;
...@@ -1283,7 +1283,7 @@ static void ether1394_iso(struct hpsb_iso *iso) ...@@ -1283,7 +1283,7 @@ static void ether1394_iso(struct hpsb_iso *iso)
for (i = 0; i < nready; i++) { for (i = 0; i < nready; i++) {
struct hpsb_iso_packet_info *info = struct hpsb_iso_packet_info *info =
&iso->infos[(iso->first_packet + i) % iso->buf_packets]; &iso->infos[(iso->first_packet + i) % iso->buf_packets];
data = (quadlet_t *)(iso->data_buf.kvirt + info->offset); data = (__be32 *)(iso->data_buf.kvirt + info->offset);
/* skip over GASP header */ /* skip over GASP header */
buf = (char *)data + 8; buf = (char *)data + 8;
...@@ -1614,7 +1614,7 @@ static int ether1394_tx(struct sk_buff *skb, struct net_device *dev) ...@@ -1614,7 +1614,7 @@ static int ether1394_tx(struct sk_buff *skb, struct net_device *dev)
if (max_payload < dg_size + hdr_type_len[ETH1394_HDR_LF_UF]) if (max_payload < dg_size + hdr_type_len[ETH1394_HDR_LF_UF])
priv->bc_dgl++; priv->bc_dgl++;
} else { } else {
__be64 guid = get_unaligned((u64 *)hdr_buf.h_dest); __be64 guid = get_unaligned((__be64 *)hdr_buf.h_dest);
node = eth1394_find_node_guid(&priv->ip_node_list, node = eth1394_find_node_guid(&priv->ip_node_list,
be64_to_cpu(guid)); be64_to_cpu(guid));
......
...@@ -82,7 +82,7 @@ struct eth1394_priv { ...@@ -82,7 +82,7 @@ struct eth1394_priv {
struct eth1394hdr { struct eth1394hdr {
unsigned char h_dest[ETH1394_ALEN]; /* destination eth1394 addr */ unsigned char h_dest[ETH1394_ALEN]; /* destination eth1394 addr */
unsigned short h_proto; /* packet type ID field */ __be16 h_proto; /* packet type ID field */
} __attribute__((packed)); } __attribute__((packed));
static inline struct eth1394hdr *eth1394_hdr(const struct sk_buff *skb) static inline struct eth1394hdr *eth1394_hdr(const struct sk_buff *skb)
...@@ -99,13 +99,13 @@ typedef enum {ETH1394_GASP, ETH1394_WRREQ} eth1394_tx_type; ...@@ -99,13 +99,13 @@ typedef enum {ETH1394_GASP, ETH1394_WRREQ} eth1394_tx_type;
struct eth1394_uf_hdr { struct eth1394_uf_hdr {
u16 lf:2; u16 lf:2;
u16 res:14; u16 res:14;
u16 ether_type; /* Ethernet packet type */ __be16 ether_type; /* Ethernet packet type */
} __attribute__((packed)); } __attribute__((packed));
#elif defined __LITTLE_ENDIAN_BITFIELD #elif defined __LITTLE_ENDIAN_BITFIELD
struct eth1394_uf_hdr { struct eth1394_uf_hdr {
u16 res:14; u16 res:14;
u16 lf:2; u16 lf:2;
u16 ether_type; __be16 ether_type;
} __attribute__((packed)); } __attribute__((packed));
#else #else
#error Unknown bit field type #error Unknown bit field type
...@@ -117,7 +117,7 @@ struct eth1394_ff_hdr { ...@@ -117,7 +117,7 @@ struct eth1394_ff_hdr {
u16 lf:2; u16 lf:2;
u16 res1:2; u16 res1:2;
u16 dg_size:12; /* Datagram size */ u16 dg_size:12; /* Datagram size */
u16 ether_type; /* Ethernet packet type */ __be16 ether_type; /* Ethernet packet type */
u16 dgl; /* Datagram label */ u16 dgl; /* Datagram label */
u16 res2; u16 res2;
} __attribute__((packed)); } __attribute__((packed));
...@@ -126,7 +126,7 @@ struct eth1394_ff_hdr { ...@@ -126,7 +126,7 @@ struct eth1394_ff_hdr {
u16 dg_size:12; u16 dg_size:12;
u16 res1:2; u16 res1:2;
u16 lf:2; u16 lf:2;
u16 ether_type; __be16 ether_type;
u16 dgl; u16 dgl;
u16 res2; u16 res2;
} __attribute__((packed)); } __attribute__((packed));
...@@ -207,11 +207,11 @@ struct eth1394_arp { ...@@ -207,11 +207,11 @@ struct eth1394_arp {
u16 opcode; /* ARP Opcode */ u16 opcode; /* ARP Opcode */
/* Above is exactly the same format as struct arphdr */ /* Above is exactly the same format as struct arphdr */
u64 s_uniq_id; /* Sender's 64bit EUI */ __be64 s_uniq_id; /* Sender's 64bit EUI */
u8 max_rec; /* Sender's max packet size */ u8 max_rec; /* Sender's max packet size */
u8 sspd; /* Sender's max speed */ u8 sspd; /* Sender's max speed */
u16 fifo_hi; /* hi 16bits of sender's FIFO addr */ __be16 fifo_hi; /* hi 16bits of sender's FIFO addr */
u32 fifo_lo; /* lo 32bits of sender's FIFO addr */ __be32 fifo_lo; /* lo 32bits of sender's FIFO addr */
u32 sip; /* Sender's IP Address */ u32 sip; /* Sender's IP Address */
u32 tip; /* IP Address of requested hw addr */ u32 tip; /* IP Address of requested hw addr */
}; };
......
...@@ -320,7 +320,7 @@ void hpsb_unregister_highlevel(struct hpsb_highlevel *hl) ...@@ -320,7 +320,7 @@ void hpsb_unregister_highlevel(struct hpsb_highlevel *hl)
*/ */
u64 hpsb_allocate_and_register_addrspace(struct hpsb_highlevel *hl, u64 hpsb_allocate_and_register_addrspace(struct hpsb_highlevel *hl,
struct hpsb_host *host, struct hpsb_host *host,
struct hpsb_address_ops *ops, const struct hpsb_address_ops *ops,
u64 size, u64 alignment, u64 size, u64 alignment,
u64 start, u64 end) u64 start, u64 end)
{ {
...@@ -407,7 +407,8 @@ u64 hpsb_allocate_and_register_addrspace(struct hpsb_highlevel *hl, ...@@ -407,7 +407,8 @@ u64 hpsb_allocate_and_register_addrspace(struct hpsb_highlevel *hl,
* are automatically deallocated together with the hpsb_highlevel @hl. * are automatically deallocated together with the hpsb_highlevel @hl.
*/ */
int hpsb_register_addrspace(struct hpsb_highlevel *hl, struct hpsb_host *host, int hpsb_register_addrspace(struct hpsb_highlevel *hl, struct hpsb_host *host,
struct hpsb_address_ops *ops, u64 start, u64 end) const struct hpsb_address_ops *ops,
u64 start, u64 end)
{ {
struct hpsb_address_serve *as; struct hpsb_address_serve *as;
struct list_head *lh; struct list_head *lh;
...@@ -420,7 +421,7 @@ int hpsb_register_addrspace(struct hpsb_highlevel *hl, struct hpsb_host *host, ...@@ -420,7 +421,7 @@ int hpsb_register_addrspace(struct hpsb_highlevel *hl, struct hpsb_host *host,
return 0; return 0;
} }
as = kmalloc(sizeof(*as), GFP_ATOMIC); as = kmalloc(sizeof(*as), GFP_KERNEL);
if (!as) if (!as)
return 0; return 0;
...@@ -477,7 +478,7 @@ int hpsb_unregister_addrspace(struct hpsb_highlevel *hl, struct hpsb_host *host, ...@@ -477,7 +478,7 @@ int hpsb_unregister_addrspace(struct hpsb_highlevel *hl, struct hpsb_host *host,
return retval; return retval;
} }
static struct hpsb_address_ops dummy_ops; const static struct hpsb_address_ops dummy_ops;
/* dummy address spaces as lower and upper bounds of the host's a.s. list */ /* dummy address spaces as lower and upper bounds of the host's a.s. list */
static void init_hpsb_highlevel(struct hpsb_host *host) static void init_hpsb_highlevel(struct hpsb_host *host)
......
...@@ -15,7 +15,7 @@ struct hpsb_host; ...@@ -15,7 +15,7 @@ struct hpsb_host;
struct hpsb_address_serve { struct hpsb_address_serve {
struct list_head host_list; /* per host list */ struct list_head host_list; /* per host list */
struct list_head hl_list; /* hpsb_highlevel list */ struct list_head hl_list; /* hpsb_highlevel list */
struct hpsb_address_ops *op; const struct hpsb_address_ops *op;
struct hpsb_host *host; struct hpsb_host *host;
u64 start; /* first address handled, quadlet aligned */ u64 start; /* first address handled, quadlet aligned */
u64 end; /* first address behind, quadlet aligned */ u64 end; /* first address behind, quadlet aligned */
...@@ -119,11 +119,12 @@ void hpsb_unregister_highlevel(struct hpsb_highlevel *hl); ...@@ -119,11 +119,12 @@ void hpsb_unregister_highlevel(struct hpsb_highlevel *hl);
u64 hpsb_allocate_and_register_addrspace(struct hpsb_highlevel *hl, u64 hpsb_allocate_and_register_addrspace(struct hpsb_highlevel *hl,
struct hpsb_host *host, struct hpsb_host *host,
struct hpsb_address_ops *ops, const struct hpsb_address_ops *ops,
u64 size, u64 alignment, u64 size, u64 alignment,
u64 start, u64 end); u64 start, u64 end);
int hpsb_register_addrspace(struct hpsb_highlevel *hl, struct hpsb_host *host, int hpsb_register_addrspace(struct hpsb_highlevel *hl, struct hpsb_host *host,
struct hpsb_address_ops *ops, u64 start, u64 end); const struct hpsb_address_ops *ops,
u64 start, u64 end);
int hpsb_unregister_addrspace(struct hpsb_highlevel *hl, struct hpsb_host *host, int hpsb_unregister_addrspace(struct hpsb_highlevel *hl, struct hpsb_host *host,
u64 start); u64 start);
......
...@@ -34,18 +34,18 @@ static void delayed_reset_bus(struct work_struct *work) ...@@ -34,18 +34,18 @@ static void delayed_reset_bus(struct work_struct *work)
{ {
struct hpsb_host *host = struct hpsb_host *host =
container_of(work, struct hpsb_host, delayed_reset.work); container_of(work, struct hpsb_host, delayed_reset.work);
int generation = host->csr.generation + 1; u8 generation = host->csr.generation + 1;
/* The generation field rolls over to 2 rather than 0 per IEEE /* The generation field rolls over to 2 rather than 0 per IEEE
* 1394a-2000. */ * 1394a-2000. */
if (generation > 0xf || generation < 2) if (generation > 0xf || generation < 2)
generation = 2; generation = 2;
CSR_SET_BUS_INFO_GENERATION(host->csr.rom, generation); csr_set_bus_info_generation(host->csr.rom, generation);
if (csr1212_generate_csr_image(host->csr.rom) != CSR1212_SUCCESS) { if (csr1212_generate_csr_image(host->csr.rom) != CSR1212_SUCCESS) {
/* CSR image creation failed. /* CSR image creation failed.
* Reset generation field and do not issue a bus reset. */ * Reset generation field and do not issue a bus reset. */
CSR_SET_BUS_INFO_GENERATION(host->csr.rom, csr_set_bus_info_generation(host->csr.rom,
host->csr.generation); host->csr.generation);
return; return;
} }
......
...@@ -154,7 +154,7 @@ struct hpsb_host_driver { ...@@ -154,7 +154,7 @@ struct hpsb_host_driver {
* to set the hardware ConfigROM if the hardware supports handling * to set the hardware ConfigROM if the hardware supports handling
* reads to the ConfigROM on its own. */ * reads to the ConfigROM on its own. */
void (*set_hw_config_rom)(struct hpsb_host *host, void (*set_hw_config_rom)(struct hpsb_host *host,
quadlet_t *config_rom); __be32 *config_rom);
/* This function shall implement packet transmission based on /* This function shall implement packet transmission based on
* packet->type. It shall CRC both parts of the packet (unless * packet->type. It shall CRC both parts of the packet (unless
......
...@@ -121,6 +121,9 @@ extern const char *hpsb_speedto_str[]; ...@@ -121,6 +121,9 @@ extern const char *hpsb_speedto_str[];
#include <asm/byteorder.h> #include <asm/byteorder.h>
/* '1' '3' '9' '4' in ASCII */
#define IEEE1394_BUSID_MAGIC cpu_to_be32(0x31333934)
#ifdef __BIG_ENDIAN_BITFIELD #ifdef __BIG_ENDIAN_BITFIELD
struct selfid { struct selfid {
......
...@@ -67,7 +67,7 @@ static int nodemgr_check_speed(struct nodemgr_csr_info *ci, u64 addr, ...@@ -67,7 +67,7 @@ static int nodemgr_check_speed(struct nodemgr_csr_info *ci, u64 addr,
for (i = IEEE1394_SPEED_100; i <= old_speed; i++) { for (i = IEEE1394_SPEED_100; i <= old_speed; i++) {
*speed = i; *speed = i;
error = hpsb_read(ci->host, ci->nodeid, ci->generation, addr, error = hpsb_read(ci->host, ci->nodeid, ci->generation, addr,
&q, sizeof(quadlet_t)); &q, 4);
if (error) if (error)
break; break;
*buffer = q; *buffer = q;
...@@ -85,7 +85,7 @@ static int nodemgr_check_speed(struct nodemgr_csr_info *ci, u64 addr, ...@@ -85,7 +85,7 @@ static int nodemgr_check_speed(struct nodemgr_csr_info *ci, u64 addr,
return error; return error;
} }
static int nodemgr_bus_read(struct csr1212_csr *csr, u64 addr, u16 length, static int nodemgr_bus_read(struct csr1212_csr *csr, u64 addr,
void *buffer, void *__ci) void *buffer, void *__ci)
{ {
struct nodemgr_csr_info *ci = (struct nodemgr_csr_info*)__ci; struct nodemgr_csr_info *ci = (struct nodemgr_csr_info*)__ci;
...@@ -93,7 +93,7 @@ static int nodemgr_bus_read(struct csr1212_csr *csr, u64 addr, u16 length, ...@@ -93,7 +93,7 @@ static int nodemgr_bus_read(struct csr1212_csr *csr, u64 addr, u16 length,
for (i = 1; ; i++) { for (i = 1; ; i++) {
error = hpsb_read(ci->host, ci->nodeid, ci->generation, addr, error = hpsb_read(ci->host, ci->nodeid, ci->generation, addr,
buffer, length); buffer, 4);
if (!error) { if (!error) {
ci->speed_unverified = 0; ci->speed_unverified = 0;
break; break;
...@@ -104,7 +104,7 @@ static int nodemgr_bus_read(struct csr1212_csr *csr, u64 addr, u16 length, ...@@ -104,7 +104,7 @@ static int nodemgr_bus_read(struct csr1212_csr *csr, u64 addr, u16 length,
/* The ieee1394_core guessed the node's speed capability from /* The ieee1394_core guessed the node's speed capability from
* the self ID. Check whether a lower speed works. */ * the self ID. Check whether a lower speed works. */
if (ci->speed_unverified && length == sizeof(quadlet_t)) { if (ci->speed_unverified) {
error = nodemgr_check_speed(ci, addr, buffer); error = nodemgr_check_speed(ci, addr, buffer);
if (!error) if (!error)
break; break;
...@@ -115,20 +115,8 @@ static int nodemgr_bus_read(struct csr1212_csr *csr, u64 addr, u16 length, ...@@ -115,20 +115,8 @@ static int nodemgr_bus_read(struct csr1212_csr *csr, u64 addr, u16 length,
return error; return error;
} }
#define OUI_FREECOM_TECHNOLOGIES_GMBH 0x0001db
static int nodemgr_get_max_rom(quadlet_t *bus_info_data, void *__ci)
{
/* Freecom FireWire Hard Drive firmware bug */
if (be32_to_cpu(bus_info_data[3]) >> 8 == OUI_FREECOM_TECHNOLOGIES_GMBH)
return 0;
return (be32_to_cpu(bus_info_data[2]) >> 8) & 0x3;
}
static struct csr1212_bus_ops nodemgr_csr_ops = { static struct csr1212_bus_ops nodemgr_csr_ops = {
.bus_read = nodemgr_bus_read, .bus_read = nodemgr_bus_read,
.get_max_rom = nodemgr_get_max_rom
}; };
......
...@@ -31,9 +31,6 @@ struct csr1212_keyval; ...@@ -31,9 +31,6 @@ struct csr1212_keyval;
struct hpsb_host; struct hpsb_host;
struct ieee1394_device_id; struct ieee1394_device_id;
/* '1' '3' '9' '4' in ASCII */
#define IEEE1394_BUSID_MAGIC __constant_cpu_to_be32(0x31333934)
/* This is the start of a Node entry structure. It should be a stable API /* This is the start of a Node entry structure. It should be a stable API
* for which to gather info from the Node Manager about devices attached * for which to gather info from the Node Manager about devices attached
* to the bus. */ * to the bus. */
......
...@@ -2973,7 +2973,7 @@ alloc_dma_trm_ctx(struct ti_ohci *ohci, struct dma_trm_ctx *d, ...@@ -2973,7 +2973,7 @@ alloc_dma_trm_ctx(struct ti_ohci *ohci, struct dma_trm_ctx *d,
return 0; return 0;
} }
static void ohci_set_hw_config_rom(struct hpsb_host *host, quadlet_t *config_rom) static void ohci_set_hw_config_rom(struct hpsb_host *host, __be32 *config_rom)
{ {
struct ti_ohci *ohci = host->hostdata; struct ti_ohci *ohci = host->hostdata;
...@@ -3199,15 +3199,16 @@ static int __devinit ohci1394_pci_probe(struct pci_dev *dev, ...@@ -3199,15 +3199,16 @@ static int __devinit ohci1394_pci_probe(struct pci_dev *dev,
/* Now enable LPS, which we need in order to start accessing /* Now enable LPS, which we need in order to start accessing
* most of the registers. In fact, on some cards (ALI M5251), * most of the registers. In fact, on some cards (ALI M5251),
* accessing registers in the SClk domain without LPS enabled * accessing registers in the SClk domain without LPS enabled
* will lock up the machine. Wait 50msec to make sure we have * will lock up the machine. */
* full link enabled. */
reg_write(ohci, OHCI1394_HCControlSet, OHCI1394_HCControl_LPS); reg_write(ohci, OHCI1394_HCControlSet, OHCI1394_HCControl_LPS);
/* Disable and clear interrupts */ /* Disable and clear interrupts */
reg_write(ohci, OHCI1394_IntEventClear, 0xffffffff); reg_write(ohci, OHCI1394_IntEventClear, 0xffffffff);
reg_write(ohci, OHCI1394_IntMaskClear, 0xffffffff); reg_write(ohci, OHCI1394_IntMaskClear, 0xffffffff);
mdelay(50); /* Flush MMIO writes and wait to make sure we have full link enabled. */
reg_read(ohci, OHCI1394_Version);
msleep(50);
/* Determine the number of available IR and IT contexts. */ /* Determine the number of available IR and IT contexts. */
ohci->nb_iso_rcv_ctx = ohci->nb_iso_rcv_ctx =
...@@ -3233,8 +3234,9 @@ static int __devinit ohci1394_pci_probe(struct pci_dev *dev, ...@@ -3233,8 +3234,9 @@ static int __devinit ohci1394_pci_probe(struct pci_dev *dev,
* we need to get to that "no event", so enough should be initialized * we need to get to that "no event", so enough should be initialized
* by that point. * by that point.
*/ */
if (request_irq(dev->irq, ohci_irq_handler, IRQF_SHARED, err = request_irq(dev->irq, ohci_irq_handler, IRQF_SHARED,
OHCI1394_DRIVER_NAME, ohci)) { OHCI1394_DRIVER_NAME, ohci);
if (err) {
PRINT_G(KERN_ERR, "Failed to allocate interrupt %d", dev->irq); PRINT_G(KERN_ERR, "Failed to allocate interrupt %d", dev->irq);
goto err; goto err;
} }
...@@ -3381,6 +3383,7 @@ static int ohci1394_pci_suspend(struct pci_dev *dev, pm_message_t state) ...@@ -3381,6 +3383,7 @@ static int ohci1394_pci_suspend(struct pci_dev *dev, pm_message_t state)
ohci_devctl(ohci->host, RESET_BUS, LONG_RESET_NO_FORCE_ROOT); ohci_devctl(ohci->host, RESET_BUS, LONG_RESET_NO_FORCE_ROOT);
ohci_soft_reset(ohci); ohci_soft_reset(ohci);
free_irq(dev->irq, ohci);
err = pci_save_state(dev); err = pci_save_state(dev);
if (err) { if (err) {
PRINT(KERN_ERR, "pci_save_state failed with %d", err); PRINT(KERN_ERR, "pci_save_state failed with %d", err);
...@@ -3420,7 +3423,16 @@ static int ohci1394_pci_resume(struct pci_dev *dev) ...@@ -3420,7 +3423,16 @@ static int ohci1394_pci_resume(struct pci_dev *dev)
reg_write(ohci, OHCI1394_HCControlSet, OHCI1394_HCControl_LPS); reg_write(ohci, OHCI1394_HCControlSet, OHCI1394_HCControl_LPS);
reg_write(ohci, OHCI1394_IntEventClear, 0xffffffff); reg_write(ohci, OHCI1394_IntEventClear, 0xffffffff);
reg_write(ohci, OHCI1394_IntMaskClear, 0xffffffff); reg_write(ohci, OHCI1394_IntMaskClear, 0xffffffff);
mdelay(50); reg_read(ohci, OHCI1394_Version);
msleep(50);
err = request_irq(dev->irq, ohci_irq_handler, IRQF_SHARED,
OHCI1394_DRIVER_NAME, ohci);
if (err) {
PRINT_G(KERN_ERR, "Failed to allocate interrupt %d", dev->irq);
return err;
}
ohci_initialize(ohci); ohci_initialize(ohci);
hpsb_resume_host(ohci->host); hpsb_resume_host(ohci->host);
......
...@@ -1463,7 +1463,7 @@ static int __devinit add_card(struct pci_dev *dev, ...@@ -1463,7 +1463,7 @@ static int __devinit add_card(struct pci_dev *dev,
/* info_length, crc_length and 1394 magic number to check, if it is really a bus info block */ /* info_length, crc_length and 1394 magic number to check, if it is really a bus info block */
if (((be32_to_cpu(lynx->bus_info_block[0]) & 0xffff0000) == 0x04040000) && if (((be32_to_cpu(lynx->bus_info_block[0]) & 0xffff0000) == 0x04040000) &&
(lynx->bus_info_block[1] == __constant_cpu_to_be32(0x31333934))) (lynx->bus_info_block[1] == IEEE1394_BUSID_MAGIC))
{ {
PRINT(KERN_DEBUG, lynx->id, "read a valid bus info block from"); PRINT(KERN_DEBUG, lynx->id, "read a valid bus info block from");
} else { } else {
......
...@@ -52,7 +52,7 @@ struct ti_lynx { ...@@ -52,7 +52,7 @@ struct ti_lynx {
void __iomem *local_rom; void __iomem *local_rom;
void __iomem *local_ram; void __iomem *local_ram;
void __iomem *aux_port; void __iomem *aux_port;
quadlet_t bus_info_block[5]; __be32 bus_info_block[5];
/* /*
* use local RAM of LOCALRAM_SIZE bytes for PCLs, which allows for * use local RAM of LOCALRAM_SIZE bytes for PCLs, which allows for
......
...@@ -90,7 +90,7 @@ static int arm_lock(struct hpsb_host *host, int nodeid, quadlet_t * store, ...@@ -90,7 +90,7 @@ static int arm_lock(struct hpsb_host *host, int nodeid, quadlet_t * store,
static int arm_lock64(struct hpsb_host *host, int nodeid, octlet_t * store, static int arm_lock64(struct hpsb_host *host, int nodeid, octlet_t * store,
u64 addr, octlet_t data, octlet_t arg, int ext_tcode, u64 addr, octlet_t data, octlet_t arg, int ext_tcode,
u16 flags); u16 flags);
static struct hpsb_address_ops arm_ops = { const static struct hpsb_address_ops arm_ops = {
.read = arm_read, .read = arm_read,
.write = arm_write, .write = arm_write,
.lock = arm_lock, .lock = arm_lock,
......
...@@ -265,7 +265,7 @@ static struct hpsb_highlevel sbp2_highlevel = { ...@@ -265,7 +265,7 @@ static struct hpsb_highlevel sbp2_highlevel = {
.host_reset = sbp2_host_reset, .host_reset = sbp2_host_reset,
}; };
static struct hpsb_address_ops sbp2_ops = { const static struct hpsb_address_ops sbp2_ops = {
.write = sbp2_handle_status_write .write = sbp2_handle_status_write
}; };
...@@ -275,7 +275,7 @@ static int sbp2_handle_physdma_write(struct hpsb_host *, int, int, quadlet_t *, ...@@ -275,7 +275,7 @@ static int sbp2_handle_physdma_write(struct hpsb_host *, int, int, quadlet_t *,
static int sbp2_handle_physdma_read(struct hpsb_host *, int, quadlet_t *, u64, static int sbp2_handle_physdma_read(struct hpsb_host *, int, quadlet_t *, u64,
size_t, u16); size_t, u16);
static struct hpsb_address_ops sbp2_physdma_ops = { const static struct hpsb_address_ops sbp2_physdma_ops = {
.read = sbp2_handle_physdma_read, .read = sbp2_handle_physdma_read,
.write = sbp2_handle_physdma_write, .write = sbp2_handle_physdma_write,
}; };
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册