diff options
Diffstat (limited to 'arch/arm/mach-exynos')
-rw-r--r-- | arch/arm/mach-exynos/common.c | 233 | ||||
-rw-r--r-- | arch/arm/mach-exynos/common.h | 25 | ||||
-rw-r--r-- | arch/arm/mach-exynos/cpuidle.c | 3 | ||||
-rw-r--r-- | arch/arm/mach-exynos/dev-audio.c | 3 | ||||
-rw-r--r-- | arch/arm/mach-exynos/include/mach/cpufreq.h | 36 | ||||
-rw-r--r-- | arch/arm/mach-exynos/include/mach/pmu.h | 34 | ||||
-rw-r--r-- | arch/arm/mach-exynos/include/mach/regs-audss.h | 18 | ||||
-rw-r--r-- | arch/arm/mach-exynos/include/mach/regs-irq.h | 2 | ||||
-rw-r--r-- | arch/arm/mach-exynos/mach-armlex4210.c | 4 | ||||
-rw-r--r-- | arch/arm/mach-exynos/mach-exynos4-dt.c | 4 | ||||
-rw-r--r-- | arch/arm/mach-exynos/mach-exynos5-dt.c | 10 | ||||
-rw-r--r-- | arch/arm/mach-exynos/mach-nuri.c | 12 | ||||
-rw-r--r-- | arch/arm/mach-exynos/mach-origen.c | 4 | ||||
-rw-r--r-- | arch/arm/mach-exynos/mach-smdk4x12.c | 7 | ||||
-rw-r--r-- | arch/arm/mach-exynos/mach-smdkv310.c | 7 | ||||
-rw-r--r-- | arch/arm/mach-exynos/mach-universal_c210.c | 12 | ||||
-rw-r--r-- | arch/arm/mach-exynos/mct.c | 25 | ||||
-rw-r--r-- | arch/arm/mach-exynos/platsmp.c | 6 | ||||
-rw-r--r-- | arch/arm/mach-exynos/pm.c | 9 | ||||
-rw-r--r-- | arch/arm/mach-exynos/pmu.c | 3 |
20 files changed, 79 insertions, 378 deletions
diff --git a/arch/arm/mach-exynos/common.c b/arch/arm/mach-exynos/common.c index 1a89824a5f78..d63d399c7bae 100644 --- a/arch/arm/mach-exynos/common.c +++ b/arch/arm/mach-exynos/common.c | |||
@@ -12,6 +12,7 @@ | |||
12 | #include <linux/kernel.h> | 12 | #include <linux/kernel.h> |
13 | #include <linux/interrupt.h> | 13 | #include <linux/interrupt.h> |
14 | #include <linux/irq.h> | 14 | #include <linux/irq.h> |
15 | #include <linux/irqchip.h> | ||
15 | #include <linux/io.h> | 16 | #include <linux/io.h> |
16 | #include <linux/device.h> | 17 | #include <linux/device.h> |
17 | #include <linux/gpio.h> | 18 | #include <linux/gpio.h> |
@@ -22,12 +23,13 @@ | |||
22 | #include <linux/of_irq.h> | 23 | #include <linux/of_irq.h> |
23 | #include <linux/export.h> | 24 | #include <linux/export.h> |
24 | #include <linux/irqdomain.h> | 25 | #include <linux/irqdomain.h> |
26 | #include <linux/irqchip.h> | ||
25 | #include <linux/of_address.h> | 27 | #include <linux/of_address.h> |
28 | #include <linux/irqchip/arm-gic.h> | ||
26 | 29 | ||
27 | #include <asm/proc-fns.h> | 30 | #include <asm/proc-fns.h> |
28 | #include <asm/exception.h> | 31 | #include <asm/exception.h> |
29 | #include <asm/hardware/cache-l2x0.h> | 32 | #include <asm/hardware/cache-l2x0.h> |
30 | #include <asm/hardware/gic.h> | ||
31 | #include <asm/mach/map.h> | 33 | #include <asm/mach/map.h> |
32 | #include <asm/mach/irq.h> | 34 | #include <asm/mach/irq.h> |
33 | #include <asm/cacheflush.h> | 35 | #include <asm/cacheflush.h> |
@@ -35,7 +37,6 @@ | |||
35 | #include <mach/regs-irq.h> | 37 | #include <mach/regs-irq.h> |
36 | #include <mach/regs-pmu.h> | 38 | #include <mach/regs-pmu.h> |
37 | #include <mach/regs-gpio.h> | 39 | #include <mach/regs-gpio.h> |
38 | #include <mach/pmu.h> | ||
39 | 40 | ||
40 | #include <plat/cpu.h> | 41 | #include <plat/cpu.h> |
41 | #include <plat/clock.h> | 42 | #include <plat/clock.h> |
@@ -299,6 +300,7 @@ void exynos4_restart(char mode, const char *cmd) | |||
299 | 300 | ||
300 | void exynos5_restart(char mode, const char *cmd) | 301 | void exynos5_restart(char mode, const char *cmd) |
301 | { | 302 | { |
303 | struct device_node *np; | ||
302 | u32 val; | 304 | u32 val; |
303 | void __iomem *addr; | 305 | void __iomem *addr; |
304 | 306 | ||
@@ -306,8 +308,9 @@ void exynos5_restart(char mode, const char *cmd) | |||
306 | val = 0x1; | 308 | val = 0x1; |
307 | addr = EXYNOS_SWRESET; | 309 | addr = EXYNOS_SWRESET; |
308 | } else if (of_machine_is_compatible("samsung,exynos5440")) { | 310 | } else if (of_machine_is_compatible("samsung,exynos5440")) { |
309 | val = (0x10 << 20) | (0x1 << 16); | 311 | np = of_find_compatible_node(NULL, NULL, "samsung,exynos5440-clock"); |
310 | addr = EXYNOS5440_SWRESET; | 312 | addr = of_iomap(np, 0) + 0xcc; |
313 | val = (0xfff << 20) | (0x1 << 16); | ||
311 | } else { | 314 | } else { |
312 | pr_err("%s: cannot support non-DT\n", __func__); | 315 | pr_err("%s: cannot support non-DT\n", __func__); |
313 | return; | 316 | return; |
@@ -438,220 +441,6 @@ static void __init exynos5_init_clocks(int xtal) | |||
438 | #endif | 441 | #endif |
439 | } | 442 | } |
440 | 443 | ||
441 | #define COMBINER_ENABLE_SET 0x0 | ||
442 | #define COMBINER_ENABLE_CLEAR 0x4 | ||
443 | #define COMBINER_INT_STATUS 0xC | ||
444 | |||
445 | static DEFINE_SPINLOCK(irq_controller_lock); | ||
446 | |||
447 | struct combiner_chip_data { | ||
448 | unsigned int irq_offset; | ||
449 | unsigned int irq_mask; | ||
450 | void __iomem *base; | ||
451 | }; | ||
452 | |||
453 | static struct irq_domain *combiner_irq_domain; | ||
454 | static struct combiner_chip_data combiner_data[MAX_COMBINER_NR]; | ||
455 | |||
456 | static inline void __iomem *combiner_base(struct irq_data *data) | ||
457 | { | ||
458 | struct combiner_chip_data *combiner_data = | ||
459 | irq_data_get_irq_chip_data(data); | ||
460 | |||
461 | return combiner_data->base; | ||
462 | } | ||
463 | |||
464 | static void combiner_mask_irq(struct irq_data *data) | ||
465 | { | ||
466 | u32 mask = 1 << (data->hwirq % 32); | ||
467 | |||
468 | __raw_writel(mask, combiner_base(data) + COMBINER_ENABLE_CLEAR); | ||
469 | } | ||
470 | |||
471 | static void combiner_unmask_irq(struct irq_data *data) | ||
472 | { | ||
473 | u32 mask = 1 << (data->hwirq % 32); | ||
474 | |||
475 | __raw_writel(mask, combiner_base(data) + COMBINER_ENABLE_SET); | ||
476 | } | ||
477 | |||
478 | static void combiner_handle_cascade_irq(unsigned int irq, struct irq_desc *desc) | ||
479 | { | ||
480 | struct combiner_chip_data *chip_data = irq_get_handler_data(irq); | ||
481 | struct irq_chip *chip = irq_get_chip(irq); | ||
482 | unsigned int cascade_irq, combiner_irq; | ||
483 | unsigned long status; | ||
484 | |||
485 | chained_irq_enter(chip, desc); | ||
486 | |||
487 | spin_lock(&irq_controller_lock); | ||
488 | status = __raw_readl(chip_data->base + COMBINER_INT_STATUS); | ||
489 | spin_unlock(&irq_controller_lock); | ||
490 | status &= chip_data->irq_mask; | ||
491 | |||
492 | if (status == 0) | ||
493 | goto out; | ||
494 | |||
495 | combiner_irq = __ffs(status); | ||
496 | |||
497 | cascade_irq = combiner_irq + (chip_data->irq_offset & ~31); | ||
498 | if (unlikely(cascade_irq >= NR_IRQS)) | ||
499 | do_bad_IRQ(cascade_irq, desc); | ||
500 | else | ||
501 | generic_handle_irq(cascade_irq); | ||
502 | |||
503 | out: | ||
504 | chained_irq_exit(chip, desc); | ||
505 | } | ||
506 | |||
507 | static struct irq_chip combiner_chip = { | ||
508 | .name = "COMBINER", | ||
509 | .irq_mask = combiner_mask_irq, | ||
510 | .irq_unmask = combiner_unmask_irq, | ||
511 | }; | ||
512 | |||
513 | static void __init combiner_cascade_irq(unsigned int combiner_nr, unsigned int irq) | ||
514 | { | ||
515 | unsigned int max_nr; | ||
516 | |||
517 | if (soc_is_exynos5250()) | ||
518 | max_nr = EXYNOS5_MAX_COMBINER_NR; | ||
519 | else | ||
520 | max_nr = EXYNOS4_MAX_COMBINER_NR; | ||
521 | |||
522 | if (combiner_nr >= max_nr) | ||
523 | BUG(); | ||
524 | if (irq_set_handler_data(irq, &combiner_data[combiner_nr]) != 0) | ||
525 | BUG(); | ||
526 | irq_set_chained_handler(irq, combiner_handle_cascade_irq); | ||
527 | } | ||
528 | |||
529 | static void __init combiner_init_one(unsigned int combiner_nr, | ||
530 | void __iomem *base) | ||
531 | { | ||
532 | combiner_data[combiner_nr].base = base; | ||
533 | combiner_data[combiner_nr].irq_offset = irq_find_mapping( | ||
534 | combiner_irq_domain, combiner_nr * MAX_IRQ_IN_COMBINER); | ||
535 | combiner_data[combiner_nr].irq_mask = 0xff << ((combiner_nr % 4) << 3); | ||
536 | |||
537 | /* Disable all interrupts */ | ||
538 | __raw_writel(combiner_data[combiner_nr].irq_mask, | ||
539 | base + COMBINER_ENABLE_CLEAR); | ||
540 | } | ||
541 | |||
542 | #ifdef CONFIG_OF | ||
543 | static int combiner_irq_domain_xlate(struct irq_domain *d, | ||
544 | struct device_node *controller, | ||
545 | const u32 *intspec, unsigned int intsize, | ||
546 | unsigned long *out_hwirq, | ||
547 | unsigned int *out_type) | ||
548 | { | ||
549 | if (d->of_node != controller) | ||
550 | return -EINVAL; | ||
551 | |||
552 | if (intsize < 2) | ||
553 | return -EINVAL; | ||
554 | |||
555 | *out_hwirq = intspec[0] * MAX_IRQ_IN_COMBINER + intspec[1]; | ||
556 | *out_type = 0; | ||
557 | |||
558 | return 0; | ||
559 | } | ||
560 | #else | ||
561 | static int combiner_irq_domain_xlate(struct irq_domain *d, | ||
562 | struct device_node *controller, | ||
563 | const u32 *intspec, unsigned int intsize, | ||
564 | unsigned long *out_hwirq, | ||
565 | unsigned int *out_type) | ||
566 | { | ||
567 | return -EINVAL; | ||
568 | } | ||
569 | #endif | ||
570 | |||
571 | static int combiner_irq_domain_map(struct irq_domain *d, unsigned int irq, | ||
572 | irq_hw_number_t hw) | ||
573 | { | ||
574 | irq_set_chip_and_handler(irq, &combiner_chip, handle_level_irq); | ||
575 | irq_set_chip_data(irq, &combiner_data[hw >> 3]); | ||
576 | set_irq_flags(irq, IRQF_VALID | IRQF_PROBE); | ||
577 | |||
578 | return 0; | ||
579 | } | ||
580 | |||
581 | static struct irq_domain_ops combiner_irq_domain_ops = { | ||
582 | .xlate = combiner_irq_domain_xlate, | ||
583 | .map = combiner_irq_domain_map, | ||
584 | }; | ||
585 | |||
586 | static void __init combiner_init(void __iomem *combiner_base, | ||
587 | struct device_node *np) | ||
588 | { | ||
589 | int i, irq, irq_base; | ||
590 | unsigned int max_nr, nr_irq; | ||
591 | |||
592 | if (np) { | ||
593 | if (of_property_read_u32(np, "samsung,combiner-nr", &max_nr)) { | ||
594 | pr_warning("%s: number of combiners not specified, " | ||
595 | "setting default as %d.\n", | ||
596 | __func__, EXYNOS4_MAX_COMBINER_NR); | ||
597 | max_nr = EXYNOS4_MAX_COMBINER_NR; | ||
598 | } | ||
599 | } else { | ||
600 | max_nr = soc_is_exynos5250() ? EXYNOS5_MAX_COMBINER_NR : | ||
601 | EXYNOS4_MAX_COMBINER_NR; | ||
602 | } | ||
603 | nr_irq = max_nr * MAX_IRQ_IN_COMBINER; | ||
604 | |||
605 | irq_base = irq_alloc_descs(COMBINER_IRQ(0, 0), 1, nr_irq, 0); | ||
606 | if (IS_ERR_VALUE(irq_base)) { | ||
607 | irq_base = COMBINER_IRQ(0, 0); | ||
608 | pr_warning("%s: irq desc alloc failed. Continuing with %d as linux irq base\n", __func__, irq_base); | ||
609 | } | ||
610 | |||
611 | combiner_irq_domain = irq_domain_add_legacy(np, nr_irq, irq_base, 0, | ||
612 | &combiner_irq_domain_ops, &combiner_data); | ||
613 | if (WARN_ON(!combiner_irq_domain)) { | ||
614 | pr_warning("%s: irq domain init failed\n", __func__); | ||
615 | return; | ||
616 | } | ||
617 | |||
618 | for (i = 0; i < max_nr; i++) { | ||
619 | combiner_init_one(i, combiner_base + (i >> 2) * 0x10); | ||
620 | irq = IRQ_SPI(i); | ||
621 | #ifdef CONFIG_OF | ||
622 | if (np) | ||
623 | irq = irq_of_parse_and_map(np, i); | ||
624 | #endif | ||
625 | combiner_cascade_irq(i, irq); | ||
626 | } | ||
627 | } | ||
628 | |||
629 | #ifdef CONFIG_OF | ||
630 | static int __init combiner_of_init(struct device_node *np, | ||
631 | struct device_node *parent) | ||
632 | { | ||
633 | void __iomem *combiner_base; | ||
634 | |||
635 | combiner_base = of_iomap(np, 0); | ||
636 | if (!combiner_base) { | ||
637 | pr_err("%s: failed to map combiner registers\n", __func__); | ||
638 | return -ENXIO; | ||
639 | } | ||
640 | |||
641 | combiner_init(combiner_base, np); | ||
642 | |||
643 | return 0; | ||
644 | } | ||
645 | |||
646 | static const struct of_device_id exynos_dt_irq_match[] = { | ||
647 | { .compatible = "arm,cortex-a9-gic", .data = gic_of_init, }, | ||
648 | { .compatible = "arm,cortex-a15-gic", .data = gic_of_init, }, | ||
649 | { .compatible = "samsung,exynos4210-combiner", | ||
650 | .data = combiner_of_init, }, | ||
651 | {}, | ||
652 | }; | ||
653 | #endif | ||
654 | |||
655 | void __init exynos4_init_irq(void) | 444 | void __init exynos4_init_irq(void) |
656 | { | 445 | { |
657 | unsigned int gic_bank_offset; | 446 | unsigned int gic_bank_offset; |
@@ -662,7 +451,7 @@ void __init exynos4_init_irq(void) | |||
662 | gic_init_bases(0, IRQ_PPI(0), S5P_VA_GIC_DIST, S5P_VA_GIC_CPU, gic_bank_offset, NULL); | 451 | gic_init_bases(0, IRQ_PPI(0), S5P_VA_GIC_DIST, S5P_VA_GIC_CPU, gic_bank_offset, NULL); |
663 | #ifdef CONFIG_OF | 452 | #ifdef CONFIG_OF |
664 | else | 453 | else |
665 | of_irq_init(exynos_dt_irq_match); | 454 | irqchip_init(); |
666 | #endif | 455 | #endif |
667 | 456 | ||
668 | if (!of_have_populated_dt()) | 457 | if (!of_have_populated_dt()) |
@@ -679,7 +468,7 @@ void __init exynos4_init_irq(void) | |||
679 | void __init exynos5_init_irq(void) | 468 | void __init exynos5_init_irq(void) |
680 | { | 469 | { |
681 | #ifdef CONFIG_OF | 470 | #ifdef CONFIG_OF |
682 | of_irq_init(exynos_dt_irq_match); | 471 | irqchip_init(); |
683 | #endif | 472 | #endif |
684 | /* | 473 | /* |
685 | * The parameters of s5p_init_irq() are for VIC init. | 474 | * The parameters of s5p_init_irq() are for VIC init. |
@@ -1031,8 +820,8 @@ static int __init exynos_init_irq_eint(void) | |||
1031 | * interrupt support code here can be completely removed. | 820 | * interrupt support code here can be completely removed. |
1032 | */ | 821 | */ |
1033 | static const struct of_device_id exynos_pinctrl_ids[] = { | 822 | static const struct of_device_id exynos_pinctrl_ids[] = { |
1034 | { .compatible = "samsung,pinctrl-exynos4210", }, | 823 | { .compatible = "samsung,exynos4210-pinctrl", }, |
1035 | { .compatible = "samsung,pinctrl-exynos4x12", }, | 824 | { .compatible = "samsung,exynos4x12-pinctrl", }, |
1036 | }; | 825 | }; |
1037 | struct device_node *pctrl_np, *wkup_np; | 826 | struct device_node *pctrl_np, *wkup_np; |
1038 | const char *wkup_compat = "samsung,exynos4210-wakeup-eint"; | 827 | const char *wkup_compat = "samsung,exynos4210-wakeup-eint"; |
diff --git a/arch/arm/mach-exynos/common.h b/arch/arm/mach-exynos/common.h index 04744f9c120f..9339bb8954be 100644 --- a/arch/arm/mach-exynos/common.h +++ b/arch/arm/mach-exynos/common.h | |||
@@ -12,7 +12,7 @@ | |||
12 | #ifndef __ARCH_ARM_MACH_EXYNOS_COMMON_H | 12 | #ifndef __ARCH_ARM_MACH_EXYNOS_COMMON_H |
13 | #define __ARCH_ARM_MACH_EXYNOS_COMMON_H | 13 | #define __ARCH_ARM_MACH_EXYNOS_COMMON_H |
14 | 14 | ||
15 | extern struct sys_timer exynos4_timer; | 15 | extern void exynos4_timer_init(void); |
16 | 16 | ||
17 | struct map_desc; | 17 | struct map_desc; |
18 | void exynos_init_io(struct map_desc *mach_desc, int size); | 18 | void exynos_init_io(struct map_desc *mach_desc, int size); |
@@ -60,8 +60,31 @@ void exynos4212_register_clocks(void); | |||
60 | #define exynos4212_register_clocks() | 60 | #define exynos4212_register_clocks() |
61 | #endif | 61 | #endif |
62 | 62 | ||
63 | struct device_node; | ||
64 | void combiner_init(void __iomem *combiner_base, struct device_node *np); | ||
65 | |||
63 | extern struct smp_operations exynos_smp_ops; | 66 | extern struct smp_operations exynos_smp_ops; |
64 | 67 | ||
65 | extern void exynos_cpu_die(unsigned int cpu); | 68 | extern void exynos_cpu_die(unsigned int cpu); |
66 | 69 | ||
70 | /* PMU(Power Management Unit) support */ | ||
71 | |||
72 | #define PMU_TABLE_END NULL | ||
73 | |||
74 | enum sys_powerdown { | ||
75 | SYS_AFTR, | ||
76 | SYS_LPA, | ||
77 | SYS_SLEEP, | ||
78 | NUM_SYS_POWERDOWN, | ||
79 | }; | ||
80 | |||
81 | extern unsigned long l2x0_regs_phys; | ||
82 | struct exynos_pmu_conf { | ||
83 | void __iomem *reg; | ||
84 | unsigned int val[NUM_SYS_POWERDOWN]; | ||
85 | }; | ||
86 | |||
87 | extern void exynos_sys_powerdown_conf(enum sys_powerdown mode); | ||
88 | extern void s3c_cpu_resume(void); | ||
89 | |||
67 | #endif /* __ARCH_ARM_MACH_EXYNOS_COMMON_H */ | 90 | #endif /* __ARCH_ARM_MACH_EXYNOS_COMMON_H */ |
diff --git a/arch/arm/mach-exynos/cpuidle.c b/arch/arm/mach-exynos/cpuidle.c index 050924152776..fcfe0251aa3e 100644 --- a/arch/arm/mach-exynos/cpuidle.c +++ b/arch/arm/mach-exynos/cpuidle.c | |||
@@ -23,10 +23,11 @@ | |||
23 | #include <asm/cpuidle.h> | 23 | #include <asm/cpuidle.h> |
24 | #include <mach/regs-clock.h> | 24 | #include <mach/regs-clock.h> |
25 | #include <mach/regs-pmu.h> | 25 | #include <mach/regs-pmu.h> |
26 | #include <mach/pmu.h> | ||
27 | 26 | ||
28 | #include <plat/cpu.h> | 27 | #include <plat/cpu.h> |
29 | 28 | ||
29 | #include "common.h" | ||
30 | |||
30 | #define REG_DIRECTGO_ADDR (samsung_rev() == EXYNOS4210_REV_1_1 ? \ | 31 | #define REG_DIRECTGO_ADDR (samsung_rev() == EXYNOS4210_REV_1_1 ? \ |
31 | S5P_INFORM7 : (samsung_rev() == EXYNOS4210_REV_1_0 ? \ | 32 | S5P_INFORM7 : (samsung_rev() == EXYNOS4210_REV_1_0 ? \ |
32 | (S5P_VA_SYSRAM + 0x24) : S5P_INFORM0)) | 33 | (S5P_VA_SYSRAM + 0x24) : S5P_INFORM0)) |
diff --git a/arch/arm/mach-exynos/dev-audio.c b/arch/arm/mach-exynos/dev-audio.c index 9d1a60951d7b..c662c89794b2 100644 --- a/arch/arm/mach-exynos/dev-audio.c +++ b/arch/arm/mach-exynos/dev-audio.c | |||
@@ -21,7 +21,8 @@ | |||
21 | #include <mach/map.h> | 21 | #include <mach/map.h> |
22 | #include <mach/dma.h> | 22 | #include <mach/dma.h> |
23 | #include <mach/irqs.h> | 23 | #include <mach/irqs.h> |
24 | #include <mach/regs-audss.h> | 24 | |
25 | #define EXYNOS4_AUDSS_INT_MEM (0x03000000) | ||
25 | 26 | ||
26 | static int exynos4_cfg_i2s(struct platform_device *pdev) | 27 | static int exynos4_cfg_i2s(struct platform_device *pdev) |
27 | { | 28 | { |
diff --git a/arch/arm/mach-exynos/include/mach/cpufreq.h b/arch/arm/mach-exynos/include/mach/cpufreq.h deleted file mode 100644 index 7517c3f417af..000000000000 --- a/arch/arm/mach-exynos/include/mach/cpufreq.h +++ /dev/null | |||
@@ -1,36 +0,0 @@ | |||
1 | /* linux/arch/arm/mach-exynos/include/mach/cpufreq.h | ||
2 | * | ||
3 | * Copyright (c) 2010 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * EXYNOS - CPUFreq support | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | enum cpufreq_level_index { | ||
14 | L0, L1, L2, L3, L4, | ||
15 | L5, L6, L7, L8, L9, | ||
16 | L10, L11, L12, L13, L14, | ||
17 | L15, L16, L17, L18, L19, | ||
18 | L20, | ||
19 | }; | ||
20 | |||
21 | struct exynos_dvfs_info { | ||
22 | unsigned long mpll_freq_khz; | ||
23 | unsigned int pll_safe_idx; | ||
24 | unsigned int pm_lock_idx; | ||
25 | unsigned int max_support_idx; | ||
26 | unsigned int min_support_idx; | ||
27 | struct clk *cpu_clk; | ||
28 | unsigned int *volt_table; | ||
29 | struct cpufreq_frequency_table *freq_table; | ||
30 | void (*set_freq)(unsigned int, unsigned int); | ||
31 | bool (*need_apll_change)(unsigned int, unsigned int); | ||
32 | }; | ||
33 | |||
34 | extern int exynos4210_cpufreq_init(struct exynos_dvfs_info *); | ||
35 | extern int exynos4x12_cpufreq_init(struct exynos_dvfs_info *); | ||
36 | extern int exynos5250_cpufreq_init(struct exynos_dvfs_info *); | ||
diff --git a/arch/arm/mach-exynos/include/mach/pmu.h b/arch/arm/mach-exynos/include/mach/pmu.h deleted file mode 100644 index 7c27c2d4bf44..000000000000 --- a/arch/arm/mach-exynos/include/mach/pmu.h +++ /dev/null | |||
@@ -1,34 +0,0 @@ | |||
1 | /* linux/arch/arm/mach-exynos4/include/mach/pmu.h | ||
2 | * | ||
3 | * Copyright (c) 2011 Samsung Electronics Co., Ltd. | ||
4 | * http://www.samsung.com/ | ||
5 | * | ||
6 | * EXYNOS4210 - PMU(Power Management Unit) support | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #ifndef __ASM_ARCH_PMU_H | ||
14 | #define __ASM_ARCH_PMU_H __FILE__ | ||
15 | |||
16 | #define PMU_TABLE_END NULL | ||
17 | |||
18 | enum sys_powerdown { | ||
19 | SYS_AFTR, | ||
20 | SYS_LPA, | ||
21 | SYS_SLEEP, | ||
22 | NUM_SYS_POWERDOWN, | ||
23 | }; | ||
24 | |||
25 | extern unsigned long l2x0_regs_phys; | ||
26 | struct exynos_pmu_conf { | ||
27 | void __iomem *reg; | ||
28 | unsigned int val[NUM_SYS_POWERDOWN]; | ||
29 | }; | ||
30 | |||
31 | extern void exynos_sys_powerdown_conf(enum sys_powerdown mode); | ||
32 | extern void s3c_cpu_resume(void); | ||
33 | |||
34 | #endif /* __ASM_ARCH_PMU_H */ | ||
diff --git a/arch/arm/mach-exynos/include/mach/regs-audss.h b/arch/arm/mach-exynos/include/mach/regs-audss.h deleted file mode 100644 index ca5a8b64218a..000000000000 --- a/arch/arm/mach-exynos/include/mach/regs-audss.h +++ /dev/null | |||
@@ -1,18 +0,0 @@ | |||
1 | /* arch/arm/mach-exynos4/include/mach/regs-audss.h | ||
2 | * | ||
3 | * Copyright (c) 2011 Samsung Electronics | ||
4 | * http://www.samsung.com | ||
5 | * | ||
6 | * Exynos4 Audio SubSystem clock register definitions | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #ifndef __PLAT_REGS_AUDSS_H | ||
14 | #define __PLAT_REGS_AUDSS_H __FILE__ | ||
15 | |||
16 | #define EXYNOS4_AUDSS_INT_MEM (0x03000000) | ||
17 | |||
18 | #endif /* _PLAT_REGS_AUDSS_H */ | ||
diff --git a/arch/arm/mach-exynos/include/mach/regs-irq.h b/arch/arm/mach-exynos/include/mach/regs-irq.h index 9c7b4bfd546f..f2b50506b9f6 100644 --- a/arch/arm/mach-exynos/include/mach/regs-irq.h +++ b/arch/arm/mach-exynos/include/mach/regs-irq.h | |||
@@ -13,7 +13,7 @@ | |||
13 | #ifndef __ASM_ARCH_REGS_IRQ_H | 13 | #ifndef __ASM_ARCH_REGS_IRQ_H |
14 | #define __ASM_ARCH_REGS_IRQ_H __FILE__ | 14 | #define __ASM_ARCH_REGS_IRQ_H __FILE__ |
15 | 15 | ||
16 | #include <asm/hardware/gic.h> | 16 | #include <linux/irqchip/arm-gic.h> |
17 | #include <mach/map.h> | 17 | #include <mach/map.h> |
18 | 18 | ||
19 | #endif /* __ASM_ARCH_REGS_IRQ_H */ | 19 | #endif /* __ASM_ARCH_REGS_IRQ_H */ |
diff --git a/arch/arm/mach-exynos/mach-armlex4210.c b/arch/arm/mach-exynos/mach-armlex4210.c index b938f9fc1dd1..685f29173afa 100644 --- a/arch/arm/mach-exynos/mach-armlex4210.c +++ b/arch/arm/mach-exynos/mach-armlex4210.c | |||
@@ -16,7 +16,6 @@ | |||
16 | #include <linux/smsc911x.h> | 16 | #include <linux/smsc911x.h> |
17 | 17 | ||
18 | #include <asm/mach/arch.h> | 18 | #include <asm/mach/arch.h> |
19 | #include <asm/hardware/gic.h> | ||
20 | #include <asm/mach-types.h> | 19 | #include <asm/mach-types.h> |
21 | 20 | ||
22 | #include <plat/cpu.h> | 21 | #include <plat/cpu.h> |
@@ -201,9 +200,8 @@ MACHINE_START(ARMLEX4210, "ARMLEX4210") | |||
201 | .smp = smp_ops(exynos_smp_ops), | 200 | .smp = smp_ops(exynos_smp_ops), |
202 | .init_irq = exynos4_init_irq, | 201 | .init_irq = exynos4_init_irq, |
203 | .map_io = armlex4210_map_io, | 202 | .map_io = armlex4210_map_io, |
204 | .handle_irq = gic_handle_irq, | ||
205 | .init_machine = armlex4210_machine_init, | 203 | .init_machine = armlex4210_machine_init, |
206 | .init_late = exynos_init_late, | 204 | .init_late = exynos_init_late, |
207 | .timer = &exynos4_timer, | 205 | .init_time = exynos4_timer_init, |
208 | .restart = exynos4_restart, | 206 | .restart = exynos4_restart, |
209 | MACHINE_END | 207 | MACHINE_END |
diff --git a/arch/arm/mach-exynos/mach-exynos4-dt.c b/arch/arm/mach-exynos/mach-exynos4-dt.c index ac09af860b38..3358088c822a 100644 --- a/arch/arm/mach-exynos/mach-exynos4-dt.c +++ b/arch/arm/mach-exynos/mach-exynos4-dt.c | |||
@@ -15,7 +15,6 @@ | |||
15 | #include <linux/serial_core.h> | 15 | #include <linux/serial_core.h> |
16 | 16 | ||
17 | #include <asm/mach/arch.h> | 17 | #include <asm/mach/arch.h> |
18 | #include <asm/hardware/gic.h> | ||
19 | #include <mach/map.h> | 18 | #include <mach/map.h> |
20 | 19 | ||
21 | #include <plat/cpu.h> | 20 | #include <plat/cpu.h> |
@@ -141,10 +140,9 @@ DT_MACHINE_START(EXYNOS4210_DT, "Samsung Exynos4 (Flattened Device Tree)") | |||
141 | .smp = smp_ops(exynos_smp_ops), | 140 | .smp = smp_ops(exynos_smp_ops), |
142 | .init_irq = exynos4_init_irq, | 141 | .init_irq = exynos4_init_irq, |
143 | .map_io = exynos4_dt_map_io, | 142 | .map_io = exynos4_dt_map_io, |
144 | .handle_irq = gic_handle_irq, | ||
145 | .init_machine = exynos4_dt_machine_init, | 143 | .init_machine = exynos4_dt_machine_init, |
146 | .init_late = exynos_init_late, | 144 | .init_late = exynos_init_late, |
147 | .timer = &exynos4_timer, | 145 | .init_time = exynos4_timer_init, |
148 | .dt_compat = exynos4_dt_compat, | 146 | .dt_compat = exynos4_dt_compat, |
149 | .restart = exynos4_restart, | 147 | .restart = exynos4_restart, |
150 | MACHINE_END | 148 | MACHINE_END |
diff --git a/arch/arm/mach-exynos/mach-exynos5-dt.c b/arch/arm/mach-exynos/mach-exynos5-dt.c index 26710758c385..acaeb14db54b 100644 --- a/arch/arm/mach-exynos/mach-exynos5-dt.c +++ b/arch/arm/mach-exynos/mach-exynos5-dt.c | |||
@@ -16,7 +16,6 @@ | |||
16 | #include <linux/io.h> | 16 | #include <linux/io.h> |
17 | 17 | ||
18 | #include <asm/mach/arch.h> | 18 | #include <asm/mach/arch.h> |
19 | #include <asm/hardware/gic.h> | ||
20 | #include <mach/map.h> | 19 | #include <mach/map.h> |
21 | #include <mach/regs-pmu.h> | 20 | #include <mach/regs-pmu.h> |
22 | 21 | ||
@@ -104,6 +103,12 @@ static const struct of_dev_auxdata exynos5250_auxdata_lookup[] __initconst = { | |||
104 | OF_DEV_AUXDATA("samsung,mfc-v6", 0x11000000, "s5p-mfc-v6", NULL), | 103 | OF_DEV_AUXDATA("samsung,mfc-v6", 0x11000000, "s5p-mfc-v6", NULL), |
105 | OF_DEV_AUXDATA("samsung,exynos5250-tmu", 0x10060000, | 104 | OF_DEV_AUXDATA("samsung,exynos5250-tmu", 0x10060000, |
106 | "exynos-tmu", NULL), | 105 | "exynos-tmu", NULL), |
106 | OF_DEV_AUXDATA("samsung,i2s-v5", 0x03830000, | ||
107 | "samsung-i2s.0", NULL), | ||
108 | OF_DEV_AUXDATA("samsung,i2s-v5", 0x12D60000, | ||
109 | "samsung-i2s.1", NULL), | ||
110 | OF_DEV_AUXDATA("samsung,i2s-v5", 0x12D70000, | ||
111 | "samsung-i2s.2", NULL), | ||
107 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x11210000, | 112 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x11210000, |
108 | "exynos-sysmmu.0", "mfc"), /* MFC_L */ | 113 | "exynos-sysmmu.0", "mfc"), /* MFC_L */ |
109 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x11200000, | 114 | OF_DEV_AUXDATA("samsung,exynos-sysmmu", 0x11200000, |
@@ -209,10 +214,9 @@ DT_MACHINE_START(EXYNOS5_DT, "SAMSUNG EXYNOS5 (Flattened Device Tree)") | |||
209 | .init_irq = exynos5_init_irq, | 214 | .init_irq = exynos5_init_irq, |
210 | .smp = smp_ops(exynos_smp_ops), | 215 | .smp = smp_ops(exynos_smp_ops), |
211 | .map_io = exynos5_dt_map_io, | 216 | .map_io = exynos5_dt_map_io, |
212 | .handle_irq = gic_handle_irq, | ||
213 | .init_machine = exynos5_dt_machine_init, | 217 | .init_machine = exynos5_dt_machine_init, |
214 | .init_late = exynos_init_late, | 218 | .init_late = exynos_init_late, |
215 | .timer = &exynos4_timer, | 219 | .init_time = exynos4_timer_init, |
216 | .dt_compat = exynos5_dt_compat, | 220 | .dt_compat = exynos5_dt_compat, |
217 | .restart = exynos5_restart, | 221 | .restart = exynos5_restart, |
218 | .reserve = exynos5_reserve, | 222 | .reserve = exynos5_reserve, |
diff --git a/arch/arm/mach-exynos/mach-nuri.c b/arch/arm/mach-exynos/mach-nuri.c index 27d4ed8b116e..1ea79730187f 100644 --- a/arch/arm/mach-exynos/mach-nuri.c +++ b/arch/arm/mach-exynos/mach-nuri.c | |||
@@ -39,7 +39,6 @@ | |||
39 | #include <media/v4l2-mediabus.h> | 39 | #include <media/v4l2-mediabus.h> |
40 | 40 | ||
41 | #include <asm/mach/arch.h> | 41 | #include <asm/mach/arch.h> |
42 | #include <asm/hardware/gic.h> | ||
43 | #include <asm/mach-types.h> | 42 | #include <asm/mach-types.h> |
44 | 43 | ||
45 | #include <plat/adc.h> | 44 | #include <plat/adc.h> |
@@ -1209,25 +1208,25 @@ static struct i2c_board_info m5mols_board_info = { | |||
1209 | .platform_data = &m5mols_platdata, | 1208 | .platform_data = &m5mols_platdata, |
1210 | }; | 1209 | }; |
1211 | 1210 | ||
1212 | static struct s5p_fimc_isp_info nuri_camera_sensors[] = { | 1211 | static struct fimc_source_info nuri_camera_sensors[] = { |
1213 | { | 1212 | { |
1214 | .flags = V4L2_MBUS_PCLK_SAMPLE_RISING | | 1213 | .flags = V4L2_MBUS_PCLK_SAMPLE_RISING | |
1215 | V4L2_MBUS_VSYNC_ACTIVE_LOW, | 1214 | V4L2_MBUS_VSYNC_ACTIVE_LOW, |
1216 | .bus_type = FIMC_ITU_601, | 1215 | .fimc_bus_type = FIMC_BUS_TYPE_ITU_601, |
1217 | .board_info = &s5k6aa_board_info, | 1216 | .board_info = &s5k6aa_board_info, |
1218 | .clk_frequency = 24000000UL, | 1217 | .clk_frequency = 24000000UL, |
1219 | .i2c_bus_num = 6, | 1218 | .i2c_bus_num = 6, |
1220 | }, { | 1219 | }, { |
1221 | .flags = V4L2_MBUS_PCLK_SAMPLE_FALLING | | 1220 | .flags = V4L2_MBUS_PCLK_SAMPLE_FALLING | |
1222 | V4L2_MBUS_VSYNC_ACTIVE_LOW, | 1221 | V4L2_MBUS_VSYNC_ACTIVE_LOW, |
1223 | .bus_type = FIMC_MIPI_CSI2, | 1222 | .fimc_bus_type = FIMC_BUS_TYPE_MIPI_CSI2, |
1224 | .board_info = &m5mols_board_info, | 1223 | .board_info = &m5mols_board_info, |
1225 | .clk_frequency = 24000000UL, | 1224 | .clk_frequency = 24000000UL, |
1226 | }, | 1225 | }, |
1227 | }; | 1226 | }; |
1228 | 1227 | ||
1229 | static struct s5p_platform_fimc fimc_md_platdata = { | 1228 | static struct s5p_platform_fimc fimc_md_platdata = { |
1230 | .isp_info = nuri_camera_sensors, | 1229 | .source_info = nuri_camera_sensors, |
1231 | .num_clients = ARRAY_SIZE(nuri_camera_sensors), | 1230 | .num_clients = ARRAY_SIZE(nuri_camera_sensors), |
1232 | }; | 1231 | }; |
1233 | 1232 | ||
@@ -1379,10 +1378,9 @@ MACHINE_START(NURI, "NURI") | |||
1379 | .smp = smp_ops(exynos_smp_ops), | 1378 | .smp = smp_ops(exynos_smp_ops), |
1380 | .init_irq = exynos4_init_irq, | 1379 | .init_irq = exynos4_init_irq, |
1381 | .map_io = nuri_map_io, | 1380 | .map_io = nuri_map_io, |
1382 | .handle_irq = gic_handle_irq, | ||
1383 | .init_machine = nuri_machine_init, | 1381 | .init_machine = nuri_machine_init, |
1384 | .init_late = exynos_init_late, | 1382 | .init_late = exynos_init_late, |
1385 | .timer = &exynos4_timer, | 1383 | .init_time = exynos4_timer_init, |
1386 | .reserve = &nuri_reserve, | 1384 | .reserve = &nuri_reserve, |
1387 | .restart = exynos4_restart, | 1385 | .restart = exynos4_restart, |
1388 | MACHINE_END | 1386 | MACHINE_END |
diff --git a/arch/arm/mach-exynos/mach-origen.c b/arch/arm/mach-exynos/mach-origen.c index 5e34b9c16196..579d2d171daa 100644 --- a/arch/arm/mach-exynos/mach-origen.c +++ b/arch/arm/mach-exynos/mach-origen.c | |||
@@ -29,7 +29,6 @@ | |||
29 | #include <linux/platform_data/usb-exynos.h> | 29 | #include <linux/platform_data/usb-exynos.h> |
30 | 30 | ||
31 | #include <asm/mach/arch.h> | 31 | #include <asm/mach/arch.h> |
32 | #include <asm/hardware/gic.h> | ||
33 | #include <asm/mach-types.h> | 32 | #include <asm/mach-types.h> |
34 | 33 | ||
35 | #include <video/platform_lcd.h> | 34 | #include <video/platform_lcd.h> |
@@ -814,10 +813,9 @@ MACHINE_START(ORIGEN, "ORIGEN") | |||
814 | .smp = smp_ops(exynos_smp_ops), | 813 | .smp = smp_ops(exynos_smp_ops), |
815 | .init_irq = exynos4_init_irq, | 814 | .init_irq = exynos4_init_irq, |
816 | .map_io = origen_map_io, | 815 | .map_io = origen_map_io, |
817 | .handle_irq = gic_handle_irq, | ||
818 | .init_machine = origen_machine_init, | 816 | .init_machine = origen_machine_init, |
819 | .init_late = exynos_init_late, | 817 | .init_late = exynos_init_late, |
820 | .timer = &exynos4_timer, | 818 | .init_time = exynos4_timer_init, |
821 | .reserve = &origen_reserve, | 819 | .reserve = &origen_reserve, |
822 | .restart = exynos4_restart, | 820 | .restart = exynos4_restart, |
823 | MACHINE_END | 821 | MACHINE_END |
diff --git a/arch/arm/mach-exynos/mach-smdk4x12.c b/arch/arm/mach-exynos/mach-smdk4x12.c index ae6da40c2aa9..fe6149624b84 100644 --- a/arch/arm/mach-exynos/mach-smdk4x12.c +++ b/arch/arm/mach-exynos/mach-smdk4x12.c | |||
@@ -25,7 +25,6 @@ | |||
25 | #include <linux/platform_data/s3c-hsotg.h> | 25 | #include <linux/platform_data/s3c-hsotg.h> |
26 | 26 | ||
27 | #include <asm/mach/arch.h> | 27 | #include <asm/mach/arch.h> |
28 | #include <asm/hardware/gic.h> | ||
29 | #include <asm/mach-types.h> | 28 | #include <asm/mach-types.h> |
30 | 29 | ||
31 | #include <video/samsung_fimd.h> | 30 | #include <video/samsung_fimd.h> |
@@ -376,9 +375,8 @@ MACHINE_START(SMDK4212, "SMDK4212") | |||
376 | .smp = smp_ops(exynos_smp_ops), | 375 | .smp = smp_ops(exynos_smp_ops), |
377 | .init_irq = exynos4_init_irq, | 376 | .init_irq = exynos4_init_irq, |
378 | .map_io = smdk4x12_map_io, | 377 | .map_io = smdk4x12_map_io, |
379 | .handle_irq = gic_handle_irq, | ||
380 | .init_machine = smdk4x12_machine_init, | 378 | .init_machine = smdk4x12_machine_init, |
381 | .timer = &exynos4_timer, | 379 | .init_time = exynos4_timer_init, |
382 | .restart = exynos4_restart, | 380 | .restart = exynos4_restart, |
383 | .reserve = &smdk4x12_reserve, | 381 | .reserve = &smdk4x12_reserve, |
384 | MACHINE_END | 382 | MACHINE_END |
@@ -390,10 +388,9 @@ MACHINE_START(SMDK4412, "SMDK4412") | |||
390 | .smp = smp_ops(exynos_smp_ops), | 388 | .smp = smp_ops(exynos_smp_ops), |
391 | .init_irq = exynos4_init_irq, | 389 | .init_irq = exynos4_init_irq, |
392 | .map_io = smdk4x12_map_io, | 390 | .map_io = smdk4x12_map_io, |
393 | .handle_irq = gic_handle_irq, | ||
394 | .init_machine = smdk4x12_machine_init, | 391 | .init_machine = smdk4x12_machine_init, |
395 | .init_late = exynos_init_late, | 392 | .init_late = exynos_init_late, |
396 | .timer = &exynos4_timer, | 393 | .init_time = exynos4_timer_init, |
397 | .restart = exynos4_restart, | 394 | .restart = exynos4_restart, |
398 | .reserve = &smdk4x12_reserve, | 395 | .reserve = &smdk4x12_reserve, |
399 | MACHINE_END | 396 | MACHINE_END |
diff --git a/arch/arm/mach-exynos/mach-smdkv310.c b/arch/arm/mach-exynos/mach-smdkv310.c index 35548e3c097d..d71672922b19 100644 --- a/arch/arm/mach-exynos/mach-smdkv310.c +++ b/arch/arm/mach-exynos/mach-smdkv310.c | |||
@@ -26,7 +26,6 @@ | |||
26 | #include <linux/platform_data/usb-exynos.h> | 26 | #include <linux/platform_data/usb-exynos.h> |
27 | 27 | ||
28 | #include <asm/mach/arch.h> | 28 | #include <asm/mach/arch.h> |
29 | #include <asm/hardware/gic.h> | ||
30 | #include <asm/mach-types.h> | 29 | #include <asm/mach-types.h> |
31 | 30 | ||
32 | #include <video/platform_lcd.h> | 31 | #include <video/platform_lcd.h> |
@@ -423,9 +422,8 @@ MACHINE_START(SMDKV310, "SMDKV310") | |||
423 | .smp = smp_ops(exynos_smp_ops), | 422 | .smp = smp_ops(exynos_smp_ops), |
424 | .init_irq = exynos4_init_irq, | 423 | .init_irq = exynos4_init_irq, |
425 | .map_io = smdkv310_map_io, | 424 | .map_io = smdkv310_map_io, |
426 | .handle_irq = gic_handle_irq, | ||
427 | .init_machine = smdkv310_machine_init, | 425 | .init_machine = smdkv310_machine_init, |
428 | .timer = &exynos4_timer, | 426 | .init_time = exynos4_timer_init, |
429 | .reserve = &smdkv310_reserve, | 427 | .reserve = &smdkv310_reserve, |
430 | .restart = exynos4_restart, | 428 | .restart = exynos4_restart, |
431 | MACHINE_END | 429 | MACHINE_END |
@@ -436,10 +434,9 @@ MACHINE_START(SMDKC210, "SMDKC210") | |||
436 | .smp = smp_ops(exynos_smp_ops), | 434 | .smp = smp_ops(exynos_smp_ops), |
437 | .init_irq = exynos4_init_irq, | 435 | .init_irq = exynos4_init_irq, |
438 | .map_io = smdkv310_map_io, | 436 | .map_io = smdkv310_map_io, |
439 | .handle_irq = gic_handle_irq, | ||
440 | .init_machine = smdkv310_machine_init, | 437 | .init_machine = smdkv310_machine_init, |
441 | .init_late = exynos_init_late, | 438 | .init_late = exynos_init_late, |
442 | .timer = &exynos4_timer, | 439 | .init_time = exynos4_timer_init, |
443 | .reserve = &smdkv310_reserve, | 440 | .reserve = &smdkv310_reserve, |
444 | .restart = exynos4_restart, | 441 | .restart = exynos4_restart, |
445 | MACHINE_END | 442 | MACHINE_END |
diff --git a/arch/arm/mach-exynos/mach-universal_c210.c b/arch/arm/mach-exynos/mach-universal_c210.c index 9e3340f18950..497fcb793dc1 100644 --- a/arch/arm/mach-exynos/mach-universal_c210.c +++ b/arch/arm/mach-exynos/mach-universal_c210.c | |||
@@ -29,7 +29,6 @@ | |||
29 | #include <drm/exynos_drm.h> | 29 | #include <drm/exynos_drm.h> |
30 | 30 | ||
31 | #include <asm/mach/arch.h> | 31 | #include <asm/mach/arch.h> |
32 | #include <asm/hardware/gic.h> | ||
33 | #include <asm/mach-types.h> | 32 | #include <asm/mach-types.h> |
34 | 33 | ||
35 | #include <video/samsung_fimd.h> | 34 | #include <video/samsung_fimd.h> |
@@ -988,12 +987,12 @@ static struct i2c_board_info m5mols_board_info = { | |||
988 | .platform_data = &m5mols_platdata, | 987 | .platform_data = &m5mols_platdata, |
989 | }; | 988 | }; |
990 | 989 | ||
991 | static struct s5p_fimc_isp_info universal_camera_sensors[] = { | 990 | static struct fimc_source_info universal_camera_sensors[] = { |
992 | { | 991 | { |
993 | .mux_id = 0, | 992 | .mux_id = 0, |
994 | .flags = V4L2_MBUS_PCLK_SAMPLE_FALLING | | 993 | .flags = V4L2_MBUS_PCLK_SAMPLE_FALLING | |
995 | V4L2_MBUS_VSYNC_ACTIVE_LOW, | 994 | V4L2_MBUS_VSYNC_ACTIVE_LOW, |
996 | .bus_type = FIMC_ITU_601, | 995 | .fimc_bus_type = FIMC_BUS_TYPE_ITU_601, |
997 | .board_info = &s5k6aa_board_info, | 996 | .board_info = &s5k6aa_board_info, |
998 | .i2c_bus_num = 0, | 997 | .i2c_bus_num = 0, |
999 | .clk_frequency = 24000000UL, | 998 | .clk_frequency = 24000000UL, |
@@ -1001,7 +1000,7 @@ static struct s5p_fimc_isp_info universal_camera_sensors[] = { | |||
1001 | .mux_id = 0, | 1000 | .mux_id = 0, |
1002 | .flags = V4L2_MBUS_PCLK_SAMPLE_FALLING | | 1001 | .flags = V4L2_MBUS_PCLK_SAMPLE_FALLING | |
1003 | V4L2_MBUS_VSYNC_ACTIVE_LOW, | 1002 | V4L2_MBUS_VSYNC_ACTIVE_LOW, |
1004 | .bus_type = FIMC_MIPI_CSI2, | 1003 | .fimc_bus_type = FIMC_BUS_TYPE_MIPI_CSI2, |
1005 | .board_info = &m5mols_board_info, | 1004 | .board_info = &m5mols_board_info, |
1006 | .i2c_bus_num = 0, | 1005 | .i2c_bus_num = 0, |
1007 | .clk_frequency = 24000000UL, | 1006 | .clk_frequency = 24000000UL, |
@@ -1009,7 +1008,7 @@ static struct s5p_fimc_isp_info universal_camera_sensors[] = { | |||
1009 | }; | 1008 | }; |
1010 | 1009 | ||
1011 | static struct s5p_platform_fimc fimc_md_platdata = { | 1010 | static struct s5p_platform_fimc fimc_md_platdata = { |
1012 | .isp_info = universal_camera_sensors, | 1011 | .source_info = universal_camera_sensors, |
1013 | .num_clients = ARRAY_SIZE(universal_camera_sensors), | 1012 | .num_clients = ARRAY_SIZE(universal_camera_sensors), |
1014 | }; | 1013 | }; |
1015 | 1014 | ||
@@ -1151,10 +1150,9 @@ MACHINE_START(UNIVERSAL_C210, "UNIVERSAL_C210") | |||
1151 | .smp = smp_ops(exynos_smp_ops), | 1150 | .smp = smp_ops(exynos_smp_ops), |
1152 | .init_irq = exynos4_init_irq, | 1151 | .init_irq = exynos4_init_irq, |
1153 | .map_io = universal_map_io, | 1152 | .map_io = universal_map_io, |
1154 | .handle_irq = gic_handle_irq, | ||
1155 | .init_machine = universal_machine_init, | 1153 | .init_machine = universal_machine_init, |
1156 | .init_late = exynos_init_late, | 1154 | .init_late = exynos_init_late, |
1157 | .timer = &s5p_timer, | 1155 | .init_time = s5p_timer_init, |
1158 | .reserve = &universal_reserve, | 1156 | .reserve = &universal_reserve, |
1159 | .restart = exynos4_restart, | 1157 | .restart = exynos4_restart, |
1160 | MACHINE_END | 1158 | MACHINE_END |
diff --git a/arch/arm/mach-exynos/mct.c b/arch/arm/mach-exynos/mct.c index 57668eb68e75..c9d6650f9b5d 100644 --- a/arch/arm/mach-exynos/mct.c +++ b/arch/arm/mach-exynos/mct.c | |||
@@ -22,7 +22,6 @@ | |||
22 | #include <linux/of.h> | 22 | #include <linux/of.h> |
23 | 23 | ||
24 | #include <asm/arch_timer.h> | 24 | #include <asm/arch_timer.h> |
25 | #include <asm/hardware/gic.h> | ||
26 | #include <asm/localtimer.h> | 25 | #include <asm/localtimer.h> |
27 | 26 | ||
28 | #include <plat/cpu.h> | 27 | #include <plat/cpu.h> |
@@ -255,13 +254,9 @@ static struct irqaction mct_comp_event_irq = { | |||
255 | 254 | ||
256 | static void exynos4_clockevent_init(void) | 255 | static void exynos4_clockevent_init(void) |
257 | { | 256 | { |
258 | clockevents_calc_mult_shift(&mct_comp_device, clk_rate, 5); | ||
259 | mct_comp_device.max_delta_ns = | ||
260 | clockevent_delta2ns(0xffffffff, &mct_comp_device); | ||
261 | mct_comp_device.min_delta_ns = | ||
262 | clockevent_delta2ns(0xf, &mct_comp_device); | ||
263 | mct_comp_device.cpumask = cpumask_of(0); | 257 | mct_comp_device.cpumask = cpumask_of(0); |
264 | clockevents_register_device(&mct_comp_device); | 258 | clockevents_config_and_register(&mct_comp_device, clk_rate, |
259 | 0xf, 0xffffffff); | ||
265 | 260 | ||
266 | if (soc_is_exynos5250()) | 261 | if (soc_is_exynos5250()) |
267 | setup_irq(EXYNOS5_IRQ_MCT_G0, &mct_comp_event_irq); | 262 | setup_irq(EXYNOS5_IRQ_MCT_G0, &mct_comp_event_irq); |
@@ -404,14 +399,8 @@ static int __cpuinit exynos4_local_timer_setup(struct clock_event_device *evt) | |||
404 | evt->set_mode = exynos4_tick_set_mode; | 399 | evt->set_mode = exynos4_tick_set_mode; |
405 | evt->features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT; | 400 | evt->features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT; |
406 | evt->rating = 450; | 401 | evt->rating = 450; |
407 | 402 | clockevents_config_and_register(evt, clk_rate / (TICK_BASE_CNT + 1), | |
408 | clockevents_calc_mult_shift(evt, clk_rate / (TICK_BASE_CNT + 1), 5); | 403 | 0xf, 0x7fffffff); |
409 | evt->max_delta_ns = | ||
410 | clockevent_delta2ns(0x7fffffff, evt); | ||
411 | evt->min_delta_ns = | ||
412 | clockevent_delta2ns(0xf, evt); | ||
413 | |||
414 | clockevents_register_device(evt); | ||
415 | 404 | ||
416 | exynos4_mct_write(TICK_BASE_CNT, mevt->base + MCT_L_TCNTB_OFFSET); | 405 | exynos4_mct_write(TICK_BASE_CNT, mevt->base + MCT_L_TCNTB_OFFSET); |
417 | 406 | ||
@@ -478,7 +467,7 @@ static void __init exynos4_timer_resources(void) | |||
478 | #endif /* CONFIG_LOCAL_TIMERS */ | 467 | #endif /* CONFIG_LOCAL_TIMERS */ |
479 | } | 468 | } |
480 | 469 | ||
481 | static void __init exynos_timer_init(void) | 470 | void __init exynos4_timer_init(void) |
482 | { | 471 | { |
483 | if (soc_is_exynos5440()) { | 472 | if (soc_is_exynos5440()) { |
484 | arch_timer_of_register(); | 473 | arch_timer_of_register(); |
@@ -494,7 +483,3 @@ static void __init exynos_timer_init(void) | |||
494 | exynos4_clocksource_init(); | 483 | exynos4_clocksource_init(); |
495 | exynos4_clockevent_init(); | 484 | exynos4_clockevent_init(); |
496 | } | 485 | } |
497 | |||
498 | struct sys_timer exynos4_timer = { | ||
499 | .init = exynos_timer_init, | ||
500 | }; | ||
diff --git a/arch/arm/mach-exynos/platsmp.c b/arch/arm/mach-exynos/platsmp.c index c5c840e947b8..60f7c5be057d 100644 --- a/arch/arm/mach-exynos/platsmp.c +++ b/arch/arm/mach-exynos/platsmp.c | |||
@@ -20,9 +20,9 @@ | |||
20 | #include <linux/jiffies.h> | 20 | #include <linux/jiffies.h> |
21 | #include <linux/smp.h> | 21 | #include <linux/smp.h> |
22 | #include <linux/io.h> | 22 | #include <linux/io.h> |
23 | #include <linux/irqchip/arm-gic.h> | ||
23 | 24 | ||
24 | #include <asm/cacheflush.h> | 25 | #include <asm/cacheflush.h> |
25 | #include <asm/hardware/gic.h> | ||
26 | #include <asm/smp_plat.h> | 26 | #include <asm/smp_plat.h> |
27 | #include <asm/smp_scu.h> | 27 | #include <asm/smp_scu.h> |
28 | 28 | ||
@@ -149,7 +149,7 @@ static int __cpuinit exynos_boot_secondary(unsigned int cpu, struct task_struct | |||
149 | 149 | ||
150 | __raw_writel(virt_to_phys(exynos4_secondary_startup), | 150 | __raw_writel(virt_to_phys(exynos4_secondary_startup), |
151 | cpu_boot_reg(phys_cpu)); | 151 | cpu_boot_reg(phys_cpu)); |
152 | gic_raise_softirq(cpumask_of(cpu), 0); | 152 | arch_send_wakeup_ipi_mask(cpumask_of(cpu)); |
153 | 153 | ||
154 | if (pen_release == -1) | 154 | if (pen_release == -1) |
155 | break; | 155 | break; |
@@ -190,8 +190,6 @@ static void __init exynos_smp_init_cpus(void) | |||
190 | 190 | ||
191 | for (i = 0; i < ncores; i++) | 191 | for (i = 0; i < ncores; i++) |
192 | set_cpu_possible(i, true); | 192 | set_cpu_possible(i, true); |
193 | |||
194 | set_smp_cross_call(gic_raise_softirq); | ||
195 | } | 193 | } |
196 | 194 | ||
197 | static void __init exynos_smp_prepare_cpus(unsigned int max_cpus) | 195 | static void __init exynos_smp_prepare_cpus(unsigned int max_cpus) |
diff --git a/arch/arm/mach-exynos/pm.c b/arch/arm/mach-exynos/pm.c index b9b539cac81e..e3faaa812016 100644 --- a/arch/arm/mach-exynos/pm.c +++ b/arch/arm/mach-exynos/pm.c | |||
@@ -34,7 +34,8 @@ | |||
34 | #include <mach/regs-clock.h> | 34 | #include <mach/regs-clock.h> |
35 | #include <mach/regs-pmu.h> | 35 | #include <mach/regs-pmu.h> |
36 | #include <mach/pm-core.h> | 36 | #include <mach/pm-core.h> |
37 | #include <mach/pmu.h> | 37 | |
38 | #include "common.h" | ||
38 | 39 | ||
39 | static struct sleep_save exynos4_set_clksrc[] = { | 40 | static struct sleep_save exynos4_set_clksrc[] = { |
40 | { .reg = EXYNOS4_CLKSRC_MASK_TOP , .val = 0x00000001, }, | 41 | { .reg = EXYNOS4_CLKSRC_MASK_TOP , .val = 0x00000001, }, |
@@ -91,8 +92,8 @@ static int exynos_cpu_suspend(unsigned long arg) | |||
91 | /* issue the standby signal into the pm unit. */ | 92 | /* issue the standby signal into the pm unit. */ |
92 | cpu_do_idle(); | 93 | cpu_do_idle(); |
93 | 94 | ||
94 | /* we should never get past here */ | 95 | pr_info("Failed to suspend the system\n"); |
95 | panic("sleep resumed to originator?"); | 96 | return 1; /* Aborting suspend */ |
96 | } | 97 | } |
97 | 98 | ||
98 | static void exynos_pm_prepare(void) | 99 | static void exynos_pm_prepare(void) |
@@ -282,6 +283,8 @@ static void exynos_pm_resume(void) | |||
282 | if (!(tmp & S5P_CENTRAL_LOWPWR_CFG)) { | 283 | if (!(tmp & S5P_CENTRAL_LOWPWR_CFG)) { |
283 | tmp |= S5P_CENTRAL_LOWPWR_CFG; | 284 | tmp |= S5P_CENTRAL_LOWPWR_CFG; |
284 | __raw_writel(tmp, S5P_CENTRAL_SEQ_CONFIGURATION); | 285 | __raw_writel(tmp, S5P_CENTRAL_SEQ_CONFIGURATION); |
286 | /* clear the wakeup state register */ | ||
287 | __raw_writel(0x0, S5P_WAKEUP_STAT); | ||
285 | /* No need to perform below restore code */ | 288 | /* No need to perform below restore code */ |
286 | goto early_wakeup; | 289 | goto early_wakeup; |
287 | } | 290 | } |
diff --git a/arch/arm/mach-exynos/pmu.c b/arch/arm/mach-exynos/pmu.c index 3a48c852be6c..daebc1abc966 100644 --- a/arch/arm/mach-exynos/pmu.c +++ b/arch/arm/mach-exynos/pmu.c | |||
@@ -14,7 +14,8 @@ | |||
14 | #include <linux/bug.h> | 14 | #include <linux/bug.h> |
15 | 15 | ||
16 | #include <mach/regs-clock.h> | 16 | #include <mach/regs-clock.h> |
17 | #include <mach/pmu.h> | 17 | |
18 | #include "common.h" | ||
18 | 19 | ||
19 | static struct exynos_pmu_conf *exynos_pmu_config; | 20 | static struct exynos_pmu_conf *exynos_pmu_config; |
20 | 21 | ||