Merge tag 'soc' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc
authorLinus Torvalds <torvalds@linux-foundation.org>
Tue, 27 Mar 2012 23:14:44 +0000 (16:14 -0700)
committerLinus Torvalds <torvalds@linux-foundation.org>
Tue, 27 Mar 2012 23:14:44 +0000 (16:14 -0700)
Pull "ARM: SoC specific updates" from Arnd Bergmann:
 "These changes are all specific to an soc family or the code for one
  soc.  Lots of work for Tegra3 this time, but also a lot of other
  platforms.  There will be another (smaller) set of soc patches later
  in the merge window for stuff that has dependencies on external trees
  or that was sent just before the merge window opened.

  The asoc tree added a few devices to the i.mx platform, which conflict
  with other devices added in the same place here.

  The tegra Makefile conflicts between a number of branches, mostly
  because of changes regarding localtimer.c, which was removed in the
  end.

Signed-off-by: Arnd Bergmann <arnd@arndb.de>"
Fix up some trivial conflicts, including the mentioned Tegra Makefile.

* tag 'soc' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc: (51 commits)
  ARM: EXYNOS: fix cycle count for periodic mode of clock event timers
  ARM: EXYNOS: add support JPEG
  ARM: EXYNOS: Add DMC1, allow PPMU access for DMC
  ARM: SAMSUNG: Correct MIPI-CSIS io memory resource definition
  ARM: SAMSUNG: fix __init attribute on regarding s3c_set_platdata()
  ARM: SAMSUNG: Add __init attribute to samsung_bl_set()
  ARM: S5PV210: Add usb otg phy control
  ARM: S3C64XX: Add usb otg phy control
  ARM: EXYNOS: Enable l2 configuration through device tree
  ARM: EXYNOS: remove useless code to save/restore L2
  ARM: EXYNOS: save L2 settings during bootup
  ARM: S5P: add L2 early resume code
  ARM: EXYNOS: Add support AFTR mode on EXYNOS4210
  ARM: mx35: Setup the AIPS registers
  ARM: mx5: Use common function for configuring AIPS
  ARM: mx3: Setup AIPS registers
  ARM: mx3: Let mx31 and mx35 enter in LPM mode in WFI
  ARM: defconfig: imx_v6_v7: build in REGULATOR_FIXED_VOLTAGE
  ARM: imx: update imx_v6_v7_defconfig
  ARM: tegra: Demote EMC clock inconsistency BUG to WARN
  ...

13 files changed:
1  2 
arch/arm/Kconfig
arch/arm/mach-exynos/common.c
arch/arm/mach-exynos/mct.c
arch/arm/mach-highbank/highbank.c
arch/arm/mach-imx/Makefile
arch/arm/mach-imx/crmregs-imx3.h
arch/arm/mach-imx/mm-imx3.c
arch/arm/mach-imx/mm-imx5.c
arch/arm/mach-omap2/id.c
arch/arm/mach-omap2/io.c
arch/arm/mach-tegra/Makefile
arch/arm/mach-tegra/common.c
arch/arm/plat-omap/include/plat/cpu.h

Simple merge
Simple merge
Simple merge
index bb1684f9b68bfabf36ce7d0e08c03374f5004c46,a96183e73fad800481b8cacc7133dab155b05cb6..808b055289b2b0443cf5f197e47f3eac11aa6679
@@@ -110,10 -109,8 +110,10 @@@ static void __init highbank_timer_init(
  
        highbank_clocks_init();
  
-       sp804_clocksource_init(timer_base + 0x20, "timer1");
+       sp804_clocksource_and_sched_clock_init(timer_base + 0x20, "timer1");
        sp804_clockevents_init(timer_base, irq, "timer0");
 +
 +      twd_local_timer_of_register();
  }
  
  static struct sys_timer highbank_timer = {
Simple merge
index d7691e2362c1c10c0bf2b5dadb2a568b2df716c8,0000000000000000000000000000000000000000..53141273df452059ed38e43e0a2cb23e5df8421e
mode 100644,000000..100644
--- /dev/null
@@@ -1,261 -1,0 +1,262 @@@
 +/*
 + * Copyright 2004-2007 Freescale Semiconductor, Inc. All Rights Reserved.
 + * Copyright (C) 2008 by Sascha Hauer <kernel@pengutronix.de>
 + *
 + * This program is free software; you can redistribute it and/or
 + * modify it under the terms of the GNU General Public License
 + * as published by the Free Software Foundation; either version 2
 + * of the License, or (at your option) any later version.
 + * This program is distributed in the hope that it will be useful,
 + * but WITHOUT ANY WARRANTY; without even the implied warranty of
 + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 + * GNU General Public License for more details.
 + *
 + * You should have received a copy of the GNU General Public License
 + * along with this program; if not, write to the Free Software
 + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
 + * MA 02110-1301, USA.
 + */
 +
 +#ifndef __ARCH_ARM_MACH_MX3_CRM_REGS_H__
 +#define __ARCH_ARM_MACH_MX3_CRM_REGS_H__
 +
 +#define CKIH_CLK_FREQ           26000000
 +#define CKIH_CLK_FREQ_27MHZ     27000000
 +#define CKIL_CLK_FREQ           32768
 +
 +#define MXC_CCM_BASE          (cpu_is_mx31() ? \
 +MX31_IO_ADDRESS(MX31_CCM_BASE_ADDR) : MX35_IO_ADDRESS(MX35_CCM_BASE_ADDR))
 +
 +/* Register addresses */
 +#define MXC_CCM_CCMR          (MXC_CCM_BASE + 0x00)
 +#define MXC_CCM_PDR0          (MXC_CCM_BASE + 0x04)
 +#define MXC_CCM_PDR1          (MXC_CCM_BASE + 0x08)
 +#define MX35_CCM_PDR2         (MXC_CCM_BASE + 0x0C)
 +#define MXC_CCM_RCSR          (MXC_CCM_BASE + 0x0C)
 +#define MX35_CCM_PDR3         (MXC_CCM_BASE + 0x10)
 +#define MXC_CCM_MPCTL         (MXC_CCM_BASE + 0x10)
 +#define MX35_CCM_PDR4         (MXC_CCM_BASE + 0x14)
 +#define MXC_CCM_UPCTL         (MXC_CCM_BASE + 0x14)
 +#define MX35_CCM_RCSR         (MXC_CCM_BASE + 0x18)
 +#define MXC_CCM_SRPCTL                (MXC_CCM_BASE + 0x18)
 +#define MX35_CCM_MPCTL                (MXC_CCM_BASE + 0x1C)
 +#define MXC_CCM_COSR          (MXC_CCM_BASE + 0x1C)
 +#define MX35_CCM_PPCTL                (MXC_CCM_BASE + 0x20)
 +#define MXC_CCM_CGR0          (MXC_CCM_BASE + 0x20)
 +#define MX35_CCM_ACMR         (MXC_CCM_BASE + 0x24)
 +#define MXC_CCM_CGR1          (MXC_CCM_BASE + 0x24)
 +#define MX35_CCM_COSR         (MXC_CCM_BASE + 0x28)
 +#define MXC_CCM_CGR2          (MXC_CCM_BASE + 0x28)
 +#define MX35_CCM_CGR0         (MXC_CCM_BASE + 0x2C)
 +#define MXC_CCM_WIMR          (MXC_CCM_BASE + 0x2C)
 +#define MX35_CCM_CGR1         (MXC_CCM_BASE + 0x30)
 +#define MXC_CCM_LDC           (MXC_CCM_BASE + 0x30)
 +#define MX35_CCM_CGR2         (MXC_CCM_BASE + 0x34)
 +#define MXC_CCM_DCVR0         (MXC_CCM_BASE + 0x34)
 +#define MX35_CCM_CGR3         (MXC_CCM_BASE + 0x38)
 +#define MXC_CCM_DCVR1         (MXC_CCM_BASE + 0x38)
 +#define MXC_CCM_DCVR2         (MXC_CCM_BASE + 0x3C)
 +#define MXC_CCM_DCVR3         (MXC_CCM_BASE + 0x40)
 +#define MXC_CCM_LTR0          (MXC_CCM_BASE + 0x44)
 +#define MXC_CCM_LTR1          (MXC_CCM_BASE + 0x48)
 +#define MXC_CCM_LTR2          (MXC_CCM_BASE + 0x4C)
 +#define MXC_CCM_LTR3          (MXC_CCM_BASE + 0x50)
 +#define MXC_CCM_LTBR0         (MXC_CCM_BASE + 0x54)
 +#define MXC_CCM_LTBR1         (MXC_CCM_BASE + 0x58)
 +#define MXC_CCM_PMCR0         (MXC_CCM_BASE + 0x5C)
 +#define MXC_CCM_PMCR1         (MXC_CCM_BASE + 0x60)
 +#define MXC_CCM_PDR2          (MXC_CCM_BASE + 0x64)
 +
 +/* Register bit definitions */
 +#define MXC_CCM_CCMR_WBEN                       (1 << 27)
 +#define MXC_CCM_CCMR_CSCS                       (1 << 25)
 +#define MXC_CCM_CCMR_PERCS                      (1 << 24)
 +#define MXC_CCM_CCMR_SSI1S_OFFSET               18
 +#define MXC_CCM_CCMR_SSI1S_MASK                 (0x3 << 18)
 +#define MXC_CCM_CCMR_SSI2S_OFFSET               21
 +#define MXC_CCM_CCMR_SSI2S_MASK                 (0x3 << 21)
 +#define MXC_CCM_CCMR_LPM_OFFSET                 14
 +#define MXC_CCM_CCMR_LPM_MASK                   (0x3 << 14)
++#define MXC_CCM_CCMR_LPM_WAIT_MX35            (0x1 << 14)
 +#define MXC_CCM_CCMR_FIRS_OFFSET                11
 +#define MXC_CCM_CCMR_FIRS_MASK                  (0x3 << 11)
 +#define MXC_CCM_CCMR_UPE                        (1 << 9)
 +#define MXC_CCM_CCMR_SPE                        (1 << 8)
 +#define MXC_CCM_CCMR_MDS                        (1 << 7)
 +#define MXC_CCM_CCMR_SBYCS                      (1 << 4)
 +#define MXC_CCM_CCMR_MPE                        (1 << 3)
 +#define MXC_CCM_CCMR_PRCS_OFFSET                1
 +#define MXC_CCM_CCMR_PRCS_MASK                  (0x3 << 1)
 +
 +#define MXC_CCM_PDR0_CSI_PODF_OFFSET            26
 +#define MXC_CCM_PDR0_CSI_PODF_MASK              (0x3F << 26)
 +#define MXC_CCM_PDR0_CSI_PRDF_OFFSET            23
 +#define MXC_CCM_PDR0_CSI_PRDF_MASK              (0x7 << 23)
 +#define MXC_CCM_PDR0_PER_PODF_OFFSET            16
 +#define MXC_CCM_PDR0_PER_PODF_MASK              (0x1F << 16)
 +#define MXC_CCM_PDR0_HSP_PODF_OFFSET            11
 +#define MXC_CCM_PDR0_HSP_PODF_MASK              (0x7 << 11)
 +#define MXC_CCM_PDR0_NFC_PODF_OFFSET            8
 +#define MXC_CCM_PDR0_NFC_PODF_MASK              (0x7 << 8)
 +#define MXC_CCM_PDR0_IPG_PODF_OFFSET            6
 +#define MXC_CCM_PDR0_IPG_PODF_MASK              (0x3 << 6)
 +#define MXC_CCM_PDR0_MAX_PODF_OFFSET            3
 +#define MXC_CCM_PDR0_MAX_PODF_MASK              (0x7 << 3)
 +#define MXC_CCM_PDR0_MCU_PODF_OFFSET            0
 +#define MXC_CCM_PDR0_MCU_PODF_MASK              0x7
 +
 +#define MXC_CCM_PDR1_USB_PRDF_OFFSET            30
 +#define MXC_CCM_PDR1_USB_PRDF_MASK              (0x3 << 30)
 +#define MXC_CCM_PDR1_USB_PODF_OFFSET            27
 +#define MXC_CCM_PDR1_USB_PODF_MASK              (0x7 << 27)
 +#define MXC_CCM_PDR1_FIRI_PRE_PODF_OFFSET       24
 +#define MXC_CCM_PDR1_FIRI_PRE_PODF_MASK         (0x7 << 24)
 +#define MXC_CCM_PDR1_FIRI_PODF_OFFSET           18
 +#define MXC_CCM_PDR1_FIRI_PODF_MASK             (0x3F << 18)
 +#define MXC_CCM_PDR1_SSI2_PRE_PODF_OFFSET       15
 +#define MXC_CCM_PDR1_SSI2_PRE_PODF_MASK         (0x7 << 15)
 +#define MXC_CCM_PDR1_SSI2_PODF_OFFSET           9
 +#define MXC_CCM_PDR1_SSI2_PODF_MASK             (0x3F << 9)
 +#define MXC_CCM_PDR1_SSI1_PRE_PODF_OFFSET       6
 +#define MXC_CCM_PDR1_SSI1_PRE_PODF_MASK         (0x7 << 6)
 +#define MXC_CCM_PDR1_SSI1_PODF_OFFSET           0
 +#define MXC_CCM_PDR1_SSI1_PODF_MASK             0x3F
 +
 +/* Bit definitions for RCSR */
 +#define MXC_CCM_RCSR_NF16B                    0x80000000
 +
 +/*
 + * LTR0 register offsets
 + */
 +#define MXC_CCM_LTR0_DIV3CK_OFFSET              1
 +#define MXC_CCM_LTR0_DIV3CK_MASK                (0x3 << 1)
 +#define MXC_CCM_LTR0_DNTHR_OFFSET               16
 +#define MXC_CCM_LTR0_DNTHR_MASK                 (0x3F << 16)
 +#define MXC_CCM_LTR0_UPTHR_OFFSET               22
 +#define MXC_CCM_LTR0_UPTHR_MASK                 (0x3F << 22)
 +
 +/*
 + * LTR1 register offsets
 + */
 +#define MXC_CCM_LTR1_PNCTHR_OFFSET              0
 +#define MXC_CCM_LTR1_PNCTHR_MASK                0x3F
 +#define MXC_CCM_LTR1_UPCNT_OFFSET               6
 +#define MXC_CCM_LTR1_UPCNT_MASK                 (0xFF << 6)
 +#define MXC_CCM_LTR1_DNCNT_OFFSET               14
 +#define MXC_CCM_LTR1_DNCNT_MASK                 (0xFF << 14)
 +#define MXC_CCM_LTR1_LTBRSR_MASK                0x400000
 +#define MXC_CCM_LTR1_LTBRSR_OFFSET              22
 +#define MXC_CCM_LTR1_LTBRSR                     0x400000
 +#define MXC_CCM_LTR1_LTBRSH                     0x800000
 +
 +/*
 + * LTR2 bit definitions. x ranges from 0 for WSW9 to 6 for WSW15
 + */
 +#define MXC_CCM_LTR2_WSW_OFFSET(x)              (11 + (x) * 3)
 +#define MXC_CCM_LTR2_WSW_MASK(x)                (0x7 << \
 +                                      MXC_CCM_LTR2_WSW_OFFSET((x)))
 +#define MXC_CCM_LTR2_EMAC_OFFSET                0
 +#define MXC_CCM_LTR2_EMAC_MASK                  0x1FF
 +
 +/*
 + * LTR3 bit definitions. x ranges from 0 for WSW0 to 8 for WSW8
 + */
 +#define MXC_CCM_LTR3_WSW_OFFSET(x)              (5 + (x) * 3)
 +#define MXC_CCM_LTR3_WSW_MASK(x)                (0x7 << \
 +                                      MXC_CCM_LTR3_WSW_OFFSET((x)))
 +
 +#define MXC_CCM_PMCR0_DFSUP1                    0x80000000
 +#define MXC_CCM_PMCR0_DFSUP1_SPLL               (0 << 31)
 +#define MXC_CCM_PMCR0_DFSUP1_MPLL               (1 << 31)
 +#define MXC_CCM_PMCR0_DFSUP0                    0x40000000
 +#define MXC_CCM_PMCR0_DFSUP0_PLL                (0 << 30)
 +#define MXC_CCM_PMCR0_DFSUP0_PDR                (1 << 30)
 +#define MXC_CCM_PMCR0_DFSUP_MASK                (0x3 << 30)
 +
 +#define DVSUP_TURBO                           0
 +#define DVSUP_HIGH                            1
 +#define DVSUP_MEDIUM                          2
 +#define DVSUP_LOW                             3
 +#define MXC_CCM_PMCR0_DVSUP_TURBO               (DVSUP_TURBO << 28)
 +#define MXC_CCM_PMCR0_DVSUP_HIGH                (DVSUP_HIGH << 28)
 +#define MXC_CCM_PMCR0_DVSUP_MEDIUM              (DVSUP_MEDIUM << 28)
 +#define MXC_CCM_PMCR0_DVSUP_LOW                 (DVSUP_LOW << 28)
 +#define MXC_CCM_PMCR0_DVSUP_OFFSET              28
 +#define MXC_CCM_PMCR0_DVSUP_MASK                (0x3 << 28)
 +#define MXC_CCM_PMCR0_UDSC                      0x08000000
 +#define MXC_CCM_PMCR0_UDSC_MASK                 (1 << 27)
 +#define MXC_CCM_PMCR0_UDSC_UP                   (1 << 27)
 +#define MXC_CCM_PMCR0_UDSC_DOWN                 (0 << 27)
 +
 +#define MXC_CCM_PMCR0_VSCNT_1                   (0x0 << 24)
 +#define MXC_CCM_PMCR0_VSCNT_2                   (0x1 << 24)
 +#define MXC_CCM_PMCR0_VSCNT_3                   (0x2 << 24)
 +#define MXC_CCM_PMCR0_VSCNT_4                   (0x3 << 24)
 +#define MXC_CCM_PMCR0_VSCNT_5                   (0x4 << 24)
 +#define MXC_CCM_PMCR0_VSCNT_6                   (0x5 << 24)
 +#define MXC_CCM_PMCR0_VSCNT_7                   (0x6 << 24)
 +#define MXC_CCM_PMCR0_VSCNT_8                   (0x7 << 24)
 +#define MXC_CCM_PMCR0_VSCNT_OFFSET              24
 +#define MXC_CCM_PMCR0_VSCNT_MASK                (0x7 << 24)
 +#define MXC_CCM_PMCR0_DVFEV                     0x00800000
 +#define MXC_CCM_PMCR0_DVFIS                     0x00400000
 +#define MXC_CCM_PMCR0_LBMI                      0x00200000
 +#define MXC_CCM_PMCR0_LBFL                      0x00100000
 +#define MXC_CCM_PMCR0_LBCF_4                    (0x0 << 18)
 +#define MXC_CCM_PMCR0_LBCF_8                    (0x1 << 18)
 +#define MXC_CCM_PMCR0_LBCF_12                   (0x2 << 18)
 +#define MXC_CCM_PMCR0_LBCF_16                   (0x3 << 18)
 +#define MXC_CCM_PMCR0_LBCF_OFFSET               18
 +#define MXC_CCM_PMCR0_LBCF_MASK                 (0x3 << 18)
 +#define MXC_CCM_PMCR0_PTVIS                     0x00020000
 +#define MXC_CCM_PMCR0_UPDTEN                    0x00010000
 +#define MXC_CCM_PMCR0_UPDTEN_MASK               (0x1 << 16)
 +#define MXC_CCM_PMCR0_FSVAIM                    0x00008000
 +#define MXC_CCM_PMCR0_FSVAI_OFFSET              13
 +#define MXC_CCM_PMCR0_FSVAI_MASK                (0x3 << 13)
 +#define MXC_CCM_PMCR0_DPVCR                     0x00001000
 +#define MXC_CCM_PMCR0_DPVV                      0x00000800
 +#define MXC_CCM_PMCR0_WFIM                      0x00000400
 +#define MXC_CCM_PMCR0_DRCE3                     0x00000200
 +#define MXC_CCM_PMCR0_DRCE2                     0x00000100
 +#define MXC_CCM_PMCR0_DRCE1                     0x00000080
 +#define MXC_CCM_PMCR0_DRCE0                     0x00000040
 +#define MXC_CCM_PMCR0_DCR                       0x00000020
 +#define MXC_CCM_PMCR0_DVFEN                     0x00000010
 +#define MXC_CCM_PMCR0_PTVAIM                    0x00000008
 +#define MXC_CCM_PMCR0_PTVAI_OFFSET              1
 +#define MXC_CCM_PMCR0_PTVAI_MASK                (0x3 << 1)
 +#define MXC_CCM_PMCR0_DPTEN                     0x00000001
 +
 +#define MXC_CCM_PMCR1_DVGP_OFFSET               0
 +#define MXC_CCM_PMCR1_DVGP_MASK                 (0xF)
 +
 +#define MXC_CCM_PMCR1_PLLRDIS                      (0x1 << 7)
 +#define MXC_CCM_PMCR1_EMIRQ_EN                      (0x1 << 8)
 +
 +#define MXC_CCM_DCVR_ULV_MASK                   (0x3FF << 22)
 +#define MXC_CCM_DCVR_ULV_OFFSET                 22
 +#define MXC_CCM_DCVR_LLV_MASK                   (0x3FF << 12)
 +#define MXC_CCM_DCVR_LLV_OFFSET                 12
 +#define MXC_CCM_DCVR_ELV_MASK                   (0x3FF << 2)
 +#define MXC_CCM_DCVR_ELV_OFFSET                 2
 +
 +#define MXC_CCM_PDR2_MST2_PDF_MASK              (0x3F << 7)
 +#define MXC_CCM_PDR2_MST2_PDF_OFFSET            7
 +#define MXC_CCM_PDR2_MST1_PDF_MASK              0x3F
 +#define MXC_CCM_PDR2_MST1_PDF_OFFSET            0
 +
 +#define MXC_CCM_COSR_CLKOSEL_MASK               0x0F
 +#define MXC_CCM_COSR_CLKOSEL_OFFSET             0
 +#define MXC_CCM_COSR_CLKOUTDIV_MASK             (0x07 << 6)
 +#define MXC_CCM_COSR_CLKOUTDIV_OFFSET           6
 +#define MXC_CCM_COSR_CLKOEN                     (1 << 9)
 +
 +/*
 + * PMCR0 register offsets
 + */
 +#define MXC_CCM_PMCR0_LBFL_OFFSET   20
 +#define MXC_CCM_PMCR0_DFSUP0_OFFSET 30
 +#define MXC_CCM_PMCR0_DFSUP1_OFFSET 31
 +
 +#endif                                /* __ARCH_ARM_MACH_MX3_CRM_REGS_H__ */
index 07699196b461b467a872f255b1964f439081303d,2215814c8c2cfd6646c2b65de77507f473b6e1f4..f8ca96c354f2280aa1ba10af200b3e443fce51fb
@@@ -177,8 -175,9 +179,12 @@@ void __init imx31_soc_init(void
        }
  
        imx_add_imx_sdma("imx31-sdma", MX31_SDMA_BASE_ADDR, MX31_INT_SDMA, &imx31_sdma_pdata);
+       imx_set_aips(MX31_IO_ADDRESS(MX31_AIPS1_BASE_ADDR));
+       imx_set_aips(MX31_IO_ADDRESS(MX31_AIPS2_BASE_ADDR));
++
 +      platform_device_register_simple("imx31-audmux", 0, imx31_audmux_res,
 +                                      ARRAY_SIZE(imx31_audmux_res));
  }
  #endif /* ifdef CONFIG_SOC_IMX31 */
  
@@@ -267,8 -262,9 +273,13 @@@ void __init imx35_soc_init(void
        }
  
        imx_add_imx_sdma("imx35-sdma", MX35_SDMA_BASE_ADDR, MX35_INT_SDMA, &imx35_sdma_pdata);
+       /* Setup AIPS registers */
+       imx_set_aips(MX35_IO_ADDRESS(MX35_AIPS1_BASE_ADDR));
+       imx_set_aips(MX35_IO_ADDRESS(MX35_AIPS2_BASE_ADDR));
++
 +      /* i.mx35 has the i.mx31 type audmux */
 +      platform_device_register_simple("imx31-audmux", 0, imx35_audmux_res,
 +                                      ARRAY_SIZE(imx35_audmux_res));
  }
  #endif /* ifdef CONFIG_SOC_IMX35 */
index dc7c4ed815312a3a9cfda690b87ad646d587da84,92efecec12608af2095d6c0c8e75a62df6f987d0..51af9fa56944cf6daf19dc295e7d7ec7f1efd9d4
@@@ -201,9 -185,10 +201,14 @@@ void __init imx51_soc_init(void
  
        /* i.mx51 has the i.mx35 type sdma */
        imx_add_imx_sdma("imx35-sdma", MX51_SDMA_BASE_ADDR, MX51_INT_SDMA, &imx51_sdma_pdata);
+       /* Setup AIPS registers */
+       imx_set_aips(MX51_IO_ADDRESS(MX51_AIPS1_BASE_ADDR));
+       imx_set_aips(MX51_IO_ADDRESS(MX51_AIPS2_BASE_ADDR));
++
 +      /* i.mx51 has the i.mx31 type audmux */
 +      platform_device_register_simple("imx31-audmux", 0, imx51_audmux_res,
 +                                      ARRAY_SIZE(imx51_audmux_res));
  }
  
  void __init imx53_soc_init(void)
  
        /* i.mx53 has the i.mx35 type sdma */
        imx_add_imx_sdma("imx35-sdma", MX53_SDMA_BASE_ADDR, MX53_INT_SDMA, &imx53_sdma_pdata);
+       /* Setup AIPS registers */
+       imx_set_aips(MX53_IO_ADDRESS(MX53_AIPS1_BASE_ADDR));
+       imx_set_aips(MX53_IO_ADDRESS(MX53_AIPS2_BASE_ADDR));
++
 +      /* i.mx53 has the i.mx31 type audmux */
 +      platform_device_register_simple("imx31-audmux", 0, imx53_audmux_res,
 +                                      ARRAY_SIZE(imx53_audmux_res));
  }
Simple merge
Simple merge
index bcbb4e8d553068e0528e847799d6fd9aad8a8297,fc4ebe35f48404f396643e3434f94596202d0605..76a79b8a1721058fcb4938de96ca8ca5405e7911
@@@ -13,7 -15,8 +15,8 @@@ obj-$(CONFIG_ARCH_TEGRA_2x_SOC)               += teg
  obj-$(CONFIG_ARCH_TEGRA_2x_SOC)               += pinmux-tegra20-tables.o
  obj-$(CONFIG_ARCH_TEGRA_3x_SOC)               += pinmux-tegra30-tables.o
  obj-$(CONFIG_ARCH_TEGRA_3x_SOC)               += board-dt-tegra30.o
 -obj-$(CONFIG_SMP)                       += platsmp.o localtimer.o headsmp.o
+ obj-$(CONFIG_ARCH_TEGRA_3x_SOC)               += tegra30_clocks.o
 +obj-$(CONFIG_SMP)                     += platsmp.o headsmp.o
  obj-$(CONFIG_HOTPLUG_CPU)               += hotplug.o
  obj-$(CONFIG_TEGRA_SYSTEM_DMA)                += dma.o
  obj-$(CONFIG_CPU_FREQ)                  += cpu-tegra.o
Simple merge
Simple merge