Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 243308
b: refs/heads/master
c: 8fac171
h: refs/heads/master
v: v3
  • Loading branch information
Thomas Gleixner committed Mar 29, 2011
1 parent a2be684 commit 263fd12
Show file tree
Hide file tree
Showing 2 changed files with 39 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: 5c217b60fed39ed2ac6a2e8b788df4a74fa68878
refs/heads/master: 8fac171f72efb2e62f34ffeca22820823e60cdb0
70 changes: 38 additions & 32 deletions trunk/arch/ia64/kernel/iosapic.c
Original file line number Diff line number Diff line change
Expand Up @@ -257,7 +257,7 @@ set_rte (unsigned int gsi, unsigned int irq, unsigned int dest, int mask)
}

static void
nop (unsigned int irq)
nop (struct irq_data *data)
{
/* do nothing... */
}
Expand Down Expand Up @@ -287,8 +287,9 @@ kexec_disable_iosapic(void)
#endif

static void
mask_irq (unsigned int irq)
mask_irq (struct irq_data *data)
{
unsigned int irq = data->irq;
u32 low32;
int rte_index;
struct iosapic_rte_info *rte;
Expand All @@ -305,8 +306,9 @@ mask_irq (unsigned int irq)
}

static void
unmask_irq (unsigned int irq)
unmask_irq (struct irq_data *data)
{
unsigned int irq = data->irq;
u32 low32;
int rte_index;
struct iosapic_rte_info *rte;
Expand All @@ -323,9 +325,11 @@ unmask_irq (unsigned int irq)


static int
iosapic_set_affinity(unsigned int irq, const struct cpumask *mask)
iosapic_set_affinity(struct irq_data *data, const struct cpumask *mask,
bool force)
{
#ifdef CONFIG_SMP
unsigned int irq = data->irq;
u32 high32, low32;
int cpu, dest, rte_index;
int redir = (irq & IA64_IRQ_REDIRECTED) ? 1 : 0;
Expand Down Expand Up @@ -379,32 +383,33 @@ iosapic_set_affinity(unsigned int irq, const struct cpumask *mask)
*/

static unsigned int
iosapic_startup_level_irq (unsigned int irq)
iosapic_startup_level_irq (struct irq_data *data)
{
unmask_irq(irq);
unmask_irq(data);
return 0;
}

static void
iosapic_unmask_level_irq (unsigned int irq)
iosapic_unmask_level_irq (struct irq_data *data)
{
unsigned int irq = data->irq;
ia64_vector vec = irq_to_vector(irq);
struct iosapic_rte_info *rte;
int do_unmask_irq = 0;

irq_complete_move(irq);
if (unlikely(irq_desc[irq].status & IRQ_MOVE_PENDING)) {
do_unmask_irq = 1;
mask_irq(irq);
mask_irq(data);
} else
unmask_irq(irq);
unmask_irq(data);

list_for_each_entry(rte, &iosapic_intr_info[irq].rtes, rte_list)
iosapic_eoi(rte->iosapic->addr, vec);

if (unlikely(do_unmask_irq)) {
move_masked_irq(irq);
unmask_irq(irq);
unmask_irq(data);
}
}

Expand All @@ -414,25 +419,25 @@ iosapic_unmask_level_irq (unsigned int irq)
#define iosapic_ack_level_irq nop

static struct irq_chip irq_type_iosapic_level = {
.name = "IO-SAPIC-level",
.startup = iosapic_startup_level_irq,
.shutdown = iosapic_shutdown_level_irq,
.enable = iosapic_enable_level_irq,
.disable = iosapic_disable_level_irq,
.ack = iosapic_ack_level_irq,
.mask = mask_irq,
.unmask = iosapic_unmask_level_irq,
.set_affinity = iosapic_set_affinity
.name = "IO-SAPIC-level",
.irq_startup = iosapic_startup_level_irq,
.irq_shutdown = iosapic_shutdown_level_irq,
.irq_enable = iosapic_enable_level_irq,
.irq_disable = iosapic_disable_level_irq,
.irq_ack = iosapic_ack_level_irq,
.irq_mask = mask_irq,
.irq_unmask = iosapic_unmask_level_irq,
.irq_set_affinity = iosapic_set_affinity
};

/*
* Handlers for edge-triggered interrupts.
*/

static unsigned int
iosapic_startup_edge_irq (unsigned int irq)
iosapic_startup_edge_irq (struct irq_data *data)
{
unmask_irq(irq);
unmask_irq(data);
/*
* IOSAPIC simply drops interrupts pended while the
* corresponding pin was masked, so we can't know if an
Expand All @@ -442,8 +447,9 @@ iosapic_startup_edge_irq (unsigned int irq)
}

static void
iosapic_ack_edge_irq (unsigned int irq)
iosapic_ack_edge_irq (struct irq_data *data)
{
unsigned int irq = data->irq;
struct irq_desc *idesc = irq_desc + irq;

irq_complete_move(irq);
Expand All @@ -455,22 +461,22 @@ iosapic_ack_edge_irq (unsigned int irq)
*/
if ((idesc->status & (IRQ_PENDING|IRQ_DISABLED)) ==
(IRQ_PENDING|IRQ_DISABLED))
mask_irq(irq);
mask_irq(data);
}

#define iosapic_enable_edge_irq unmask_irq
#define iosapic_disable_edge_irq nop

static struct irq_chip irq_type_iosapic_edge = {
.name = "IO-SAPIC-edge",
.startup = iosapic_startup_edge_irq,
.shutdown = iosapic_disable_edge_irq,
.enable = iosapic_enable_edge_irq,
.disable = iosapic_disable_edge_irq,
.ack = iosapic_ack_edge_irq,
.mask = mask_irq,
.unmask = unmask_irq,
.set_affinity = iosapic_set_affinity
.name = "IO-SAPIC-edge",
.irq_startup = iosapic_startup_edge_irq,
.irq_shutdown = iosapic_disable_edge_irq,
.irq_enable = iosapic_enable_edge_irq,
.irq_disable = iosapic_disable_edge_irq,
.irq_ack = iosapic_ack_edge_irq,
.irq_mask = mask_irq,
.irq_unmask = unmask_irq,
.irq_set_affinity = iosapic_set_affinity
};

static unsigned int
Expand Down

0 comments on commit 263fd12

Please sign in to comment.