diff options
| author | Paul Mundt <lethal@linux-sh.org> | 2011-03-31 02:39:47 -0400 |
|---|---|---|
| committer | Paul Mundt <lethal@linux-sh.org> | 2011-03-31 02:39:47 -0400 |
| commit | 7ea5db8efeac8627500e012aa6829ca612c5a700 (patch) | |
| tree | 90e4de22f60b989dcf0f0d7436978c0b463d5827 /arch/powerpc/kernel | |
| parent | eee7631fdf8ae63c4f24daf66981ac1a7b55d7fd (diff) | |
| parent | 6aba74f2791287ec407e0f92487a725a25908067 (diff) | |
Merge branch 'master' of git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6 into sh-latest
Diffstat (limited to 'arch/powerpc/kernel')
| -rw-r--r-- | arch/powerpc/kernel/dma.c | 18 | ||||
| -rw-r--r-- | arch/powerpc/kernel/exceptions-64s.S | 28 | ||||
| -rw-r--r-- | arch/powerpc/kernel/irq.c | 81 | ||||
| -rw-r--r-- | arch/powerpc/kernel/machine_kexec.c | 6 | ||||
| -rw-r--r-- | arch/powerpc/kernel/pci-common.c | 2 | ||||
| -rw-r--r-- | arch/powerpc/kernel/time.c | 2 |
6 files changed, 49 insertions, 88 deletions
diff --git a/arch/powerpc/kernel/dma.c b/arch/powerpc/kernel/dma.c index cf02cad62d9a..d238c082c3c5 100644 --- a/arch/powerpc/kernel/dma.c +++ b/arch/powerpc/kernel/dma.c | |||
| @@ -179,3 +179,21 @@ static int __init dma_init(void) | |||
| 179 | return 0; | 179 | return 0; |
| 180 | } | 180 | } |
| 181 | fs_initcall(dma_init); | 181 | fs_initcall(dma_init); |
| 182 | |||
| 183 | int dma_mmap_coherent(struct device *dev, struct vm_area_struct *vma, | ||
| 184 | void *cpu_addr, dma_addr_t handle, size_t size) | ||
| 185 | { | ||
| 186 | unsigned long pfn; | ||
| 187 | |||
| 188 | #ifdef CONFIG_NOT_COHERENT_CACHE | ||
| 189 | vma->vm_page_prot = pgprot_noncached(vma->vm_page_prot); | ||
| 190 | pfn = __dma_get_coherent_pfn((unsigned long)cpu_addr); | ||
| 191 | #else | ||
| 192 | pfn = page_to_pfn(virt_to_page(cpu_addr)); | ||
| 193 | #endif | ||
| 194 | return remap_pfn_range(vma, vma->vm_start, | ||
| 195 | pfn + vma->vm_pgoff, | ||
| 196 | vma->vm_end - vma->vm_start, | ||
| 197 | vma->vm_page_prot); | ||
| 198 | } | ||
| 199 | EXPORT_SYMBOL_GPL(dma_mmap_coherent); | ||
diff --git a/arch/powerpc/kernel/exceptions-64s.S b/arch/powerpc/kernel/exceptions-64s.S index 8a817995b4cd..c532cb2c927a 100644 --- a/arch/powerpc/kernel/exceptions-64s.S +++ b/arch/powerpc/kernel/exceptions-64s.S | |||
| @@ -977,20 +977,6 @@ _GLOBAL(do_stab_bolted) | |||
| 977 | rfid | 977 | rfid |
| 978 | b . /* prevent speculative execution */ | 978 | b . /* prevent speculative execution */ |
| 979 | 979 | ||
| 980 | /* | ||
| 981 | * Space for CPU0's segment table. | ||
| 982 | * | ||
| 983 | * On iSeries, the hypervisor must fill in at least one entry before | ||
| 984 | * we get control (with relocate on). The address is given to the hv | ||
| 985 | * as a page number (see xLparMap below), so this must be at a | ||
| 986 | * fixed address (the linker can't compute (u64)&initial_stab >> | ||
| 987 | * PAGE_SHIFT). | ||
| 988 | */ | ||
| 989 | . = STAB0_OFFSET /* 0x6000 */ | ||
| 990 | .globl initial_stab | ||
| 991 | initial_stab: | ||
| 992 | .space 4096 | ||
| 993 | |||
| 994 | #ifdef CONFIG_PPC_PSERIES | 980 | #ifdef CONFIG_PPC_PSERIES |
| 995 | /* | 981 | /* |
| 996 | * Data area reserved for FWNMI option. | 982 | * Data area reserved for FWNMI option. |
| @@ -1027,3 +1013,17 @@ xLparMap: | |||
| 1027 | #ifdef CONFIG_PPC_PSERIES | 1013 | #ifdef CONFIG_PPC_PSERIES |
| 1028 | . = 0x8000 | 1014 | . = 0x8000 |
| 1029 | #endif /* CONFIG_PPC_PSERIES */ | 1015 | #endif /* CONFIG_PPC_PSERIES */ |
| 1016 | |||
| 1017 | /* | ||
| 1018 | * Space for CPU0's segment table. | ||
| 1019 | * | ||
| 1020 | * On iSeries, the hypervisor must fill in at least one entry before | ||
| 1021 | * we get control (with relocate on). The address is given to the hv | ||
| 1022 | * as a page number (see xLparMap above), so this must be at a | ||
| 1023 | * fixed address (the linker can't compute (u64)&initial_stab >> | ||
| 1024 | * PAGE_SHIFT). | ||
| 1025 | */ | ||
| 1026 | . = STAB0_OFFSET /* 0x8000 */ | ||
| 1027 | .globl initial_stab | ||
| 1028 | initial_stab: | ||
| 1029 | .space 4096 | ||
diff --git a/arch/powerpc/kernel/irq.c b/arch/powerpc/kernel/irq.c index 0a5570338b96..63625e0650b5 100644 --- a/arch/powerpc/kernel/irq.c +++ b/arch/powerpc/kernel/irq.c | |||
| @@ -195,7 +195,7 @@ notrace void arch_local_irq_restore(unsigned long en) | |||
| 195 | EXPORT_SYMBOL(arch_local_irq_restore); | 195 | EXPORT_SYMBOL(arch_local_irq_restore); |
| 196 | #endif /* CONFIG_PPC64 */ | 196 | #endif /* CONFIG_PPC64 */ |
| 197 | 197 | ||
| 198 | static int show_other_interrupts(struct seq_file *p, int prec) | 198 | int arch_show_interrupts(struct seq_file *p, int prec) |
| 199 | { | 199 | { |
| 200 | int j; | 200 | int j; |
| 201 | 201 | ||
| @@ -231,65 +231,6 @@ static int show_other_interrupts(struct seq_file *p, int prec) | |||
| 231 | return 0; | 231 | return 0; |
| 232 | } | 232 | } |
| 233 | 233 | ||
| 234 | int show_interrupts(struct seq_file *p, void *v) | ||
| 235 | { | ||
| 236 | unsigned long flags, any_count = 0; | ||
| 237 | int i = *(loff_t *) v, j, prec; | ||
| 238 | struct irqaction *action; | ||
| 239 | struct irq_desc *desc; | ||
| 240 | struct irq_chip *chip; | ||
| 241 | |||
| 242 | if (i > nr_irqs) | ||
| 243 | return 0; | ||
| 244 | |||
| 245 | for (prec = 3, j = 1000; prec < 10 && j <= nr_irqs; ++prec) | ||
| 246 | j *= 10; | ||
| 247 | |||
| 248 | if (i == nr_irqs) | ||
| 249 | return show_other_interrupts(p, prec); | ||
| 250 | |||
| 251 | /* print header */ | ||
| 252 | if (i == 0) { | ||
| 253 | seq_printf(p, "%*s", prec + 8, ""); | ||
| 254 | for_each_online_cpu(j) | ||
| 255 | seq_printf(p, "CPU%-8d", j); | ||
| 256 | seq_putc(p, '\n'); | ||
| 257 | } | ||
| 258 | |||
| 259 | desc = irq_to_desc(i); | ||
| 260 | if (!desc) | ||
| 261 | return 0; | ||
| 262 | |||
| 263 | raw_spin_lock_irqsave(&desc->lock, flags); | ||
| 264 | for_each_online_cpu(j) | ||
| 265 | any_count |= kstat_irqs_cpu(i, j); | ||
| 266 | action = desc->action; | ||
| 267 | if (!action && !any_count) | ||
| 268 | goto out; | ||
| 269 | |||
| 270 | seq_printf(p, "%*d: ", prec, i); | ||
| 271 | for_each_online_cpu(j) | ||
| 272 | seq_printf(p, "%10u ", kstat_irqs_cpu(i, j)); | ||
| 273 | |||
| 274 | chip = get_irq_desc_chip(desc); | ||
| 275 | if (chip) | ||
| 276 | seq_printf(p, " %-16s", chip->name); | ||
| 277 | else | ||
| 278 | seq_printf(p, " %-16s", "None"); | ||
| 279 | seq_printf(p, " %-8s", (desc->status & IRQ_LEVEL) ? "Level" : "Edge"); | ||
| 280 | |||
| 281 | if (action) { | ||
| 282 | seq_printf(p, " %s", action->name); | ||
| 283 | while ((action = action->next) != NULL) | ||
| 284 | seq_printf(p, ", %s", action->name); | ||
| 285 | } | ||
| 286 | |||
| 287 | seq_putc(p, '\n'); | ||
| 288 | out: | ||
| 289 | raw_spin_unlock_irqrestore(&desc->lock, flags); | ||
| 290 | return 0; | ||
| 291 | } | ||
| 292 | |||
| 293 | /* | 234 | /* |
| 294 | * /proc/stat helpers | 235 | * /proc/stat helpers |
| 295 | */ | 236 | */ |
| @@ -315,24 +256,26 @@ void fixup_irqs(const struct cpumask *map) | |||
| 315 | alloc_cpumask_var(&mask, GFP_KERNEL); | 256 | alloc_cpumask_var(&mask, GFP_KERNEL); |
| 316 | 257 | ||
| 317 | for_each_irq(irq) { | 258 | for_each_irq(irq) { |
| 259 | struct irq_data *data; | ||
| 318 | struct irq_chip *chip; | 260 | struct irq_chip *chip; |
| 319 | 261 | ||
| 320 | desc = irq_to_desc(irq); | 262 | desc = irq_to_desc(irq); |
| 321 | if (!desc) | 263 | if (!desc) |
| 322 | continue; | 264 | continue; |
| 323 | 265 | ||
| 324 | if (desc->status & IRQ_PER_CPU) | 266 | data = irq_desc_get_irq_data(desc); |
| 267 | if (irqd_is_per_cpu(data)) | ||
| 325 | continue; | 268 | continue; |
| 326 | 269 | ||
| 327 | chip = get_irq_desc_chip(desc); | 270 | chip = irq_data_get_irq_chip(data); |
| 328 | 271 | ||
| 329 | cpumask_and(mask, desc->irq_data.affinity, map); | 272 | cpumask_and(mask, data->affinity, map); |
| 330 | if (cpumask_any(mask) >= nr_cpu_ids) { | 273 | if (cpumask_any(mask) >= nr_cpu_ids) { |
| 331 | printk("Breaking affinity for irq %i\n", irq); | 274 | printk("Breaking affinity for irq %i\n", irq); |
| 332 | cpumask_copy(mask, map); | 275 | cpumask_copy(mask, map); |
| 333 | } | 276 | } |
| 334 | if (chip->irq_set_affinity) | 277 | if (chip->irq_set_affinity) |
| 335 | chip->irq_set_affinity(&desc->irq_data, mask, true); | 278 | chip->irq_set_affinity(data, mask, true); |
| 336 | else if (desc->action && !(warned++)) | 279 | else if (desc->action && !(warned++)) |
| 337 | printk("Cannot set affinity for irq %i\n", irq); | 280 | printk("Cannot set affinity for irq %i\n", irq); |
| 338 | } | 281 | } |
| @@ -618,7 +561,7 @@ struct irq_host *irq_alloc_host(struct device_node *of_node, | |||
| 618 | smp_wmb(); | 561 | smp_wmb(); |
| 619 | 562 | ||
| 620 | /* Clear norequest flags */ | 563 | /* Clear norequest flags */ |
| 621 | irq_to_desc(i)->status &= ~IRQ_NOREQUEST; | 564 | irq_clear_status_flags(i, IRQ_NOREQUEST); |
| 622 | 565 | ||
| 623 | /* Legacy flags are left to default at this point, | 566 | /* Legacy flags are left to default at this point, |
| 624 | * one can then use irq_create_mapping() to | 567 | * one can then use irq_create_mapping() to |
| @@ -827,8 +770,8 @@ unsigned int irq_create_of_mapping(struct device_node *controller, | |||
| 827 | 770 | ||
| 828 | /* Set type if specified and different than the current one */ | 771 | /* Set type if specified and different than the current one */ |
| 829 | if (type != IRQ_TYPE_NONE && | 772 | if (type != IRQ_TYPE_NONE && |
| 830 | type != (irq_to_desc(virq)->status & IRQF_TRIGGER_MASK)) | 773 | type != (irqd_get_trigger_type(irq_get_irq_data(virq)))) |
| 831 | set_irq_type(virq, type); | 774 | irq_set_irq_type(virq, type); |
| 832 | return virq; | 775 | return virq; |
| 833 | } | 776 | } |
| 834 | EXPORT_SYMBOL_GPL(irq_create_of_mapping); | 777 | EXPORT_SYMBOL_GPL(irq_create_of_mapping); |
| @@ -851,7 +794,7 @@ void irq_dispose_mapping(unsigned int virq) | |||
| 851 | return; | 794 | return; |
| 852 | 795 | ||
| 853 | /* remove chip and handler */ | 796 | /* remove chip and handler */ |
| 854 | set_irq_chip_and_handler(virq, NULL, NULL); | 797 | irq_set_chip_and_handler(virq, NULL, NULL); |
| 855 | 798 | ||
| 856 | /* Make sure it's completed */ | 799 | /* Make sure it's completed */ |
| 857 | synchronize_irq(virq); | 800 | synchronize_irq(virq); |
| @@ -1156,7 +1099,7 @@ static int virq_debug_show(struct seq_file *m, void *private) | |||
| 1156 | seq_printf(m, "%5d ", i); | 1099 | seq_printf(m, "%5d ", i); |
| 1157 | seq_printf(m, "0x%05lx ", virq_to_hw(i)); | 1100 | seq_printf(m, "0x%05lx ", virq_to_hw(i)); |
| 1158 | 1101 | ||
| 1159 | chip = get_irq_desc_chip(desc); | 1102 | chip = irq_desc_get_chip(desc); |
| 1160 | if (chip && chip->name) | 1103 | if (chip && chip->name) |
| 1161 | p = chip->name; | 1104 | p = chip->name; |
| 1162 | else | 1105 | else |
diff --git a/arch/powerpc/kernel/machine_kexec.c b/arch/powerpc/kernel/machine_kexec.c index bd1e1ff17b2d..7ee50f0547cb 100644 --- a/arch/powerpc/kernel/machine_kexec.c +++ b/arch/powerpc/kernel/machine_kexec.c | |||
| @@ -31,17 +31,17 @@ void machine_kexec_mask_interrupts(void) { | |||
| 31 | if (!desc) | 31 | if (!desc) |
| 32 | continue; | 32 | continue; |
| 33 | 33 | ||
| 34 | chip = get_irq_desc_chip(desc); | 34 | chip = irq_desc_get_chip(desc); |
| 35 | if (!chip) | 35 | if (!chip) |
| 36 | continue; | 36 | continue; |
| 37 | 37 | ||
| 38 | if (chip->irq_eoi && desc->status & IRQ_INPROGRESS) | 38 | if (chip->irq_eoi && irqd_irq_inprogress(&desc->irq_data)) |
| 39 | chip->irq_eoi(&desc->irq_data); | 39 | chip->irq_eoi(&desc->irq_data); |
| 40 | 40 | ||
| 41 | if (chip->irq_mask) | 41 | if (chip->irq_mask) |
| 42 | chip->irq_mask(&desc->irq_data); | 42 | chip->irq_mask(&desc->irq_data); |
| 43 | 43 | ||
| 44 | if (chip->irq_disable && !(desc->status & IRQ_DISABLED)) | 44 | if (chip->irq_disable && !irqd_irq_disabled(&desc->irq_data)) |
| 45 | chip->irq_disable(&desc->irq_data); | 45 | chip->irq_disable(&desc->irq_data); |
| 46 | } | 46 | } |
| 47 | } | 47 | } |
diff --git a/arch/powerpc/kernel/pci-common.c b/arch/powerpc/kernel/pci-common.c index 3cd85faa8ac6..893af2a9cd03 100644 --- a/arch/powerpc/kernel/pci-common.c +++ b/arch/powerpc/kernel/pci-common.c | |||
| @@ -261,7 +261,7 @@ int pci_read_irq_line(struct pci_dev *pci_dev) | |||
| 261 | 261 | ||
| 262 | virq = irq_create_mapping(NULL, line); | 262 | virq = irq_create_mapping(NULL, line); |
| 263 | if (virq != NO_IRQ) | 263 | if (virq != NO_IRQ) |
| 264 | set_irq_type(virq, IRQ_TYPE_LEVEL_LOW); | 264 | irq_set_irq_type(virq, IRQ_TYPE_LEVEL_LOW); |
| 265 | } else { | 265 | } else { |
| 266 | pr_debug(" Got one, spec %d cells (0x%08x 0x%08x...) on %s\n", | 266 | pr_debug(" Got one, spec %d cells (0x%08x 0x%08x...) on %s\n", |
| 267 | oirq.size, oirq.specifier[0], oirq.specifier[1], | 267 | oirq.size, oirq.specifier[0], oirq.specifier[1], |
diff --git a/arch/powerpc/kernel/time.c b/arch/powerpc/kernel/time.c index 09d31dbf43f9..aa9269600ca2 100644 --- a/arch/powerpc/kernel/time.c +++ b/arch/powerpc/kernel/time.c | |||
| @@ -356,7 +356,7 @@ void account_system_vtime(struct task_struct *tsk) | |||
| 356 | } | 356 | } |
| 357 | get_paca()->user_time_scaled += user_scaled; | 357 | get_paca()->user_time_scaled += user_scaled; |
| 358 | 358 | ||
| 359 | if (in_irq() || idle_task(smp_processor_id()) != tsk) { | 359 | if (in_interrupt() || idle_task(smp_processor_id()) != tsk) { |
| 360 | account_system_time(tsk, 0, delta, sys_scaled); | 360 | account_system_time(tsk, 0, delta, sys_scaled); |
| 361 | if (stolen) | 361 | if (stolen) |
| 362 | account_steal_time(stolen); | 362 | account_steal_time(stolen); |
