Merge branch 'driver-core-next' of git://git.kernel.org/pub/scm/linux/kernel/git...
authorLinus Torvalds <torvalds@linux-foundation.org>
Sat, 7 Jan 2012 20:03:30 +0000 (12:03 -0800)
committerLinus Torvalds <torvalds@linux-foundation.org>
Sat, 7 Jan 2012 20:03:30 +0000 (12:03 -0800)
* 'driver-core-next' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/driver-core: (73 commits)
  arm: fix up some samsung merge sysdev conversion problems
  firmware: Fix an oops on reading fw_priv->fw in sysfs loading file
  Drivers:hv: Fix a bug in vmbus_driver_unregister()
  driver core: remove __must_check from device_create_file
  debugfs: add missing #ifdef HAS_IOMEM
  arm: time.h: remove device.h #include
  driver-core: remove sysdev.h usage.
  clockevents: remove sysdev.h
  arm: convert sysdev_class to a regular subsystem
  arm: leds: convert sysdev_class to a regular subsystem
  kobject: remove kset_find_obj_hinted()
  m86k: gpio - convert sysdev_class to a regular subsystem
  mips: txx9_sram - convert sysdev_class to a regular subsystem
  mips: 7segled - convert sysdev_class to a regular subsystem
  sh: dma - convert sysdev_class to a regular subsystem
  sh: intc - convert sysdev_class to a regular subsystem
  power: suspend - convert sysdev_class to a regular subsystem
  power: qe_ic - convert sysdev_class to a regular subsystem
  power: cmm - convert sysdev_class to a regular subsystem
  s390: time - convert sysdev_class to a regular subsystem
  ...

Fix up conflicts with 'struct sysdev' removal from various platform
drivers that got changed:
 - arch/arm/mach-exynos/cpu.c
 - arch/arm/mach-exynos/irq-eint.c
 - arch/arm/mach-s3c64xx/common.c
 - arch/arm/mach-s3c64xx/cpu.c
 - arch/arm/mach-s5p64x0/cpu.c
 - arch/arm/mach-s5pv210/common.c
 - arch/arm/plat-samsung/include/plat/cpu.h
 - arch/powerpc/kernel/sysfs.c
and fix up cpu_is_hotpluggable() as per Greg in include/linux/cpu.h

66 files changed:
1  2 
MAINTAINERS
arch/arm/mach-exynos/common.c
arch/arm/mach-integrator/integrator_cp.c
arch/arm/mach-lpc32xx/phy3250.c
arch/arm/mach-realview/realview_eb.c
arch/arm/mach-realview/realview_pb1176.c
arch/arm/mach-realview/realview_pb11mp.c
arch/arm/mach-realview/realview_pba8.c
arch/arm/mach-realview/realview_pbx.c
arch/arm/mach-s3c2410/mach-h1940.c
arch/arm/mach-s3c2410/mach-qt2410.c
arch/arm/mach-s3c2410/s3c2410.c
arch/arm/mach-s3c2412/s3c2412.c
arch/arm/mach-s3c2416/s3c2416.c
arch/arm/mach-s3c2440/mach-rx1950.c
arch/arm/mach-s3c2440/mach-rx3715.c
arch/arm/mach-s3c2440/s3c2440.c
arch/arm/mach-s3c2443/s3c2443.c
arch/arm/mach-s3c64xx/common.c
arch/arm/mach-s3c64xx/common.h
arch/arm/mach-s3c64xx/s3c6400.c
arch/arm/mach-s3c64xx/s3c6410.c
arch/arm/mach-s5p64x0/clock-s5p6440.c
arch/arm/mach-s5p64x0/clock-s5p6450.c
arch/arm/mach-s5p64x0/clock.c
arch/arm/mach-s5p64x0/common.c
arch/arm/mach-s5pc100/common.c
arch/arm/mach-s5pv210/clock.c
arch/arm/mach-s5pv210/common.c
arch/arm/mach-s5pv210/mach-smdkc110.c
arch/arm/mach-s5pv210/mach-smdkv210.c
arch/arm/mach-versatile/core.c
arch/arm/mach-versatile/versatile_ab.c
arch/arm/mach-versatile/versatile_pb.c
arch/arm/mach-vexpress/v2m.c
arch/arm/mach-w90x900/irq.c
arch/arm/plat-samsung/include/plat/cpu.h
arch/powerpc/kernel/smp.c
arch/powerpc/kernel/sysfs.c
arch/powerpc/mm/numa.c
arch/powerpc/platforms/pseries/smp.c
arch/x86/include/asm/mce.h
arch/x86/kernel/cpu/mcheck/mce.c
arch/x86/kernel/cpu/mcheck/mce_amd.c
arch/x86/kernel/cpu/mcheck/therm_throt.c
arch/x86/kernel/hpet.c
arch/x86/kernel/microcode_core.c
drivers/base/cpu.c
drivers/bluetooth/ath3k.c
drivers/bluetooth/bfusb.c
drivers/bluetooth/btusb.c
drivers/cpufreq/cpufreq_stats.c
drivers/net/usb/asix.c
drivers/net/usb/cdc-phonet.c
drivers/net/usb/cdc_ncm.c
drivers/net/usb/smsc75xx.c
drivers/net/usb/smsc95xx.c
drivers/net/wireless/rndis_wlan.c
drivers/net/wireless/rt2x00/rt2500usb.c
drivers/net/wireless/rt2x00/rt2800usb.c
drivers/net/wireless/rt2x00/rt73usb.c
drivers/net/wireless/rtlwifi/rtl8192cu/sw.c
drivers/nfc/pn533.c
include/linux/cpu.h
kernel/sched/core.c
lib/Makefile

diff --cc MAINTAINERS
Simple merge
index d2acb0f948c6c6ad40ef7e2448d76f0b8271fefd,0000000000000000000000000000000000000000..b6ac6ee658c068fb8ee28f64894bff7421d87a51
mode 100644,000000..100644
--- /dev/null
@@@ -1,713 -1,0 +1,714 @@@
- #include <linux/sysdev.h>
 +/*
 + * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd.
 + *            http://www.samsung.com
 + *
 + * Common Codes for EXYNOS
 + *
 + * This program is free software; you can redistribute it and/or modify
 + * it under the terms of the GNU General Public License version 2 as
 + * published by the Free Software Foundation.
 + */
 +
 +#include <linux/kernel.h>
 +#include <linux/interrupt.h>
 +#include <linux/irq.h>
 +#include <linux/io.h>
- struct sysdev_class exynos4_sysclass = {
-       .name   = "exynos4-core",
++#include <linux/device.h>
 +#include <linux/gpio.h>
 +#include <linux/sched.h>
 +#include <linux/serial_core.h>
 +
 +#include <asm/proc-fns.h>
 +#include <asm/hardware/cache-l2x0.h>
 +#include <asm/hardware/gic.h>
 +#include <asm/mach/map.h>
 +#include <asm/mach/irq.h>
 +
 +#include <mach/regs-irq.h>
 +#include <mach/regs-pmu.h>
 +#include <mach/regs-gpio.h>
 +
 +#include <plat/cpu.h>
 +#include <plat/clock.h>
 +#include <plat/devs.h>
 +#include <plat/pm.h>
 +#include <plat/sdhci.h>
 +#include <plat/gpio-cfg.h>
 +#include <plat/adc-core.h>
 +#include <plat/fb-core.h>
 +#include <plat/fimc-core.h>
 +#include <plat/iic-core.h>
 +#include <plat/tv-core.h>
 +#include <plat/regs-serial.h>
 +
 +#include "common.h"
 +
 +unsigned int gic_bank_offset __read_mostly;
 +
 +static const char name_exynos4210[] = "EXYNOS4210";
 +static const char name_exynos4212[] = "EXYNOS4212";
 +static const char name_exynos4412[] = "EXYNOS4412";
 +
 +static struct cpu_table cpu_ids[] __initdata = {
 +      {
 +              .idcode         = EXYNOS4210_CPU_ID,
 +              .idmask         = EXYNOS4_CPU_MASK,
 +              .map_io         = exynos4_map_io,
 +              .init_clocks    = exynos4_init_clocks,
 +              .init_uarts     = exynos4_init_uarts,
 +              .init           = exynos_init,
 +              .name           = name_exynos4210,
 +      }, {
 +              .idcode         = EXYNOS4212_CPU_ID,
 +              .idmask         = EXYNOS4_CPU_MASK,
 +              .map_io         = exynos4_map_io,
 +              .init_clocks    = exynos4_init_clocks,
 +              .init_uarts     = exynos4_init_uarts,
 +              .init           = exynos_init,
 +              .name           = name_exynos4212,
 +      }, {
 +              .idcode         = EXYNOS4412_CPU_ID,
 +              .idmask         = EXYNOS4_CPU_MASK,
 +              .map_io         = exynos4_map_io,
 +              .init_clocks    = exynos4_init_clocks,
 +              .init_uarts     = exynos4_init_uarts,
 +              .init           = exynos_init,
 +              .name           = name_exynos4412,
 +      },
 +};
 +
 +/* Initial IO mappings */
 +
 +static struct map_desc exynos_iodesc[] __initdata = {
 +      {
 +              .virtual        = (unsigned long)S5P_VA_CHIPID,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_CHIPID),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S3C_VA_SYS,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_SYSCON),
 +              .length         = SZ_64K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S3C_VA_TIMER,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_TIMER),
 +              .length         = SZ_16K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S3C_VA_WATCHDOG,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_WATCHDOG),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S5P_VA_SROMC,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_SROMC),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S5P_VA_SYSTIMER,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_SYSTIMER),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S5P_VA_PMU,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_PMU),
 +              .length         = SZ_64K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S5P_VA_COMBINER_BASE,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_COMBINER),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S5P_VA_GIC_CPU,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_GIC_CPU),
 +              .length         = SZ_64K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S5P_VA_GIC_DIST,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_GIC_DIST),
 +              .length         = SZ_64K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S3C_VA_UART,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_UART),
 +              .length         = SZ_512K,
 +              .type           = MT_DEVICE,
 +      },
 +};
 +
 +static struct map_desc exynos4_iodesc[] __initdata = {
 +      {
 +              .virtual        = (unsigned long)S5P_VA_CMU,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_CMU),
 +              .length         = SZ_128K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S5P_VA_COREPERI_BASE,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_COREPERI),
 +              .length         = SZ_8K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S5P_VA_L2CC,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_L2CC),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S5P_VA_GPIO1,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_GPIO1),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S5P_VA_GPIO2,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_GPIO2),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S5P_VA_GPIO3,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_GPIO3),
 +              .length         = SZ_256,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S5P_VA_DMC0,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_DMC0),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S3C_VA_USB_HSPHY,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_HSPHY),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      },
 +};
 +
 +static struct map_desc exynos4_iodesc0[] __initdata = {
 +      {
 +              .virtual        = (unsigned long)S5P_VA_SYSRAM,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_SYSRAM0),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      },
 +};
 +
 +static struct map_desc exynos4_iodesc1[] __initdata = {
 +      {
 +              .virtual        = (unsigned long)S5P_VA_SYSRAM,
 +              .pfn            = __phys_to_pfn(EXYNOS4_PA_SYSRAM1),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      },
 +};
 +
 +static void exynos_idle(void)
 +{
 +      if (!need_resched())
 +              cpu_do_idle();
 +
 +      local_irq_enable();
 +}
 +
 +void exynos4_restart(char mode, const char *cmd)
 +{
 +      __raw_writel(0x1, S5P_SWRESET);
 +}
 +
 +/*
 + * exynos_map_io
 + *
 + * register the standard cpu IO areas
 + */
 +
 +void __init exynos_init_io(struct map_desc *mach_desc, int size)
 +{
 +      /* initialize the io descriptors we need for initialization */
 +      iotable_init(exynos_iodesc, ARRAY_SIZE(exynos_iodesc));
 +      if (mach_desc)
 +              iotable_init(mach_desc, size);
 +
 +      /* detect cpu id and rev. */
 +      s5p_init_cpu(S5P_VA_CHIPID);
 +
 +      s3c_init_cpu(samsung_cpu_id, cpu_ids, ARRAY_SIZE(cpu_ids));
 +}
 +
 +void __init exynos4_map_io(void)
 +{
 +      iotable_init(exynos4_iodesc, ARRAY_SIZE(exynos4_iodesc));
 +
 +      if (soc_is_exynos4210() && samsung_rev() == EXYNOS4210_REV_0)
 +              iotable_init(exynos4_iodesc0, ARRAY_SIZE(exynos4_iodesc0));
 +      else
 +              iotable_init(exynos4_iodesc1, ARRAY_SIZE(exynos4_iodesc1));
 +
 +      /* initialize device information early */
 +      exynos4_default_sdhci0();
 +      exynos4_default_sdhci1();
 +      exynos4_default_sdhci2();
 +      exynos4_default_sdhci3();
 +
 +      s3c_adc_setname("samsung-adc-v3");
 +
 +      s3c_fimc_setname(0, "exynos4-fimc");
 +      s3c_fimc_setname(1, "exynos4-fimc");
 +      s3c_fimc_setname(2, "exynos4-fimc");
 +      s3c_fimc_setname(3, "exynos4-fimc");
 +
 +      /* The I2C bus controllers are directly compatible with s3c2440 */
 +      s3c_i2c0_setname("s3c2440-i2c");
 +      s3c_i2c1_setname("s3c2440-i2c");
 +      s3c_i2c2_setname("s3c2440-i2c");
 +
 +      s5p_fb_setname(0, "exynos4-fb");
 +      s5p_hdmi_setname("exynos4-hdmi");
 +}
 +
 +void __init exynos4_init_clocks(int xtal)
 +{
 +      printk(KERN_DEBUG "%s: initializing clocks\n", __func__);
 +
 +      s3c24xx_register_baseclocks(xtal);
 +      s5p_register_clocks(xtal);
 +
 +      if (soc_is_exynos4210())
 +              exynos4210_register_clocks();
 +      else if (soc_is_exynos4212() || soc_is_exynos4412())
 +              exynos4212_register_clocks();
 +
 +      exynos4_register_clocks();
 +      exynos4_setup_clocks();
 +}
 +
 +#define COMBINER_ENABLE_SET   0x0
 +#define COMBINER_ENABLE_CLEAR 0x4
 +#define COMBINER_INT_STATUS   0xC
 +
 +static DEFINE_SPINLOCK(irq_controller_lock);
 +
 +struct combiner_chip_data {
 +      unsigned int irq_offset;
 +      unsigned int irq_mask;
 +      void __iomem *base;
 +};
 +
 +static struct combiner_chip_data combiner_data[MAX_COMBINER_NR];
 +
 +static inline void __iomem *combiner_base(struct irq_data *data)
 +{
 +      struct combiner_chip_data *combiner_data =
 +              irq_data_get_irq_chip_data(data);
 +
 +      return combiner_data->base;
 +}
 +
 +static void combiner_mask_irq(struct irq_data *data)
 +{
 +      u32 mask = 1 << (data->irq % 32);
 +
 +      __raw_writel(mask, combiner_base(data) + COMBINER_ENABLE_CLEAR);
 +}
 +
 +static void combiner_unmask_irq(struct irq_data *data)
 +{
 +      u32 mask = 1 << (data->irq % 32);
 +
 +      __raw_writel(mask, combiner_base(data) + COMBINER_ENABLE_SET);
 +}
 +
 +static void combiner_handle_cascade_irq(unsigned int irq, struct irq_desc *desc)
 +{
 +      struct combiner_chip_data *chip_data = irq_get_handler_data(irq);
 +      struct irq_chip *chip = irq_get_chip(irq);
 +      unsigned int cascade_irq, combiner_irq;
 +      unsigned long status;
 +
 +      chained_irq_enter(chip, desc);
 +
 +      spin_lock(&irq_controller_lock);
 +      status = __raw_readl(chip_data->base + COMBINER_INT_STATUS);
 +      spin_unlock(&irq_controller_lock);
 +      status &= chip_data->irq_mask;
 +
 +      if (status == 0)
 +              goto out;
 +
 +      combiner_irq = __ffs(status);
 +
 +      cascade_irq = combiner_irq + (chip_data->irq_offset & ~31);
 +      if (unlikely(cascade_irq >= NR_IRQS))
 +              do_bad_IRQ(cascade_irq, desc);
 +      else
 +              generic_handle_irq(cascade_irq);
 +
 + out:
 +      chained_irq_exit(chip, desc);
 +}
 +
 +static struct irq_chip combiner_chip = {
 +      .name           = "COMBINER",
 +      .irq_mask       = combiner_mask_irq,
 +      .irq_unmask     = combiner_unmask_irq,
 +};
 +
 +static void __init combiner_cascade_irq(unsigned int combiner_nr, unsigned int irq)
 +{
 +      if (combiner_nr >= MAX_COMBINER_NR)
 +              BUG();
 +      if (irq_set_handler_data(irq, &combiner_data[combiner_nr]) != 0)
 +              BUG();
 +      irq_set_chained_handler(irq, combiner_handle_cascade_irq);
 +}
 +
 +static void __init combiner_init(unsigned int combiner_nr, void __iomem *base,
 +                        unsigned int irq_start)
 +{
 +      unsigned int i;
 +
 +      if (combiner_nr >= MAX_COMBINER_NR)
 +              BUG();
 +
 +      combiner_data[combiner_nr].base = base;
 +      combiner_data[combiner_nr].irq_offset = irq_start;
 +      combiner_data[combiner_nr].irq_mask = 0xff << ((combiner_nr % 4) << 3);
 +
 +      /* Disable all interrupts */
 +
 +      __raw_writel(combiner_data[combiner_nr].irq_mask,
 +                   base + COMBINER_ENABLE_CLEAR);
 +
 +      /* Setup the Linux IRQ subsystem */
 +
 +      for (i = irq_start; i < combiner_data[combiner_nr].irq_offset
 +                              + MAX_IRQ_IN_COMBINER; i++) {
 +              irq_set_chip_and_handler(i, &combiner_chip, handle_level_irq);
 +              irq_set_chip_data(i, &combiner_data[combiner_nr]);
 +              set_irq_flags(i, IRQF_VALID | IRQF_PROBE);
 +      }
 +}
 +
 +static void exynos4_gic_irq_fix_base(struct irq_data *d)
 +{
 +      struct gic_chip_data *gic_data = irq_data_get_irq_chip_data(d);
 +
 +      gic_data->cpu_base = S5P_VA_GIC_CPU +
 +                          (gic_bank_offset * smp_processor_id());
 +
 +      gic_data->dist_base = S5P_VA_GIC_DIST +
 +                          (gic_bank_offset * smp_processor_id());
 +}
 +
 +void __init exynos4_init_irq(void)
 +{
 +      int irq;
 +
 +      gic_bank_offset = soc_is_exynos4412() ? 0x4000 : 0x8000;
 +
 +      gic_init(0, IRQ_PPI(0), S5P_VA_GIC_DIST, S5P_VA_GIC_CPU);
 +      gic_arch_extn.irq_eoi = exynos4_gic_irq_fix_base;
 +      gic_arch_extn.irq_unmask = exynos4_gic_irq_fix_base;
 +      gic_arch_extn.irq_mask = exynos4_gic_irq_fix_base;
 +
 +      for (irq = 0; irq < MAX_COMBINER_NR; irq++) {
 +
 +              combiner_init(irq, (void __iomem *)S5P_VA_COMBINER(irq),
 +                              COMBINER_IRQ(irq, 0));
 +              combiner_cascade_irq(irq, IRQ_SPI(irq));
 +      }
 +
 +      /*
 +       * The parameters of s5p_init_irq() are for VIC init.
 +       * Theses parameters should be NULL and 0 because EXYNOS4
 +       * uses GIC instead of VIC.
 +       */
 +      s5p_init_irq(NULL, 0);
 +}
 +
- static struct sys_device exynos4_sysdev = {
-       .cls    = &exynos4_sysclass,
++struct bus_type exynos4_subsys = {
++      .name           = "exynos4-core",
++      .dev_name       = "exynos4-core",
 +};
 +
-       return sysdev_class_register(&exynos4_sysclass);
++static struct device exynos4_dev = {
++      .bus    = &exynos4_subsys,
 +};
 +
 +static int __init exynos4_core_init(void)
 +{
-       return sysdev_register(&exynos4_sysdev);
++      return subsys_system_register(&exynos4_subsys, NULL);
 +}
 +core_initcall(exynos4_core_init);
 +
 +#ifdef CONFIG_CACHE_L2X0
 +static int __init exynos4_l2x0_cache_init(void)
 +{
 +      /* TAG, Data Latency Control: 2cycle */
 +      __raw_writel(0x110, S5P_VA_L2CC + L2X0_TAG_LATENCY_CTRL);
 +
 +      if (soc_is_exynos4210())
 +              __raw_writel(0x110, S5P_VA_L2CC + L2X0_DATA_LATENCY_CTRL);
 +      else if (soc_is_exynos4212() || soc_is_exynos4412())
 +              __raw_writel(0x120, S5P_VA_L2CC + L2X0_DATA_LATENCY_CTRL);
 +
 +      /* L2X0 Prefetch Control */
 +      __raw_writel(0x30000007, S5P_VA_L2CC + L2X0_PREFETCH_CTRL);
 +
 +      /* L2X0 Power Control */
 +      __raw_writel(L2X0_DYNAMIC_CLK_GATING_EN | L2X0_STNDBY_MODE_EN,
 +                   S5P_VA_L2CC + L2X0_POWER_CTRL);
 +
 +      l2x0_init(S5P_VA_L2CC, 0x7C470001, 0xC200ffff);
 +
 +      return 0;
 +}
 +
 +early_initcall(exynos4_l2x0_cache_init);
 +#endif
 +
 +int __init exynos_init(void)
 +{
 +      printk(KERN_INFO "EXYNOS: Initializing architecture\n");
 +
 +      /* set idle function */
 +      pm_idle = exynos_idle;
 +
++      return device_register(&exynos4_dev);
 +}
 +
 +static struct s3c24xx_uart_clksrc exynos4_serial_clocks[] = {
 +      [0] = {
 +              .name           = "uclk1",
 +              .divisor        = 1,
 +              .min_baud       = 0,
 +              .max_baud       = 0,
 +      },
 +};
 +
 +/* uart registration process */
 +
 +void __init exynos4_init_uarts(struct s3c2410_uartcfg *cfg, int no)
 +{
 +      struct s3c2410_uartcfg *tcfg = cfg;
 +      u32 ucnt;
 +
 +      for (ucnt = 0; ucnt < no; ucnt++, tcfg++) {
 +              if (!tcfg->clocks) {
 +                      tcfg->has_fracval = 1;
 +                      tcfg->clocks = exynos4_serial_clocks;
 +                      tcfg->clocks_size = ARRAY_SIZE(exynos4_serial_clocks);
 +              }
 +              tcfg->flags |= NO_NEED_CHECK_CLKSRC;
 +      }
 +
 +      s3c24xx_init_uartdevs("s5pv210-uart", s5p_uart_resources, cfg, no);
 +}
 +
 +static DEFINE_SPINLOCK(eint_lock);
 +
 +static unsigned int eint0_15_data[16];
 +
 +static unsigned int exynos4_get_irq_nr(unsigned int number)
 +{
 +      u32 ret = 0;
 +
 +      switch (number) {
 +      case 0 ... 3:
 +              ret = (number + IRQ_EINT0);
 +              break;
 +      case 4 ... 7:
 +              ret = (number + (IRQ_EINT4 - 4));
 +              break;
 +      case 8 ... 15:
 +              ret = (number + (IRQ_EINT8 - 8));
 +              break;
 +      default:
 +              printk(KERN_ERR "number available : %d\n", number);
 +      }
 +
 +      return ret;
 +}
 +
 +static inline void exynos4_irq_eint_mask(struct irq_data *data)
 +{
 +      u32 mask;
 +
 +      spin_lock(&eint_lock);
 +      mask = __raw_readl(S5P_EINT_MASK(EINT_REG_NR(data->irq)));
 +      mask |= eint_irq_to_bit(data->irq);
 +      __raw_writel(mask, S5P_EINT_MASK(EINT_REG_NR(data->irq)));
 +      spin_unlock(&eint_lock);
 +}
 +
 +static void exynos4_irq_eint_unmask(struct irq_data *data)
 +{
 +      u32 mask;
 +
 +      spin_lock(&eint_lock);
 +      mask = __raw_readl(S5P_EINT_MASK(EINT_REG_NR(data->irq)));
 +      mask &= ~(eint_irq_to_bit(data->irq));
 +      __raw_writel(mask, S5P_EINT_MASK(EINT_REG_NR(data->irq)));
 +      spin_unlock(&eint_lock);
 +}
 +
 +static inline void exynos4_irq_eint_ack(struct irq_data *data)
 +{
 +      __raw_writel(eint_irq_to_bit(data->irq),
 +                   S5P_EINT_PEND(EINT_REG_NR(data->irq)));
 +}
 +
 +static void exynos4_irq_eint_maskack(struct irq_data *data)
 +{
 +      exynos4_irq_eint_mask(data);
 +      exynos4_irq_eint_ack(data);
 +}
 +
 +static int exynos4_irq_eint_set_type(struct irq_data *data, unsigned int type)
 +{
 +      int offs = EINT_OFFSET(data->irq);
 +      int shift;
 +      u32 ctrl, mask;
 +      u32 newvalue = 0;
 +
 +      switch (type) {
 +      case IRQ_TYPE_EDGE_RISING:
 +              newvalue = S5P_IRQ_TYPE_EDGE_RISING;
 +              break;
 +
 +      case IRQ_TYPE_EDGE_FALLING:
 +              newvalue = S5P_IRQ_TYPE_EDGE_FALLING;
 +              break;
 +
 +      case IRQ_TYPE_EDGE_BOTH:
 +              newvalue = S5P_IRQ_TYPE_EDGE_BOTH;
 +              break;
 +
 +      case IRQ_TYPE_LEVEL_LOW:
 +              newvalue = S5P_IRQ_TYPE_LEVEL_LOW;
 +              break;
 +
 +      case IRQ_TYPE_LEVEL_HIGH:
 +              newvalue = S5P_IRQ_TYPE_LEVEL_HIGH;
 +              break;
 +
 +      default:
 +              printk(KERN_ERR "No such irq type %d", type);
 +              return -EINVAL;
 +      }
 +
 +      shift = (offs & 0x7) * 4;
 +      mask = 0x7 << shift;
 +
 +      spin_lock(&eint_lock);
 +      ctrl = __raw_readl(S5P_EINT_CON(EINT_REG_NR(data->irq)));
 +      ctrl &= ~mask;
 +      ctrl |= newvalue << shift;
 +      __raw_writel(ctrl, S5P_EINT_CON(EINT_REG_NR(data->irq)));
 +      spin_unlock(&eint_lock);
 +
 +      switch (offs) {
 +      case 0 ... 7:
 +              s3c_gpio_cfgpin(EINT_GPIO_0(offs & 0x7), EINT_MODE);
 +              break;
 +      case 8 ... 15:
 +              s3c_gpio_cfgpin(EINT_GPIO_1(offs & 0x7), EINT_MODE);
 +              break;
 +      case 16 ... 23:
 +              s3c_gpio_cfgpin(EINT_GPIO_2(offs & 0x7), EINT_MODE);
 +              break;
 +      case 24 ... 31:
 +              s3c_gpio_cfgpin(EINT_GPIO_3(offs & 0x7), EINT_MODE);
 +              break;
 +      default:
 +              printk(KERN_ERR "No such irq number %d", offs);
 +      }
 +
 +      return 0;
 +}
 +
 +static struct irq_chip exynos4_irq_eint = {
 +      .name           = "exynos4-eint",
 +      .irq_mask       = exynos4_irq_eint_mask,
 +      .irq_unmask     = exynos4_irq_eint_unmask,
 +      .irq_mask_ack   = exynos4_irq_eint_maskack,
 +      .irq_ack        = exynos4_irq_eint_ack,
 +      .irq_set_type   = exynos4_irq_eint_set_type,
 +#ifdef CONFIG_PM
 +      .irq_set_wake   = s3c_irqext_wake,
 +#endif
 +};
 +
 +/*
 + * exynos4_irq_demux_eint
 + *
 + * This function demuxes the IRQ from from EINTs 16 to 31.
 + * It is designed to be inlined into the specific handler
 + * s5p_irq_demux_eintX_Y.
 + *
 + * Each EINT pend/mask registers handle eight of them.
 + */
 +static inline void exynos4_irq_demux_eint(unsigned int start)
 +{
 +      unsigned int irq;
 +
 +      u32 status = __raw_readl(S5P_EINT_PEND(EINT_REG_NR(start)));
 +      u32 mask = __raw_readl(S5P_EINT_MASK(EINT_REG_NR(start)));
 +
 +      status &= ~mask;
 +      status &= 0xff;
 +
 +      while (status) {
 +              irq = fls(status) - 1;
 +              generic_handle_irq(irq + start);
 +              status &= ~(1 << irq);
 +      }
 +}
 +
 +static void exynos4_irq_demux_eint16_31(unsigned int irq, struct irq_desc *desc)
 +{
 +      struct irq_chip *chip = irq_get_chip(irq);
 +      chained_irq_enter(chip, desc);
 +      exynos4_irq_demux_eint(IRQ_EINT(16));
 +      exynos4_irq_demux_eint(IRQ_EINT(24));
 +      chained_irq_exit(chip, desc);
 +}
 +
 +static void exynos4_irq_eint0_15(unsigned int irq, struct irq_desc *desc)
 +{
 +      u32 *irq_data = irq_get_handler_data(irq);
 +      struct irq_chip *chip = irq_get_chip(irq);
 +
 +      chained_irq_enter(chip, desc);
 +      chip->irq_mask(&desc->irq_data);
 +
 +      if (chip->irq_ack)
 +              chip->irq_ack(&desc->irq_data);
 +
 +      generic_handle_irq(*irq_data);
 +
 +      chip->irq_unmask(&desc->irq_data);
 +      chained_irq_exit(chip, desc);
 +}
 +
 +int __init exynos4_init_irq_eint(void)
 +{
 +      int irq;
 +
 +      for (irq = 0 ; irq <= 31 ; irq++) {
 +              irq_set_chip_and_handler(IRQ_EINT(irq), &exynos4_irq_eint,
 +                                       handle_level_irq);
 +              set_irq_flags(IRQ_EINT(irq), IRQF_VALID);
 +      }
 +
 +      irq_set_chained_handler(IRQ_EINT16_31, exynos4_irq_demux_eint16_31);
 +
 +      for (irq = 0 ; irq <= 15 ; irq++) {
 +              eint0_15_data[irq] = IRQ_EINT(irq);
 +
 +              irq_set_handler_data(exynos4_get_irq_nr(irq),
 +                                   &eint0_15_data[irq]);
 +              irq_set_chained_handler(exynos4_get_irq_nr(irq),
 +                                      exynos4_irq_eint0_15);
 +      }
 +
 +      return 0;
 +}
 +arch_initcall(exynos4_init_irq_eint);
Simple merge
Simple merge
Simple merge
Simple merge
Simple merge
index 489c826e92a7edbf85470a73908aeb966fe78636,da6651556eb94fc2e2134d812b377f5df243d4ab..eea559ec7a58c01045f7b7a6f7ed0d8b568b74b5
@@@ -181,18 -182,6 +183,18 @@@ int __init s3c2410_init(void
  
  int __init s3c2410a_init(void)
  {
-       s3c2410_sysdev.cls = &s3c2410a_sysclass;
+       s3c2410_dev.bus = &s3c2410a_subsys;
        return s3c2410_init();
  }
 +
 +void s3c2410_restart(char mode, const char *cmd)
 +{
 +      if (mode == 's') {
 +              soft_restart(0);
 +      }
 +
 +      arch_wdt_reset();
 +
 +      /* we'll take a jump through zero as a poor second */
 +      soft_restart(0);
 +}
Simple merge
index 46062232bbc784484382b50f3187317b6ef85e79,143db908c2c5f25bcbc8a777db90fa72aa4f1073..5287d2808d3ef1f1c471545cd54b64132b2f1e1f
@@@ -67,19 -68,17 +67,20 @@@ static struct map_desc s3c2416_iodesc[
        IODESC_ENT(TIMER),
  };
  
- struct sysdev_class s3c2416_sysclass = {
+ struct bus_type s3c2416_subsys = {
        .name = "s3c2416-core",
+       .dev_name = "s3c2416-core",
  };
  
- static struct sys_device s3c2416_sysdev = {
-       .cls            = &s3c2416_sysclass,
+ static struct device s3c2416_dev = {
+       .bus            = &s3c2416_subsys,
  };
  
 -static void s3c2416_hard_reset(void)
 +void s3c2416_restart(char mode, const char *cmd)
  {
 +      if (mode == 's')
 +              soft_restart(0);
 +
        __raw_writel(S3C2443_SWRST_RESET, S3C2443_SWRST);
  }
  
Simple merge
Simple merge
Simple merge
index 4568ded338d0a67f76328e7dde1aa0752893e385,aa90ae4fc980c0292cca047165351c1bd49cc911..b9deaeb0dfff5ea0dbc3b1f83cadd25c78854599
@@@ -48,19 -49,17 +48,20 @@@ static struct map_desc s3c2443_iodesc[
        IODESC_ENT(TIMER),
  };
  
- struct sysdev_class s3c2443_sysclass = {
+ struct bus_type s3c2443_subsys = {
        .name = "s3c2443-core",
+       .dev_name = "s3c2443-core",
  };
  
- static struct sys_device s3c2443_sysdev = {
-       .cls            = &s3c2443_sysclass,
+ static struct device s3c2443_dev = {
+       .bus            = &s3c2443_subsys,
  };
  
 -static void s3c2443_hard_reset(void)
 +void s3c2443_restart(char mode, const char *cmd)
  {
 +      if (mode == 's')
 +              soft_restart(0);
 +
        __raw_writel(S3C2443_SWRST_RESET, S3C2443_SWRST);
  }
  
index 35182ba049da43cb6c8bf221096924fc1aeb7330,0000000000000000000000000000000000000000..4a7394d4bd9ea0e2f79fbb2af25a19c862cf7257
mode 100644,000000..100644
--- /dev/null
@@@ -1,385 -1,0 +1,385 @@@
- #include <linux/sysdev.h>
 +/*
 + * Copyright (c) 2011 Samsung Electronics Co., Ltd.
 + *            http://www.samsung.com
 + *
 + * Copyright 2008 Openmoko, Inc.
 + * Copyright 2008 Simtec Electronics
 + *    Ben Dooks <ben@simtec.co.uk>
 + *    http://armlinux.simtec.co.uk/
 + *
 + * Common Codes for S3C64XX machines
 + *
 + * This program is free software; you can redistribute it and/or modify
 + * it under the terms of the GNU General Public License version 2 as
 + * published by the Free Software Foundation.
 + */
 +
 +#include <linux/kernel.h>
 +#include <linux/init.h>
 +#include <linux/module.h>
 +#include <linux/interrupt.h>
 +#include <linux/ioport.h>
- struct sysdev_class s3c64xx_sysclass = {
-       .name   = "s3c64xx-core",
 +#include <linux/serial_core.h>
 +#include <linux/platform_device.h>
 +#include <linux/io.h>
 +#include <linux/dma-mapping.h>
 +#include <linux/irq.h>
 +#include <linux/gpio.h>
 +
 +#include <asm/mach/arch.h>
 +#include <asm/mach/map.h>
 +#include <asm/hardware/vic.h>
 +
 +#include <mach/map.h>
 +#include <mach/hardware.h>
 +#include <mach/regs-gpio.h>
 +
 +#include <plat/cpu.h>
 +#include <plat/clock.h>
 +#include <plat/devs.h>
 +#include <plat/pm.h>
 +#include <plat/gpio-cfg.h>
 +#include <plat/irq-uart.h>
 +#include <plat/irq-vic-timer.h>
 +#include <plat/regs-irqtype.h>
 +#include <plat/regs-serial.h>
 +#include <plat/watchdog-reset.h>
 +
 +#include "common.h"
 +
 +/* uart registration process */
 +
 +void __init s3c64xx_init_uarts(struct s3c2410_uartcfg *cfg, int no)
 +{
 +      s3c24xx_init_uartdevs("s3c6400-uart", s3c64xx_uart_resources, cfg, no);
 +}
 +
 +/* table of supported CPUs */
 +
 +static const char name_s3c6400[] = "S3C6400";
 +static const char name_s3c6410[] = "S3C6410";
 +
 +static struct cpu_table cpu_ids[] __initdata = {
 +      {
 +              .idcode         = S3C6400_CPU_ID,
 +              .idmask         = S3C64XX_CPU_MASK,
 +              .map_io         = s3c6400_map_io,
 +              .init_clocks    = s3c6400_init_clocks,
 +              .init_uarts     = s3c64xx_init_uarts,
 +              .init           = s3c6400_init,
 +              .name           = name_s3c6400,
 +      }, {
 +              .idcode         = S3C6410_CPU_ID,
 +              .idmask         = S3C64XX_CPU_MASK,
 +              .map_io         = s3c6410_map_io,
 +              .init_clocks    = s3c6410_init_clocks,
 +              .init_uarts     = s3c64xx_init_uarts,
 +              .init           = s3c6410_init,
 +              .name           = name_s3c6410,
 +      },
 +};
 +
 +/* minimal IO mapping */
 +
 +/* see notes on uart map in arch/arm/mach-s3c64xx/include/mach/debug-macro.S */
 +#define UART_OFFS (S3C_PA_UART & 0xfffff)
 +
 +static struct map_desc s3c_iodesc[] __initdata = {
 +      {
 +              .virtual        = (unsigned long)S3C_VA_SYS,
 +              .pfn            = __phys_to_pfn(S3C64XX_PA_SYSCON),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S3C_VA_MEM,
 +              .pfn            = __phys_to_pfn(S3C64XX_PA_SROM),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)(S3C_VA_UART + UART_OFFS),
 +              .pfn            = __phys_to_pfn(S3C_PA_UART),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)VA_VIC0,
 +              .pfn            = __phys_to_pfn(S3C64XX_PA_VIC0),
 +              .length         = SZ_16K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)VA_VIC1,
 +              .pfn            = __phys_to_pfn(S3C64XX_PA_VIC1),
 +              .length         = SZ_16K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S3C_VA_TIMER,
 +              .pfn            = __phys_to_pfn(S3C_PA_TIMER),
 +              .length         = SZ_16K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S3C64XX_VA_GPIO,
 +              .pfn            = __phys_to_pfn(S3C64XX_PA_GPIO),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S3C64XX_VA_MODEM,
 +              .pfn            = __phys_to_pfn(S3C64XX_PA_MODEM),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S3C_VA_WATCHDOG,
 +              .pfn            = __phys_to_pfn(S3C64XX_PA_WATCHDOG),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S3C_VA_USB_HSPHY,
 +              .pfn            = __phys_to_pfn(S3C64XX_PA_USB_HSPHY),
 +              .length         = SZ_1K,
 +              .type           = MT_DEVICE,
 +      },
 +};
 +
- static struct sys_device s3c64xx_sysdev = {
-       .cls    = &s3c64xx_sysclass,
++static struct bus_type s3c64xx_subsys = {
++      .name           = "s3c64xx-core",
++      .dev_name       = "s3c64xx-core",
 +};
 +
- static __init int s3c64xx_sysdev_init(void)
++static struct device s3c64xx_dev = {
++      .bus    = &s3c64xx_subsys,
 +};
 +
 +/* read cpu identification code */
 +
 +void __init s3c64xx_init_io(struct map_desc *mach_desc, int size)
 +{
 +      /* initialise the io descriptors we need for initialisation */
 +      iotable_init(s3c_iodesc, ARRAY_SIZE(s3c_iodesc));
 +      iotable_init(mach_desc, size);
 +      init_consistent_dma_size(SZ_8M);
 +
 +      /* detect cpu id */
 +      s3c64xx_init_cpu();
 +
 +      s3c_init_cpu(samsung_cpu_id, cpu_ids, ARRAY_SIZE(cpu_ids));
 +}
 +
-       sysdev_class_register(&s3c64xx_sysclass);
-       return sysdev_register(&s3c64xx_sysdev);
++static __init int s3c64xx_dev_init(void)
 +{
- core_initcall(s3c64xx_sysdev_init);
++      subsys_system_register(&s3c64xx_subsys, NULL);
++      return device_register(&s3c64xx_dev);
 +}
++core_initcall(s3c64xx_dev_init);
 +
 +/*
 + * setup the sources the vic should advertise resume
 + * for, even though it is not doing the wake
 + * (set_irq_wake needs to be valid)
 + */
 +#define IRQ_VIC0_RESUME (1 << (IRQ_RTC_TIC - IRQ_VIC0_BASE))
 +#define IRQ_VIC1_RESUME (1 << (IRQ_RTC_ALARM - IRQ_VIC1_BASE) |       \
 +                       1 << (IRQ_PENDN - IRQ_VIC1_BASE) |     \
 +                       1 << (IRQ_HSMMC0 - IRQ_VIC1_BASE) |    \
 +                       1 << (IRQ_HSMMC1 - IRQ_VIC1_BASE) |    \
 +                       1 << (IRQ_HSMMC2 - IRQ_VIC1_BASE))
 +
 +void __init s3c64xx_init_irq(u32 vic0_valid, u32 vic1_valid)
 +{
 +      printk(KERN_DEBUG "%s: initialising interrupts\n", __func__);
 +
 +      /* initialise the pair of VICs */
 +      vic_init(VA_VIC0, IRQ_VIC0_BASE, vic0_valid, IRQ_VIC0_RESUME);
 +      vic_init(VA_VIC1, IRQ_VIC1_BASE, vic1_valid, IRQ_VIC1_RESUME);
 +
 +      /* add the timer sub-irqs */
 +      s3c_init_vic_timer_irq(5, IRQ_TIMER0);
 +}
 +
 +#define eint_offset(irq)      ((irq) - IRQ_EINT(0))
 +#define eint_irq_to_bit(irq)  ((u32)(1 << eint_offset(irq)))
 +
 +static inline void s3c_irq_eint_mask(struct irq_data *data)
 +{
 +      u32 mask;
 +
 +      mask = __raw_readl(S3C64XX_EINT0MASK);
 +      mask |= (u32)data->chip_data;
 +      __raw_writel(mask, S3C64XX_EINT0MASK);
 +}
 +
 +static void s3c_irq_eint_unmask(struct irq_data *data)
 +{
 +      u32 mask;
 +
 +      mask = __raw_readl(S3C64XX_EINT0MASK);
 +      mask &= ~((u32)data->chip_data);
 +      __raw_writel(mask, S3C64XX_EINT0MASK);
 +}
 +
 +static inline void s3c_irq_eint_ack(struct irq_data *data)
 +{
 +      __raw_writel((u32)data->chip_data, S3C64XX_EINT0PEND);
 +}
 +
 +static void s3c_irq_eint_maskack(struct irq_data *data)
 +{
 +      /* compiler should in-line these */
 +      s3c_irq_eint_mask(data);
 +      s3c_irq_eint_ack(data);
 +}
 +
 +static int s3c_irq_eint_set_type(struct irq_data *data, unsigned int type)
 +{
 +      int offs = eint_offset(data->irq);
 +      int pin, pin_val;
 +      int shift;
 +      u32 ctrl, mask;
 +      u32 newvalue = 0;
 +      void __iomem *reg;
 +
 +      if (offs > 27)
 +              return -EINVAL;
 +
 +      if (offs <= 15)
 +              reg = S3C64XX_EINT0CON0;
 +      else
 +              reg = S3C64XX_EINT0CON1;
 +
 +      switch (type) {
 +      case IRQ_TYPE_NONE:
 +              printk(KERN_WARNING "No edge setting!\n");
 +              break;
 +
 +      case IRQ_TYPE_EDGE_RISING:
 +              newvalue = S3C2410_EXTINT_RISEEDGE;
 +              break;
 +
 +      case IRQ_TYPE_EDGE_FALLING:
 +              newvalue = S3C2410_EXTINT_FALLEDGE;
 +              break;
 +
 +      case IRQ_TYPE_EDGE_BOTH:
 +              newvalue = S3C2410_EXTINT_BOTHEDGE;
 +              break;
 +
 +      case IRQ_TYPE_LEVEL_LOW:
 +              newvalue = S3C2410_EXTINT_LOWLEV;
 +              break;
 +
 +      case IRQ_TYPE_LEVEL_HIGH:
 +              newvalue = S3C2410_EXTINT_HILEV;
 +              break;
 +
 +      default:
 +              printk(KERN_ERR "No such irq type %d", type);
 +              return -1;
 +      }
 +
 +      if (offs <= 15)
 +              shift = (offs / 2) * 4;
 +      else
 +              shift = ((offs - 16) / 2) * 4;
 +      mask = 0x7 << shift;
 +
 +      ctrl = __raw_readl(reg);
 +      ctrl &= ~mask;
 +      ctrl |= newvalue << shift;
 +      __raw_writel(ctrl, reg);
 +
 +      /* set the GPIO pin appropriately */
 +
 +      if (offs < 16) {
 +              pin = S3C64XX_GPN(offs);
 +              pin_val = S3C_GPIO_SFN(2);
 +      } else if (offs < 23) {
 +              pin = S3C64XX_GPL(offs + 8 - 16);
 +              pin_val = S3C_GPIO_SFN(3);
 +      } else {
 +              pin = S3C64XX_GPM(offs - 23);
 +              pin_val = S3C_GPIO_SFN(3);
 +      }
 +
 +      s3c_gpio_cfgpin(pin, pin_val);
 +
 +      return 0;
 +}
 +
 +static struct irq_chip s3c_irq_eint = {
 +      .name           = "s3c-eint",
 +      .irq_mask       = s3c_irq_eint_mask,
 +      .irq_unmask     = s3c_irq_eint_unmask,
 +      .irq_mask_ack   = s3c_irq_eint_maskack,
 +      .irq_ack        = s3c_irq_eint_ack,
 +      .irq_set_type   = s3c_irq_eint_set_type,
 +      .irq_set_wake   = s3c_irqext_wake,
 +};
 +
 +/* s3c_irq_demux_eint
 + *
 + * This function demuxes the IRQ from the group0 external interrupts,
 + * from IRQ_EINT(0) to IRQ_EINT(27). It is designed to be inlined into
 + * the specific handlers s3c_irq_demux_eintX_Y.
 + */
 +static inline void s3c_irq_demux_eint(unsigned int start, unsigned int end)
 +{
 +      u32 status = __raw_readl(S3C64XX_EINT0PEND);
 +      u32 mask = __raw_readl(S3C64XX_EINT0MASK);
 +      unsigned int irq;
 +
 +      status &= ~mask;
 +      status >>= start;
 +      status &= (1 << (end - start + 1)) - 1;
 +
 +      for (irq = IRQ_EINT(start); irq <= IRQ_EINT(end); irq++) {
 +              if (status & 1)
 +                      generic_handle_irq(irq);
 +
 +              status >>= 1;
 +      }
 +}
 +
 +static void s3c_irq_demux_eint0_3(unsigned int irq, struct irq_desc *desc)
 +{
 +      s3c_irq_demux_eint(0, 3);
 +}
 +
 +static void s3c_irq_demux_eint4_11(unsigned int irq, struct irq_desc *desc)
 +{
 +      s3c_irq_demux_eint(4, 11);
 +}
 +
 +static void s3c_irq_demux_eint12_19(unsigned int irq, struct irq_desc *desc)
 +{
 +      s3c_irq_demux_eint(12, 19);
 +}
 +
 +static void s3c_irq_demux_eint20_27(unsigned int irq, struct irq_desc *desc)
 +{
 +      s3c_irq_demux_eint(20, 27);
 +}
 +
 +static int __init s3c64xx_init_irq_eint(void)
 +{
 +      int irq;
 +
 +      for (irq = IRQ_EINT(0); irq <= IRQ_EINT(27); irq++) {
 +              irq_set_chip_and_handler(irq, &s3c_irq_eint, handle_level_irq);
 +              irq_set_chip_data(irq, (void *)eint_irq_to_bit(irq));
 +              set_irq_flags(irq, IRQF_VALID);
 +      }
 +
 +      irq_set_chained_handler(IRQ_EINT0_3, s3c_irq_demux_eint0_3);
 +      irq_set_chained_handler(IRQ_EINT4_11, s3c_irq_demux_eint4_11);
 +      irq_set_chained_handler(IRQ_EINT12_19, s3c_irq_demux_eint12_19);
 +      irq_set_chained_handler(IRQ_EINT20_27, s3c_irq_demux_eint20_27);
 +
 +      return 0;
 +}
 +arch_initcall(s3c64xx_init_irq_eint);
 +
 +void s3c64xx_restart(char mode, const char *cmd)
 +{
 +      if (mode != 's')
 +              arch_wdt_reset();
 +
 +      /* if all else fails, or mode was for soft, jump to 0 */
 +      soft_restart(0);
 +}
index 8dc8ab6d8d6d4e3d20bcf6b6bcf009ee9b2d853d,0000000000000000000000000000000000000000..5eb9c9a7d73b3d8dd3123e88bedd2382d37f2f9c
mode 100644,000000..100644
--- /dev/null
@@@ -1,57 -1,0 +1,56 @@@
- extern struct sysdev_class s3c64xx_sysclass;
 +/*
 + * Copyright (c) 2011 Samsung Electronics Co., Ltd.
 + *            http://www.samsung.com
 + *
 + * Copyright 2008 Openmoko, Inc.
 + * Copyright 2008 Simtec Electronics
 + *    Ben Dooks <ben@simtec.co.uk>
 + *    http://armlinux.simtec.co.uk/
 + *
 + * Common Header for S3C64XX machines
 + *
 + * This program is free software; you can redistribute it and/or modify
 + * it under the terms of the GNU General Public License version 2 as
 + * published by the Free Software Foundation.
 + */
 +
 +#ifndef __ARCH_ARM_MACH_S3C64XX_COMMON_H
 +#define __ARCH_ARM_MACH_S3C64XX_COMMON_H
 +
 +void s3c64xx_init_irq(u32 vic0, u32 vic1);
 +void s3c64xx_init_io(struct map_desc *mach_desc, int size);
 +
 +void s3c64xx_register_clocks(unsigned long xtal, unsigned armclk_limit);
 +void s3c64xx_setup_clocks(void);
 +
 +void s3c64xx_restart(char mode, const char *cmd);
 +
 +extern struct syscore_ops s3c64xx_irq_syscore_ops;
 +
 +#ifdef CONFIG_CPU_S3C6400
 +
 +extern  int s3c6400_init(void);
 +extern void s3c6400_init_irq(void);
 +extern void s3c6400_map_io(void);
 +extern void s3c6400_init_clocks(int xtal);
 +
 +#else
 +#define s3c6400_init_clocks NULL
 +#define s3c6400_map_io NULL
 +#define s3c6400_init NULL
 +#endif
 +
 +#ifdef CONFIG_CPU_S3C6410
 +
 +extern  int s3c6410_init(void);
 +extern void s3c6410_init_irq(void);
 +extern void s3c6410_map_io(void);
 +extern void s3c6410_init_clocks(int xtal);
 +
 +#else
 +#define s3c6410_init_clocks NULL
 +#define s3c6410_map_io NULL
 +#define s3c6410_init NULL
 +#endif
 +
 +#endif /* __ARCH_ARM_MACH_S3C64XX_COMMON_H */
Simple merge
Simple merge
Simple merge
Simple merge
Simple merge
index b7555a0fb0fb2b02b1fc692bfe88b1da9423e9b3,0000000000000000000000000000000000000000..28d0b918cd4b6cf911afac7bb836e9c8260658df
mode 100644,000000..100644
--- /dev/null
@@@ -1,468 -1,0 +1,469 @@@
- #include <linux/sysdev.h>
 +/*
 + * Copyright (c) 2009-2011 Samsung Electronics Co., Ltd.
 + *            http://www.samsung.com
 + *
 + * Common Codes for S5P64X0 machines
 + *
 + * This program is free software; you can redistribute it and/or modify
 + * it under the terms of the GNU General Public License version 2 as
 + * published by the Free Software Foundation.
 + */
 +
 +#include <linux/kernel.h>
 +#include <linux/types.h>
 +#include <linux/interrupt.h>
 +#include <linux/list.h>
 +#include <linux/timer.h>
 +#include <linux/init.h>
 +#include <linux/clk.h>
 +#include <linux/io.h>
- struct sysdev_class s5p64x0_sysclass = {
-       .name   = "s5p64x0-core",
++#include <linux/device.h>
 +#include <linux/serial_core.h>
 +#include <linux/platform_device.h>
 +#include <linux/sched.h>
 +#include <linux/dma-mapping.h>
 +#include <linux/gpio.h>
 +#include <linux/irq.h>
 +
 +#include <asm/irq.h>
 +#include <asm/proc-fns.h>
 +#include <asm/mach/arch.h>
 +#include <asm/mach/map.h>
 +#include <asm/mach/irq.h>
 +
 +#include <mach/map.h>
 +#include <mach/hardware.h>
 +#include <mach/regs-clock.h>
 +#include <mach/regs-gpio.h>
 +
 +#include <plat/cpu.h>
 +#include <plat/clock.h>
 +#include <plat/devs.h>
 +#include <plat/pm.h>
 +#include <plat/adc-core.h>
 +#include <plat/fb-core.h>
 +#include <plat/gpio-cfg.h>
 +#include <plat/regs-irqtype.h>
 +#include <plat/regs-serial.h>
 +#include <plat/watchdog-reset.h>
 +
 +#include "common.h"
 +
 +static const char name_s5p6440[] = "S5P6440";
 +static const char name_s5p6450[] = "S5P6450";
 +
 +static struct cpu_table cpu_ids[] __initdata = {
 +      {
 +              .idcode         = S5P6440_CPU_ID,
 +              .idmask         = S5P64XX_CPU_MASK,
 +              .map_io         = s5p6440_map_io,
 +              .init_clocks    = s5p6440_init_clocks,
 +              .init_uarts     = s5p6440_init_uarts,
 +              .init           = s5p64x0_init,
 +              .name           = name_s5p6440,
 +      }, {
 +              .idcode         = S5P6450_CPU_ID,
 +              .idmask         = S5P64XX_CPU_MASK,
 +              .map_io         = s5p6450_map_io,
 +              .init_clocks    = s5p6450_init_clocks,
 +              .init_uarts     = s5p6450_init_uarts,
 +              .init           = s5p64x0_init,
 +              .name           = name_s5p6450,
 +      },
 +};
 +
 +/* Initial IO mappings */
 +
 +static struct map_desc s5p64x0_iodesc[] __initdata = {
 +      {
 +              .virtual        = (unsigned long)S5P_VA_CHIPID,
 +              .pfn            = __phys_to_pfn(S5P64X0_PA_CHIPID),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S3C_VA_SYS,
 +              .pfn            = __phys_to_pfn(S5P64X0_PA_SYSCON),
 +              .length         = SZ_64K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S3C_VA_TIMER,
 +              .pfn            = __phys_to_pfn(S5P64X0_PA_TIMER),
 +              .length         = SZ_16K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S3C_VA_WATCHDOG,
 +              .pfn            = __phys_to_pfn(S5P64X0_PA_WDT),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S5P_VA_SROMC,
 +              .pfn            = __phys_to_pfn(S5P64X0_PA_SROMC),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S5P_VA_GPIO,
 +              .pfn            = __phys_to_pfn(S5P64X0_PA_GPIO),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)VA_VIC0,
 +              .pfn            = __phys_to_pfn(S5P64X0_PA_VIC0),
 +              .length         = SZ_16K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)VA_VIC1,
 +              .pfn            = __phys_to_pfn(S5P64X0_PA_VIC1),
 +              .length         = SZ_16K,
 +              .type           = MT_DEVICE,
 +      },
 +};
 +
 +static struct map_desc s5p6440_iodesc[] __initdata = {
 +      {
 +              .virtual        = (unsigned long)S3C_VA_UART,
 +              .pfn            = __phys_to_pfn(S5P6440_PA_UART(0)),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      },
 +};
 +
 +static struct map_desc s5p6450_iodesc[] __initdata = {
 +      {
 +              .virtual        = (unsigned long)S3C_VA_UART,
 +              .pfn            = __phys_to_pfn(S5P6450_PA_UART(0)),
 +              .length         = SZ_512K,
 +              .type           = MT_DEVICE,
 +      }, {
 +              .virtual        = (unsigned long)S3C_VA_UART + SZ_512K,
 +              .pfn            = __phys_to_pfn(S5P6450_PA_UART(5)),
 +              .length         = SZ_4K,
 +              .type           = MT_DEVICE,
 +      },
 +};
 +
 +static void s5p64x0_idle(void)
 +{
 +      unsigned long val;
 +
 +      if (!need_resched()) {
 +              val = __raw_readl(S5P64X0_PWR_CFG);
 +              val &= ~(0x3 << 5);
 +              val |= (0x1 << 5);
 +              __raw_writel(val, S5P64X0_PWR_CFG);
 +
 +              cpu_do_idle();
 +      }
 +      local_irq_enable();
 +}
 +
 +/*
 + * s5p64x0_map_io
 + *
 + * register the standard CPU IO areas
 + */
 +
 +void __init s5p64x0_init_io(struct map_desc *mach_desc, int size)
 +{
 +      /* initialize the io descriptors we need for initialization */
 +      iotable_init(s5p64x0_iodesc, ARRAY_SIZE(s5p64x0_iodesc));
 +      if (mach_desc)
 +              iotable_init(mach_desc, size);
 +
 +      /* detect cpu id and rev. */
 +      s5p_init_cpu(S5P64X0_SYS_ID);
 +
 +      s3c_init_cpu(samsung_cpu_id, cpu_ids, ARRAY_SIZE(cpu_ids));
 +}
 +
 +void __init s5p6440_map_io(void)
 +{
 +      /* initialize any device information early */
 +      s3c_adc_setname("s3c64xx-adc");
 +      s3c_fb_setname("s5p64x0-fb");
 +
 +      iotable_init(s5p6440_iodesc, ARRAY_SIZE(s5p6440_iodesc));
 +      init_consistent_dma_size(SZ_8M);
 +}
 +
 +void __init s5p6450_map_io(void)
 +{
 +      /* initialize any device information early */
 +      s3c_adc_setname("s3c64xx-adc");
 +      s3c_fb_setname("s5p64x0-fb");
 +
 +      iotable_init(s5p6450_iodesc, ARRAY_SIZE(s5p6450_iodesc));
 +      init_consistent_dma_size(SZ_8M);
 +}
 +
 +/*
 + * s5p64x0_init_clocks
 + *
 + * register and setup the CPU clocks
 + */
 +
 +void __init s5p6440_init_clocks(int xtal)
 +{
 +      printk(KERN_DEBUG "%s: initializing clocks\n", __func__);
 +
 +      s3c24xx_register_baseclocks(xtal);
 +      s5p_register_clocks(xtal);
 +      s5p6440_register_clocks();
 +      s5p6440_setup_clocks();
 +}
 +
 +void __init s5p6450_init_clocks(int xtal)
 +{
 +      printk(KERN_DEBUG "%s: initializing clocks\n", __func__);
 +
 +      s3c24xx_register_baseclocks(xtal);
 +      s5p_register_clocks(xtal);
 +      s5p6450_register_clocks();
 +      s5p6450_setup_clocks();
 +}
 +
 +/*
 + * s5p64x0_init_irq
 + *
 + * register the CPU interrupts
 + */
 +
 +void __init s5p6440_init_irq(void)
 +{
 +      /* S5P6440 supports 2 VIC */
 +      u32 vic[2];
 +
 +      /*
 +       * VIC0 is missing IRQ_VIC0[3, 4, 8, 10, (12-22)]
 +       * VIC1 is missing IRQ VIC1[1, 3, 4, 10, 11, 12, 14, 15, 22]
 +       */
 +      vic[0] = 0xff800ae7;
 +      vic[1] = 0xffbf23e5;
 +
 +      s5p_init_irq(vic, ARRAY_SIZE(vic));
 +}
 +
 +void __init s5p6450_init_irq(void)
 +{
 +      /* S5P6450 supports only 2 VIC */
 +      u32 vic[2];
 +
 +      /*
 +       * VIC0 is missing IRQ_VIC0[(13-15), (21-22)]
 +       * VIC1 is missing IRQ VIC1[12, 14, 23]
 +       */
 +      vic[0] = 0xff9f1fff;
 +      vic[1] = 0xff7fafff;
 +
 +      s5p_init_irq(vic, ARRAY_SIZE(vic));
 +}
 +
- static struct sys_device s5p64x0_sysdev = {
-       .cls    = &s5p64x0_sysclass,
++struct bus_type s5p64x0_subsys = {
++      .name           = "s5p64x0-core",
++      .dev_name       = "s5p64x0-core",
 +};
 +
-       return sysdev_class_register(&s5p64x0_sysclass);
++static struct device s5p64x0_dev = {
++      .bus    = &s5p64x0_subsys,
 +};
 +
 +static int __init s5p64x0_core_init(void)
 +{
-       return sysdev_register(&s5p64x0_sysdev);
++      return subsys_system_register(&s5p64x0_subsys, NULL);
 +}
 +core_initcall(s5p64x0_core_init);
 +
 +int __init s5p64x0_init(void)
 +{
 +      printk(KERN_INFO "S5P64X0(S5P6440/S5P6450): Initializing architecture\n");
 +
 +      /* set idle function */
 +      pm_idle = s5p64x0_idle;
 +
++      return device_register(&s5p64x0_dev);
 +}
 +
 +static struct s3c24xx_uart_clksrc s5p64x0_serial_clocks[] = {
 +      [0] = {
 +              .name           = "pclk_low",
 +              .divisor        = 1,
 +              .min_baud       = 0,
 +              .max_baud       = 0,
 +      },
 +      [1] = {
 +              .name           = "uclk1",
 +              .divisor        = 1,
 +              .min_baud       = 0,
 +              .max_baud       = 0,
 +      },
 +};
 +
 +/* uart registration process */
 +
 +void __init s5p64x0_common_init_uarts(struct s3c2410_uartcfg *cfg, int no)
 +{
 +      struct s3c2410_uartcfg *tcfg = cfg;
 +      u32 ucnt;
 +
 +      for (ucnt = 0; ucnt < no; ucnt++, tcfg++) {
 +              if (!tcfg->clocks) {
 +                      tcfg->clocks = s5p64x0_serial_clocks;
 +                      tcfg->clocks_size = ARRAY_SIZE(s5p64x0_serial_clocks);
 +              }
 +      }
 +}
 +
 +void __init s5p6440_init_uarts(struct s3c2410_uartcfg *cfg, int no)
 +{
 +      int uart;
 +
 +      for (uart = 0; uart < no; uart++) {
 +              s5p_uart_resources[uart].resources->start = S5P6440_PA_UART(uart);
 +              s5p_uart_resources[uart].resources->end = S5P6440_PA_UART(uart) + S5P_SZ_UART;
 +      }
 +
 +      s5p64x0_common_init_uarts(cfg, no);
 +      s3c24xx_init_uartdevs("s3c6400-uart", s5p_uart_resources, cfg, no);
 +}
 +
 +void __init s5p6450_init_uarts(struct s3c2410_uartcfg *cfg, int no)
 +{
 +      s5p64x0_common_init_uarts(cfg, no);
 +      s3c24xx_init_uartdevs("s3c6400-uart", s5p_uart_resources, cfg, no);
 +}
 +
 +#define eint_offset(irq)      ((irq) - IRQ_EINT(0))
 +
 +static int s5p64x0_irq_eint_set_type(struct irq_data *data, unsigned int type)
 +{
 +      int offs = eint_offset(data->irq);
 +      int shift;
 +      u32 ctrl, mask;
 +      u32 newvalue = 0;
 +
 +      if (offs > 15)
 +              return -EINVAL;
 +
 +      switch (type) {
 +      case IRQ_TYPE_NONE:
 +              printk(KERN_WARNING "No edge setting!\n");
 +              break;
 +      case IRQ_TYPE_EDGE_RISING:
 +              newvalue = S3C2410_EXTINT_RISEEDGE;
 +              break;
 +      case IRQ_TYPE_EDGE_FALLING:
 +              newvalue = S3C2410_EXTINT_FALLEDGE;
 +              break;
 +      case IRQ_TYPE_EDGE_BOTH:
 +              newvalue = S3C2410_EXTINT_BOTHEDGE;
 +              break;
 +      case IRQ_TYPE_LEVEL_LOW:
 +              newvalue = S3C2410_EXTINT_LOWLEV;
 +              break;
 +      case IRQ_TYPE_LEVEL_HIGH:
 +              newvalue = S3C2410_EXTINT_HILEV;
 +              break;
 +      default:
 +              printk(KERN_ERR "No such irq type %d", type);
 +              return -EINVAL;
 +      }
 +
 +      shift = (offs / 2) * 4;
 +      mask = 0x7 << shift;
 +
 +      ctrl = __raw_readl(S5P64X0_EINT0CON0) & ~mask;
 +      ctrl |= newvalue << shift;
 +      __raw_writel(ctrl, S5P64X0_EINT0CON0);
 +
 +      /* Configure the GPIO pin for 6450 or 6440 based on CPU ID */
 +      if (soc_is_s5p6450())
 +              s3c_gpio_cfgpin(S5P6450_GPN(offs), S3C_GPIO_SFN(2));
 +      else
 +              s3c_gpio_cfgpin(S5P6440_GPN(offs), S3C_GPIO_SFN(2));
 +
 +      return 0;
 +}
 +
 +/*
 + * s5p64x0_irq_demux_eint
 + *
 + * This function demuxes the IRQ from the group0 external interrupts,
 + * from IRQ_EINT(0) to IRQ_EINT(15). It is designed to be inlined into
 + * the specific handlers s5p64x0_irq_demux_eintX_Y.
 + */
 +static inline void s5p64x0_irq_demux_eint(unsigned int start, unsigned int end)
 +{
 +      u32 status = __raw_readl(S5P64X0_EINT0PEND);
 +      u32 mask = __raw_readl(S5P64X0_EINT0MASK);
 +      unsigned int irq;
 +
 +      status &= ~mask;
 +      status >>= start;
 +      status &= (1 << (end - start + 1)) - 1;
 +
 +      for (irq = IRQ_EINT(start); irq <= IRQ_EINT(end); irq++) {
 +              if (status & 1)
 +                      generic_handle_irq(irq);
 +              status >>= 1;
 +      }
 +}
 +
 +static void s5p64x0_irq_demux_eint0_3(unsigned int irq, struct irq_desc *desc)
 +{
 +      s5p64x0_irq_demux_eint(0, 3);
 +}
 +
 +static void s5p64x0_irq_demux_eint4_11(unsigned int irq, struct irq_desc *desc)
 +{
 +      s5p64x0_irq_demux_eint(4, 11);
 +}
 +
 +static void s5p64x0_irq_demux_eint12_15(unsigned int irq,
 +                                      struct irq_desc *desc)
 +{
 +      s5p64x0_irq_demux_eint(12, 15);
 +}
 +
 +static int s5p64x0_alloc_gc(void)
 +{
 +      struct irq_chip_generic *gc;
 +      struct irq_chip_type *ct;
 +
 +      gc = irq_alloc_generic_chip("s5p64x0-eint", 1, S5P_IRQ_EINT_BASE,
 +                                  S5P_VA_GPIO, handle_level_irq);
 +      if (!gc) {
 +              printk(KERN_ERR "%s: irq_alloc_generic_chip for group 0"
 +                      "external interrupts failed\n", __func__);
 +              return -EINVAL;
 +      }
 +
 +      ct = gc->chip_types;
 +      ct->chip.irq_ack = irq_gc_ack_set_bit;
 +      ct->chip.irq_mask = irq_gc_mask_set_bit;
 +      ct->chip.irq_unmask = irq_gc_mask_clr_bit;
 +      ct->chip.irq_set_type = s5p64x0_irq_eint_set_type;
 +      ct->chip.irq_set_wake = s3c_irqext_wake;
 +      ct->regs.ack = EINT0PEND_OFFSET;
 +      ct->regs.mask = EINT0MASK_OFFSET;
 +      irq_setup_generic_chip(gc, IRQ_MSK(16), IRQ_GC_INIT_MASK_CACHE,
 +                             IRQ_NOREQUEST | IRQ_NOPROBE, 0);
 +      return 0;
 +}
 +
 +static int __init s5p64x0_init_irq_eint(void)
 +{
 +      int ret = s5p64x0_alloc_gc();
 +      irq_set_chained_handler(IRQ_EINT0_3, s5p64x0_irq_demux_eint0_3);
 +      irq_set_chained_handler(IRQ_EINT4_11, s5p64x0_irq_demux_eint4_11);
 +      irq_set_chained_handler(IRQ_EINT12_15, s5p64x0_irq_demux_eint12_15);
 +
 +      return ret;
 +}
 +arch_initcall(s5p64x0_init_irq_eint);
 +
 +void s5p64x0_restart(char mode, const char *cmd)
 +{
 +      if (mode != 's')
 +              arch_wdt_reset();
 +
 +      soft_restart(0);
 +}
index 73594a2fcf267ac1d8305471ccf65791b7d80f05,330a10b23a5d741027bed471a7a0cc9bb53fe9e7..c9095730a7f58ec31f4cf34ee3863f32a848dd6a
@@@ -202,8 -154,9 +203,8 @@@ static struct device s5pc100_dev = 
  
  static int __init s5pc100_core_init(void)
  {
-       return sysdev_class_register(&s5pc100_sysclass);
+       return subsys_system_register(&s5pc100_subsys, NULL);
  }
 -
  core_initcall(s5pc100_core_init);
  
  int __init s5pc100_init(void)
        /* set idle function */
        pm_idle = s5pc100_idle;
  
-       return sysdev_register(&s5pc100_sysdev);
+       return device_register(&s5pc100_dev);
  }
 +
 +/* uart registration process */
 +
 +void __init s5pc100_init_uarts(struct s3c2410_uartcfg *cfg, int no)
 +{
 +      s3c24xx_init_uartdevs("s3c6400-uart", s5p_uart_resources, cfg, no);
 +}
 +
 +void s5pc100_restart(char mode, const char *cmd)
 +{
 +      if (mode != 's')
 +              arch_wdt_reset();
 +
 +      soft_restart(0);
 +}
Simple merge
index a4921bc9f1dcfc4724170ff0ef94c9bb684dd08e,28e71efb388e9ab7d21f7b53521c72a6b9b630b1..0ec393305d7cff71da295b23f666519e39b2da1b
@@@ -239,8 -185,9 +240,8 @@@ static struct device s5pv210_dev = 
  
  static int __init s5pv210_core_init(void)
  {
-       return sysdev_class_register(&s5pv210_sysclass);
+       return subsys_system_register(&s5pv210_subsys, NULL);
  }
 -
  core_initcall(s5pv210_core_init);
  
  int __init s5pv210_init(void)
        /* set idle function */
        pm_idle = s5pv210_idle;
  
-       return sysdev_register(&s5pv210_sysdev);
 -      /* set sw_reset function */
 -      s5p_reset_hook = s5pv210_sw_reset;
 -
+       return device_register(&s5pv210_dev);
  }
 +
 +static struct s3c24xx_uart_clksrc s5pv210_serial_clocks[] = {
 +      [0] = {
 +              .name           = "pclk",
 +              .divisor        = 1,
 +              .min_baud       = 0,
 +              .max_baud       = 0,
 +      },
 +};
 +
 +/* uart registration process */
 +
 +void __init s5pv210_init_uarts(struct s3c2410_uartcfg *cfg, int no)
 +{
 +      struct s3c2410_uartcfg *tcfg = cfg;
 +      u32 ucnt;
 +
 +      for (ucnt = 0; ucnt < no; ucnt++, tcfg++) {
 +              if (!tcfg->clocks) {
 +                      tcfg->clocks = s5pv210_serial_clocks;
 +                      tcfg->clocks_size = ARRAY_SIZE(s5pv210_serial_clocks);
 +              }
 +      }
 +
 +      s3c24xx_init_uartdevs("s5pv210-uart", s5p_uart_resources, cfg, no);
 +}
index 9405da4ae3a36ba85767b73b869d2fa91679ceda,05cf7dc6128611f300dbc374223c589390618ece..b323983b2c544d648a9e8142e5d35fee019b05a9
@@@ -13,9 -13,8 +13,9 @@@
  #include <linux/init.h>
  #include <linux/serial_core.h>
  #include <linux/i2c.h>
- #include <linux/sysdev.h>
+ #include <linux/device.h>
  
 +#include <asm/hardware/vic.h>
  #include <asm/mach/arch.h>
  #include <asm/mach/map.h>
  #include <asm/setup.h>
Simple merge
Simple merge
Simple merge
Simple merge
index 258d9d8a94f2e3b94ac92537aef68bf20f2719fc,0122a22eb732513f8fc3138f3a3260f8d7b47c5b..73cb3cfd06853bd3ead46c8661acfdc0ad926f1a
@@@ -179,20 -183,22 +179,20 @@@ extern struct syscore_ops s3c2410_pm_sy
  extern struct syscore_ops s3c2412_pm_syscore_ops;
  extern struct syscore_ops s3c2416_pm_syscore_ops;
  extern struct syscore_ops s3c244x_pm_syscore_ops;
 -extern struct syscore_ops s3c64xx_irq_syscore_ops;
  
- /* system device classes */
- extern struct sysdev_class s3c2410_sysclass;
- extern struct sysdev_class s3c2410a_sysclass;
- extern struct sysdev_class s3c2412_sysclass;
- extern struct sysdev_class s3c2416_sysclass;
- extern struct sysdev_class s3c2440_sysclass;
- extern struct sysdev_class s3c2442_sysclass;
- extern struct sysdev_class s3c2443_sysclass;
- extern struct sysdev_class s3c6410_sysclass;
- extern struct sysdev_class s5p64x0_sysclass;
- extern struct sysdev_class s5pv210_sysclass;
- extern struct sysdev_class exynos4_sysclass;
+ /* system device subsystems */
+ extern struct bus_type s3c2410_subsys;
+ extern struct bus_type s3c2410a_subsys;
+ extern struct bus_type s3c2412_subsys;
+ extern struct bus_type s3c2416_subsys;
+ extern struct bus_type s3c2440_subsys;
+ extern struct bus_type s3c2442_subsys;
+ extern struct bus_type s3c2443_subsys;
+ extern struct bus_type s3c6410_subsys;
 -extern struct bus_type s3c64xx_subsys;
+ extern struct bus_type s5p64x0_subsys;
+ extern struct bus_type s5pv210_subsys;
+ extern struct bus_type exynos4_subsys;
  
  extern void (*s5pc1xx_idle)(void);
  
Simple merge
index 6fdf5ffe8c44665df26c5750576a84ac74c4c6fa,5e7c1655f13a20c1cb6b1305f25f51add0966bc9..883e74c0d1b3b53b8a5cd1a003bc4ae30d0659f1
@@@ -51,8 -50,7 +51,8 @@@ static ssize_t store_smt_snooze_delay(s
        if (ret != 1)
                return -EINVAL;
  
-       per_cpu(smt_snooze_delay, cpu->sysdev.id) = snooze;
+       per_cpu(smt_snooze_delay, cpu->dev.id) = snooze;
 +      update_smt_snooze_delay(snooze);
  
        return count;
  }
@@@ -179,13 -177,11 +179,13 @@@ SYSFS_PMCSETUP(mmcra, SPRN_MMCRA)
  SYSFS_PMCSETUP(purr, SPRN_PURR);
  SYSFS_PMCSETUP(spurr, SPRN_SPURR);
  SYSFS_PMCSETUP(dscr, SPRN_DSCR);
 +SYSFS_PMCSETUP(pir, SPRN_PIR);
  
- static SYSDEV_ATTR(mmcra, 0600, show_mmcra, store_mmcra);
- static SYSDEV_ATTR(spurr, 0600, show_spurr, NULL);
- static SYSDEV_ATTR(dscr, 0600, show_dscr, store_dscr);
- static SYSDEV_ATTR(purr, 0600, show_purr, store_purr);
- static SYSDEV_ATTR(pir, 0400, show_pir, NULL);
+ static DEVICE_ATTR(mmcra, 0600, show_mmcra, store_mmcra);
+ static DEVICE_ATTR(spurr, 0600, show_spurr, NULL);
+ static DEVICE_ATTR(dscr, 0600, show_dscr, store_dscr);
+ static DEVICE_ATTR(purr, 0600, show_purr, store_purr);
++static DEVICE_ATTR(pir, 0400, show_pir, NULL);
  
  unsigned long dscr_default = 0;
  EXPORT_SYMBOL(dscr_default);
@@@ -386,19 -381,16 +385,19 @@@ static void __cpuinit register_cpu_onli
  
  #ifdef CONFIG_PPC64
        if (cpu_has_feature(CPU_FTR_MMCRA))
-               sysdev_create_file(s, &attr_mmcra);
+               device_create_file(s, &dev_attr_mmcra);
  
        if (cpu_has_feature(CPU_FTR_PURR))
-               sysdev_create_file(s, &attr_purr);
+               device_create_file(s, &dev_attr_purr);
  
        if (cpu_has_feature(CPU_FTR_SPURR))
-               sysdev_create_file(s, &attr_spurr);
+               device_create_file(s, &dev_attr_spurr);
  
        if (cpu_has_feature(CPU_FTR_DSCR))
-               sysdev_create_file(s, &attr_dscr);
+               device_create_file(s, &dev_attr_dscr);
 +
 +      if (cpu_has_feature(CPU_FTR_PPCAS_ARCH_V2))
-               sysdev_create_file(s, &attr_pir);
++              device_create_file(s, &dev_attr_pir);
  #endif /* CONFIG_PPC64 */
  
        cacheinfo_cpu_online(cpu);
@@@ -459,19 -451,16 +458,19 @@@ static void unregister_cpu_online(unsig
  
  #ifdef CONFIG_PPC64
        if (cpu_has_feature(CPU_FTR_MMCRA))
-               sysdev_remove_file(s, &attr_mmcra);
+               device_remove_file(s, &dev_attr_mmcra);
  
        if (cpu_has_feature(CPU_FTR_PURR))
-               sysdev_remove_file(s, &attr_purr);
+               device_remove_file(s, &dev_attr_purr);
  
        if (cpu_has_feature(CPU_FTR_SPURR))
-               sysdev_remove_file(s, &attr_spurr);
+               device_remove_file(s, &dev_attr_spurr);
  
        if (cpu_has_feature(CPU_FTR_DSCR))
-               sysdev_remove_file(s, &attr_dscr);
+               device_remove_file(s, &dev_attr_dscr);
 +
 +      if (cpu_has_feature(CPU_FTR_PPCAS_ARCH_V2))
-               sysdev_remove_file(s, &attr_pir);
++              device_remove_file(s, &dev_attr_pir);
  #endif /* CONFIG_PPC64 */
  
        cacheinfo_cpu_offline(cpu);
Simple merge
Simple merge
Simple merge
Simple merge
Simple merge
Simple merge
Simple merge
index 3991502b21e55103fcc780c4651a880c05226625,5bb0298fbcc0cdecb6a7f22034255486d7065cf1..9a5578efbc9368437c559ba4ed358560721b512b
@@@ -245,15 -243,30 +243,37 @@@ struct device *get_cpu_device(unsigned 
        else
                return NULL;
  }
- EXPORT_SYMBOL_GPL(get_cpu_sysdev);
+ EXPORT_SYMBOL_GPL(get_cpu_device);
+ static struct attribute *cpu_root_attrs[] = {
+ #ifdef CONFIG_ARCH_CPU_PROBE_RELEASE
+       &dev_attr_probe.attr,
+       &dev_attr_release.attr,
+ #endif
+       &cpu_attrs[0].attr.attr,
+       &cpu_attrs[1].attr.attr,
+       &cpu_attrs[2].attr.attr,
+       &dev_attr_kernel_max.attr,
+       &dev_attr_offline.attr,
+       NULL
+ };
+ static struct attribute_group cpu_root_attr_group = {
+       .attrs = cpu_root_attrs,
+ };
+ static const struct attribute_group *cpu_root_attr_groups[] = {
+       &cpu_root_attr_group,
+       NULL,
+ };
  
-       struct sys_device *dev = get_cpu_sysdev(cpu);
-       return dev && container_of(dev, struct cpu, sysdev)->hotpluggable;
 +bool cpu_is_hotpluggable(unsigned cpu)
 +{
++      struct device *dev = get_cpu_device(cpu);
++      return dev && container_of(dev, struct cpu, dev)->hotpluggable;
 +}
 +EXPORT_SYMBOL_GPL(cpu_is_hotpluggable);
 +
  int __init cpu_dev_init(void)
  {
        int err;
Simple merge
Simple merge
Simple merge
Simple merge
Simple merge
Simple merge
Simple merge
Simple merge
Simple merge
Simple merge
Simple merge
Simple merge
index 305c263021e7e6ae701c61b47ec2bbba0136aeec,fc3da0d70d6880c23794668303598d55f109a045..1f6587590a1afedf4a8c7478fde3d41a7de9d4e0
@@@ -26,16 -26,15 +26,16 @@@ struct cpu 
  };
  
  extern int register_cpu(struct cpu *cpu, int num);
- extern struct sys_device *get_cpu_sysdev(unsigned cpu);
+ extern struct device *get_cpu_device(unsigned cpu);
 +extern bool cpu_is_hotpluggable(unsigned cpu);
  
- extern int cpu_add_sysdev_attr(struct sysdev_attribute *attr);
- extern void cpu_remove_sysdev_attr(struct sysdev_attribute *attr);
+ extern int cpu_add_dev_attr(struct device_attribute *attr);
+ extern void cpu_remove_dev_attr(struct device_attribute *attr);
  
- extern int cpu_add_sysdev_attr_group(struct attribute_group *attrs);
- extern void cpu_remove_sysdev_attr_group(struct attribute_group *attrs);
+ extern int cpu_add_dev_attr_group(struct attribute_group *attrs);
+ extern void cpu_remove_dev_attr_group(struct attribute_group *attrs);
  
- extern int sched_create_sysfs_power_savings_entries(struct sysdev_class *cls);
+ extern int sched_create_sysfs_power_savings_entries(struct device *dev);
  
  #ifdef CONFIG_HOTPLUG_CPU
  extern void unregister_cpu(struct cpu *cpu);
Simple merge
diff --cc lib/Makefile
Simple merge