diff options
25 files changed, 277 insertions, 124 deletions
diff --git a/.get_maintainer.ignore b/.get_maintainer.ignore index cca6d870f7a5..a64d21913745 100644 --- a/.get_maintainer.ignore +++ b/.get_maintainer.ignore | |||
| @@ -1 +1,2 @@ | |||
| 1 | Christoph Hellwig <hch@lst.de> | 1 | Christoph Hellwig <hch@lst.de> |
| 2 | Marc Gonzalez <marc.w.gonzalez@free.fr> | ||
diff --git a/Documentation/devicetree/bindings/arm/atmel-at91.txt b/Documentation/devicetree/bindings/arm/atmel-at91.txt index 4bf1b4da7659..99dee23c74a4 100644 --- a/Documentation/devicetree/bindings/arm/atmel-at91.txt +++ b/Documentation/devicetree/bindings/arm/atmel-at91.txt | |||
| @@ -25,6 +25,7 @@ compatible: must be one of: | |||
| 25 | o "atmel,at91sam9n12" | 25 | o "atmel,at91sam9n12" |
| 26 | o "atmel,at91sam9rl" | 26 | o "atmel,at91sam9rl" |
| 27 | o "atmel,at91sam9xe" | 27 | o "atmel,at91sam9xe" |
| 28 | o "microchip,sam9x60" | ||
| 28 | * "atmel,sama5" for SoCs using a Cortex-A5, shall be extended with the specific | 29 | * "atmel,sama5" for SoCs using a Cortex-A5, shall be extended with the specific |
| 29 | SoC family: | 30 | SoC family: |
| 30 | o "atmel,sama5d2" shall be extended with the specific SoC compatible: | 31 | o "atmel,sama5d2" shall be extended with the specific SoC compatible: |
diff --git a/arch/arm/boot/dts/logicpd-som-lv-baseboard.dtsi b/arch/arm/boot/dts/logicpd-som-lv-baseboard.dtsi index 4990ed90dcea..3e39b9a1f35d 100644 --- a/arch/arm/boot/dts/logicpd-som-lv-baseboard.dtsi +++ b/arch/arm/boot/dts/logicpd-som-lv-baseboard.dtsi | |||
| @@ -153,7 +153,7 @@ | |||
| 153 | pinctrl-names = "default"; | 153 | pinctrl-names = "default"; |
| 154 | pinctrl-0 = <&mmc1_pins>; | 154 | pinctrl-0 = <&mmc1_pins>; |
| 155 | wp-gpios = <&gpio4 30 GPIO_ACTIVE_HIGH>; /* gpio_126 */ | 155 | wp-gpios = <&gpio4 30 GPIO_ACTIVE_HIGH>; /* gpio_126 */ |
| 156 | cd-gpios = <&gpio4 14 IRQ_TYPE_LEVEL_LOW>; /* gpio_110 */ | 156 | cd-gpios = <&gpio4 14 GPIO_ACTIVE_LOW>; /* gpio_110 */ |
| 157 | vmmc-supply = <&vmmc1>; | 157 | vmmc-supply = <&vmmc1>; |
| 158 | bus-width = <4>; | 158 | bus-width = <4>; |
| 159 | cap-power-off-card; | 159 | cap-power-off-card; |
diff --git a/arch/arm/configs/sama5_defconfig b/arch/arm/configs/sama5_defconfig index 515cb37eeab6..d5341b0bd88d 100644 --- a/arch/arm/configs/sama5_defconfig +++ b/arch/arm/configs/sama5_defconfig | |||
| @@ -150,7 +150,7 @@ CONFIG_MEDIA_CAMERA_SUPPORT=y | |||
| 150 | CONFIG_V4L_PLATFORM_DRIVERS=y | 150 | CONFIG_V4L_PLATFORM_DRIVERS=y |
| 151 | CONFIG_SOC_CAMERA=y | 151 | CONFIG_SOC_CAMERA=y |
| 152 | CONFIG_VIDEO_ATMEL_ISI=y | 152 | CONFIG_VIDEO_ATMEL_ISI=y |
| 153 | CONFIG_SOC_CAMERA_OV2640=y | 153 | CONFIG_SOC_CAMERA_OV2640=m |
| 154 | CONFIG_DRM=y | 154 | CONFIG_DRM=y |
| 155 | CONFIG_DRM_ATMEL_HLCDC=y | 155 | CONFIG_DRM_ATMEL_HLCDC=y |
| 156 | CONFIG_DRM_PANEL_SIMPLE=y | 156 | CONFIG_DRM_PANEL_SIMPLE=y |
diff --git a/arch/arm/configs/socfpga_defconfig b/arch/arm/configs/socfpga_defconfig index 9d42cfe85f5b..6701a975e785 100644 --- a/arch/arm/configs/socfpga_defconfig +++ b/arch/arm/configs/socfpga_defconfig | |||
| @@ -21,7 +21,6 @@ CONFIG_NEON=y | |||
| 21 | CONFIG_OPROFILE=y | 21 | CONFIG_OPROFILE=y |
| 22 | CONFIG_MODULES=y | 22 | CONFIG_MODULES=y |
| 23 | CONFIG_MODULE_UNLOAD=y | 23 | CONFIG_MODULE_UNLOAD=y |
| 24 | # CONFIG_LBDAF is not set | ||
| 25 | # CONFIG_BLK_DEV_BSG is not set | 24 | # CONFIG_BLK_DEV_BSG is not set |
| 26 | CONFIG_NET=y | 25 | CONFIG_NET=y |
| 27 | CONFIG_PACKET=y | 26 | CONFIG_PACKET=y |
| @@ -128,6 +127,8 @@ CONFIG_RTC_DRV_DS1307=y | |||
| 128 | CONFIG_DMADEVICES=y | 127 | CONFIG_DMADEVICES=y |
| 129 | CONFIG_PL330_DMA=y | 128 | CONFIG_PL330_DMA=y |
| 130 | CONFIG_DMATEST=m | 129 | CONFIG_DMATEST=m |
| 130 | CONFIG_IIO=y | ||
| 131 | CONFIG_LTC2497=y | ||
| 131 | CONFIG_FPGA=y | 132 | CONFIG_FPGA=y |
| 132 | CONFIG_FPGA_MGR_SOCFPGA=y | 133 | CONFIG_FPGA_MGR_SOCFPGA=y |
| 133 | CONFIG_FPGA_MGR_SOCFPGA_A10=y | 134 | CONFIG_FPGA_MGR_SOCFPGA_A10=y |
diff --git a/arch/arm/mach-at91/Kconfig b/arch/arm/mach-at91/Kconfig index 903f23c309df..01b1bdb4fb6e 100644 --- a/arch/arm/mach-at91/Kconfig +++ b/arch/arm/mach-at91/Kconfig | |||
| @@ -21,7 +21,6 @@ config SOC_SAMA5D2 | |||
| 21 | depends on ARCH_MULTI_V7 | 21 | depends on ARCH_MULTI_V7 |
| 22 | select SOC_SAMA5 | 22 | select SOC_SAMA5 |
| 23 | select CACHE_L2X0 | 23 | select CACHE_L2X0 |
| 24 | select HAVE_FB_ATMEL | ||
| 25 | select HAVE_AT91_UTMI | 24 | select HAVE_AT91_UTMI |
| 26 | select HAVE_AT91_USB_CLK | 25 | select HAVE_AT91_USB_CLK |
| 27 | select HAVE_AT91_H32MX | 26 | select HAVE_AT91_H32MX |
| @@ -36,7 +35,6 @@ config SOC_SAMA5D3 | |||
| 36 | bool "SAMA5D3 family" | 35 | bool "SAMA5D3 family" |
| 37 | depends on ARCH_MULTI_V7 | 36 | depends on ARCH_MULTI_V7 |
| 38 | select SOC_SAMA5 | 37 | select SOC_SAMA5 |
| 39 | select HAVE_FB_ATMEL | ||
| 40 | select HAVE_AT91_UTMI | 38 | select HAVE_AT91_UTMI |
| 41 | select HAVE_AT91_SMD | 39 | select HAVE_AT91_SMD |
| 42 | select HAVE_AT91_USB_CLK | 40 | select HAVE_AT91_USB_CLK |
| @@ -50,7 +48,6 @@ config SOC_SAMA5D4 | |||
| 50 | depends on ARCH_MULTI_V7 | 48 | depends on ARCH_MULTI_V7 |
| 51 | select SOC_SAMA5 | 49 | select SOC_SAMA5 |
| 52 | select CACHE_L2X0 | 50 | select CACHE_L2X0 |
| 53 | select HAVE_FB_ATMEL | ||
| 54 | select HAVE_AT91_UTMI | 51 | select HAVE_AT91_UTMI |
| 55 | select HAVE_AT91_SMD | 52 | select HAVE_AT91_SMD |
| 56 | select HAVE_AT91_USB_CLK | 53 | select HAVE_AT91_USB_CLK |
diff --git a/arch/arm/mach-at91/at91sam9.c b/arch/arm/mach-at91/at91sam9.c index 3dbdef4d3cbf..c12563b09656 100644 --- a/arch/arm/mach-at91/at91sam9.c +++ b/arch/arm/mach-at91/at91sam9.c | |||
| @@ -32,3 +32,21 @@ DT_MACHINE_START(at91sam_dt, "Atmel AT91SAM9") | |||
| 32 | .init_machine = at91sam9_init, | 32 | .init_machine = at91sam9_init, |
| 33 | .dt_compat = at91_dt_board_compat, | 33 | .dt_compat = at91_dt_board_compat, |
| 34 | MACHINE_END | 34 | MACHINE_END |
| 35 | |||
| 36 | static void __init sam9x60_init(void) | ||
| 37 | { | ||
| 38 | of_platform_default_populate(NULL, NULL, NULL); | ||
| 39 | |||
| 40 | sam9x60_pm_init(); | ||
| 41 | } | ||
| 42 | |||
| 43 | static const char *const sam9x60_dt_board_compat[] __initconst = { | ||
| 44 | "microchip,sam9x60", | ||
| 45 | NULL | ||
| 46 | }; | ||
| 47 | |||
| 48 | DT_MACHINE_START(sam9x60_dt, "Microchip SAM9X60") | ||
| 49 | /* Maintainer: Microchip */ | ||
| 50 | .init_machine = sam9x60_init, | ||
| 51 | .dt_compat = sam9x60_dt_board_compat, | ||
| 52 | MACHINE_END | ||
diff --git a/arch/arm/mach-at91/generic.h b/arch/arm/mach-at91/generic.h index e2bd17237964..72b45accfa0f 100644 --- a/arch/arm/mach-at91/generic.h +++ b/arch/arm/mach-at91/generic.h | |||
| @@ -14,11 +14,13 @@ | |||
| 14 | #ifdef CONFIG_PM | 14 | #ifdef CONFIG_PM |
| 15 | extern void __init at91rm9200_pm_init(void); | 15 | extern void __init at91rm9200_pm_init(void); |
| 16 | extern void __init at91sam9_pm_init(void); | 16 | extern void __init at91sam9_pm_init(void); |
| 17 | extern void __init sam9x60_pm_init(void); | ||
| 17 | extern void __init sama5_pm_init(void); | 18 | extern void __init sama5_pm_init(void); |
| 18 | extern void __init sama5d2_pm_init(void); | 19 | extern void __init sama5d2_pm_init(void); |
| 19 | #else | 20 | #else |
| 20 | static inline void __init at91rm9200_pm_init(void) { } | 21 | static inline void __init at91rm9200_pm_init(void) { } |
| 21 | static inline void __init at91sam9_pm_init(void) { } | 22 | static inline void __init at91sam9_pm_init(void) { } |
| 23 | static inline void __init sam9x60_pm_init(void) { } | ||
| 22 | static inline void __init sama5_pm_init(void) { } | 24 | static inline void __init sama5_pm_init(void) { } |
| 23 | static inline void __init sama5d2_pm_init(void) { } | 25 | static inline void __init sama5d2_pm_init(void) { } |
| 24 | #endif | 26 | #endif |
diff --git a/arch/arm/mach-at91/pm.c b/arch/arm/mach-at91/pm.c index 2a757dcaa1a5..6c8147536f3d 100644 --- a/arch/arm/mach-at91/pm.c +++ b/arch/arm/mach-at91/pm.c | |||
| @@ -39,6 +39,20 @@ extern void at91_pinctrl_gpio_suspend(void); | |||
| 39 | extern void at91_pinctrl_gpio_resume(void); | 39 | extern void at91_pinctrl_gpio_resume(void); |
| 40 | #endif | 40 | #endif |
| 41 | 41 | ||
| 42 | struct at91_soc_pm { | ||
| 43 | int (*config_shdwc_ws)(void __iomem *shdwc, u32 *mode, u32 *polarity); | ||
| 44 | int (*config_pmc_ws)(void __iomem *pmc, u32 mode, u32 polarity); | ||
| 45 | const struct of_device_id *ws_ids; | ||
| 46 | struct at91_pm_data data; | ||
| 47 | }; | ||
| 48 | |||
| 49 | static struct at91_soc_pm soc_pm = { | ||
| 50 | .data = { | ||
| 51 | .standby_mode = AT91_PM_STANDBY, | ||
| 52 | .suspend_mode = AT91_PM_ULP0, | ||
| 53 | }, | ||
| 54 | }; | ||
| 55 | |||
| 42 | static const match_table_t pm_modes __initconst = { | 56 | static const match_table_t pm_modes __initconst = { |
| 43 | { AT91_PM_STANDBY, "standby" }, | 57 | { AT91_PM_STANDBY, "standby" }, |
| 44 | { AT91_PM_ULP0, "ulp0" }, | 58 | { AT91_PM_ULP0, "ulp0" }, |
| @@ -47,16 +61,11 @@ static const match_table_t pm_modes __initconst = { | |||
| 47 | { -1, NULL }, | 61 | { -1, NULL }, |
| 48 | }; | 62 | }; |
| 49 | 63 | ||
| 50 | static struct at91_pm_data pm_data = { | ||
| 51 | .standby_mode = AT91_PM_STANDBY, | ||
| 52 | .suspend_mode = AT91_PM_ULP0, | ||
| 53 | }; | ||
| 54 | |||
| 55 | #define at91_ramc_read(id, field) \ | 64 | #define at91_ramc_read(id, field) \ |
| 56 | __raw_readl(pm_data.ramc[id] + field) | 65 | __raw_readl(soc_pm.data.ramc[id] + field) |
| 57 | 66 | ||
| 58 | #define at91_ramc_write(id, field, value) \ | 67 | #define at91_ramc_write(id, field, value) \ |
| 59 | __raw_writel(value, pm_data.ramc[id] + field) | 68 | __raw_writel(value, soc_pm.data.ramc[id] + field) |
| 60 | 69 | ||
| 61 | static int at91_pm_valid_state(suspend_state_t state) | 70 | static int at91_pm_valid_state(suspend_state_t state) |
| 62 | { | 71 | { |
| @@ -91,6 +100,8 @@ static const struct wakeup_source_info ws_info[] = { | |||
| 91 | { .pmc_fsmr_bit = AT91_PMC_RTCAL, .shdwc_mr_bit = BIT(17) }, | 100 | { .pmc_fsmr_bit = AT91_PMC_RTCAL, .shdwc_mr_bit = BIT(17) }, |
| 92 | { .pmc_fsmr_bit = AT91_PMC_USBAL }, | 101 | { .pmc_fsmr_bit = AT91_PMC_USBAL }, |
| 93 | { .pmc_fsmr_bit = AT91_PMC_SDMMC_CD }, | 102 | { .pmc_fsmr_bit = AT91_PMC_SDMMC_CD }, |
| 103 | { .pmc_fsmr_bit = AT91_PMC_RTTAL }, | ||
| 104 | { .pmc_fsmr_bit = AT91_PMC_RXLP_MCE }, | ||
| 94 | }; | 105 | }; |
| 95 | 106 | ||
| 96 | static const struct of_device_id sama5d2_ws_ids[] = { | 107 | static const struct of_device_id sama5d2_ws_ids[] = { |
| @@ -105,6 +116,17 @@ static const struct of_device_id sama5d2_ws_ids[] = { | |||
| 105 | { /* sentinel */ } | 116 | { /* sentinel */ } |
| 106 | }; | 117 | }; |
| 107 | 118 | ||
| 119 | static const struct of_device_id sam9x60_ws_ids[] = { | ||
| 120 | { .compatible = "atmel,at91sam9x5-rtc", .data = &ws_info[1] }, | ||
| 121 | { .compatible = "atmel,at91rm9200-ohci", .data = &ws_info[2] }, | ||
| 122 | { .compatible = "usb-ohci", .data = &ws_info[2] }, | ||
| 123 | { .compatible = "atmel,at91sam9g45-ehci", .data = &ws_info[2] }, | ||
| 124 | { .compatible = "usb-ehci", .data = &ws_info[2] }, | ||
| 125 | { .compatible = "atmel,at91sam9260-rtt", .data = &ws_info[4] }, | ||
| 126 | { .compatible = "cdns,sam9x60-macb", .data = &ws_info[5] }, | ||
| 127 | { /* sentinel */ } | ||
| 128 | }; | ||
| 129 | |||
| 108 | static int at91_pm_config_ws(unsigned int pm_mode, bool set) | 130 | static int at91_pm_config_ws(unsigned int pm_mode, bool set) |
| 109 | { | 131 | { |
| 110 | const struct wakeup_source_info *wsi; | 132 | const struct wakeup_source_info *wsi; |
| @@ -116,24 +138,22 @@ static int at91_pm_config_ws(unsigned int pm_mode, bool set) | |||
| 116 | if (pm_mode != AT91_PM_ULP1) | 138 | if (pm_mode != AT91_PM_ULP1) |
| 117 | return 0; | 139 | return 0; |
| 118 | 140 | ||
| 119 | if (!pm_data.pmc || !pm_data.shdwc) | 141 | if (!soc_pm.data.pmc || !soc_pm.data.shdwc || !soc_pm.ws_ids) |
| 120 | return -EPERM; | 142 | return -EPERM; |
| 121 | 143 | ||
| 122 | if (!set) { | 144 | if (!set) { |
| 123 | writel(mode, pm_data.pmc + AT91_PMC_FSMR); | 145 | writel(mode, soc_pm.data.pmc + AT91_PMC_FSMR); |
| 124 | return 0; | 146 | return 0; |
| 125 | } | 147 | } |
| 126 | 148 | ||
| 127 | /* SHDWC.WUIR */ | 149 | if (soc_pm.config_shdwc_ws) |
| 128 | val = readl(pm_data.shdwc + 0x0c); | 150 | soc_pm.config_shdwc_ws(soc_pm.data.shdwc, &mode, &polarity); |
| 129 | mode |= (val & 0x3ff); | ||
| 130 | polarity |= ((val >> 16) & 0x3ff); | ||
| 131 | 151 | ||
| 132 | /* SHDWC.MR */ | 152 | /* SHDWC.MR */ |
| 133 | val = readl(pm_data.shdwc + 0x04); | 153 | val = readl(soc_pm.data.shdwc + 0x04); |
| 134 | 154 | ||
| 135 | /* Loop through defined wakeup sources. */ | 155 | /* Loop through defined wakeup sources. */ |
| 136 | for_each_matching_node_and_match(np, sama5d2_ws_ids, &match) { | 156 | for_each_matching_node_and_match(np, soc_pm.ws_ids, &match) { |
| 137 | pdev = of_find_device_by_node(np); | 157 | pdev = of_find_device_by_node(np); |
| 138 | if (!pdev) | 158 | if (!pdev) |
| 139 | continue; | 159 | continue; |
| @@ -155,8 +175,8 @@ put_device: | |||
| 155 | } | 175 | } |
| 156 | 176 | ||
| 157 | if (mode) { | 177 | if (mode) { |
| 158 | writel(mode, pm_data.pmc + AT91_PMC_FSMR); | 178 | if (soc_pm.config_pmc_ws) |
| 159 | writel(polarity, pm_data.pmc + AT91_PMC_FSPR); | 179 | soc_pm.config_pmc_ws(soc_pm.data.pmc, mode, polarity); |
| 160 | } else { | 180 | } else { |
| 161 | pr_err("AT91: PM: no ULP1 wakeup sources found!"); | 181 | pr_err("AT91: PM: no ULP1 wakeup sources found!"); |
| 162 | } | 182 | } |
| @@ -164,6 +184,34 @@ put_device: | |||
| 164 | return mode ? 0 : -EPERM; | 184 | return mode ? 0 : -EPERM; |
| 165 | } | 185 | } |
| 166 | 186 | ||
| 187 | static int at91_sama5d2_config_shdwc_ws(void __iomem *shdwc, u32 *mode, | ||
| 188 | u32 *polarity) | ||
| 189 | { | ||
| 190 | u32 val; | ||
| 191 | |||
| 192 | /* SHDWC.WUIR */ | ||
| 193 | val = readl(shdwc + 0x0c); | ||
| 194 | *mode |= (val & 0x3ff); | ||
| 195 | *polarity |= ((val >> 16) & 0x3ff); | ||
| 196 | |||
| 197 | return 0; | ||
| 198 | } | ||
| 199 | |||
| 200 | static int at91_sama5d2_config_pmc_ws(void __iomem *pmc, u32 mode, u32 polarity) | ||
| 201 | { | ||
| 202 | writel(mode, pmc + AT91_PMC_FSMR); | ||
| 203 | writel(polarity, pmc + AT91_PMC_FSPR); | ||
| 204 | |||
| 205 | return 0; | ||
| 206 | } | ||
| 207 | |||
| 208 | static int at91_sam9x60_config_pmc_ws(void __iomem *pmc, u32 mode, u32 polarity) | ||
| 209 | { | ||
| 210 | writel(mode, pmc + AT91_PMC_FSMR); | ||
| 211 | |||
| 212 | return 0; | ||
| 213 | } | ||
| 214 | |||
| 167 | /* | 215 | /* |
| 168 | * Called after processes are frozen, but before we shutdown devices. | 216 | * Called after processes are frozen, but before we shutdown devices. |
| 169 | */ | 217 | */ |
| @@ -171,18 +219,18 @@ static int at91_pm_begin(suspend_state_t state) | |||
| 171 | { | 219 | { |
| 172 | switch (state) { | 220 | switch (state) { |
| 173 | case PM_SUSPEND_MEM: | 221 | case PM_SUSPEND_MEM: |
| 174 | pm_data.mode = pm_data.suspend_mode; | 222 | soc_pm.data.mode = soc_pm.data.suspend_mode; |
| 175 | break; | 223 | break; |
| 176 | 224 | ||
| 177 | case PM_SUSPEND_STANDBY: | 225 | case PM_SUSPEND_STANDBY: |
| 178 | pm_data.mode = pm_data.standby_mode; | 226 | soc_pm.data.mode = soc_pm.data.standby_mode; |
| 179 | break; | 227 | break; |
| 180 | 228 | ||
| 181 | default: | 229 | default: |
| 182 | pm_data.mode = -1; | 230 | soc_pm.data.mode = -1; |
| 183 | } | 231 | } |
| 184 | 232 | ||
| 185 | return at91_pm_config_ws(pm_data.mode, true); | 233 | return at91_pm_config_ws(soc_pm.data.mode, true); |
| 186 | } | 234 | } |
| 187 | 235 | ||
| 188 | /* | 236 | /* |
| @@ -194,10 +242,10 @@ static int at91_pm_verify_clocks(void) | |||
| 194 | unsigned long scsr; | 242 | unsigned long scsr; |
| 195 | int i; | 243 | int i; |
| 196 | 244 | ||
| 197 | scsr = readl(pm_data.pmc + AT91_PMC_SCSR); | 245 | scsr = readl(soc_pm.data.pmc + AT91_PMC_SCSR); |
| 198 | 246 | ||
| 199 | /* USB must not be using PLLB */ | 247 | /* USB must not be using PLLB */ |
| 200 | if ((scsr & pm_data.uhp_udp_mask) != 0) { | 248 | if ((scsr & soc_pm.data.uhp_udp_mask) != 0) { |
| 201 | pr_err("AT91: PM - Suspend-to-RAM with USB still active\n"); | 249 | pr_err("AT91: PM - Suspend-to-RAM with USB still active\n"); |
| 202 | return 0; | 250 | return 0; |
| 203 | } | 251 | } |
| @@ -208,7 +256,7 @@ static int at91_pm_verify_clocks(void) | |||
| 208 | 256 | ||
| 209 | if ((scsr & (AT91_PMC_PCK0 << i)) == 0) | 257 | if ((scsr & (AT91_PMC_PCK0 << i)) == 0) |
| 210 | continue; | 258 | continue; |
| 211 | css = readl(pm_data.pmc + AT91_PMC_PCKR(i)) & AT91_PMC_CSS; | 259 | css = readl(soc_pm.data.pmc + AT91_PMC_PCKR(i)) & AT91_PMC_CSS; |
| 212 | if (css != AT91_PMC_CSS_SLOW) { | 260 | if (css != AT91_PMC_CSS_SLOW) { |
| 213 | pr_err("AT91: PM - Suspend-to-RAM with PCK%d src %d\n", i, css); | 261 | pr_err("AT91: PM - Suspend-to-RAM with PCK%d src %d\n", i, css); |
| 214 | return 0; | 262 | return 0; |
| @@ -230,7 +278,7 @@ static int at91_pm_verify_clocks(void) | |||
| 230 | */ | 278 | */ |
| 231 | int at91_suspend_entering_slow_clock(void) | 279 | int at91_suspend_entering_slow_clock(void) |
| 232 | { | 280 | { |
| 233 | return (pm_data.mode >= AT91_PM_ULP0); | 281 | return (soc_pm.data.mode >= AT91_PM_ULP0); |
| 234 | } | 282 | } |
| 235 | EXPORT_SYMBOL(at91_suspend_entering_slow_clock); | 283 | EXPORT_SYMBOL(at91_suspend_entering_slow_clock); |
| 236 | 284 | ||
| @@ -243,14 +291,14 @@ static int at91_suspend_finish(unsigned long val) | |||
| 243 | flush_cache_all(); | 291 | flush_cache_all(); |
| 244 | outer_disable(); | 292 | outer_disable(); |
| 245 | 293 | ||
| 246 | at91_suspend_sram_fn(&pm_data); | 294 | at91_suspend_sram_fn(&soc_pm.data); |
| 247 | 295 | ||
| 248 | return 0; | 296 | return 0; |
| 249 | } | 297 | } |
| 250 | 298 | ||
| 251 | static void at91_pm_suspend(suspend_state_t state) | 299 | static void at91_pm_suspend(suspend_state_t state) |
| 252 | { | 300 | { |
| 253 | if (pm_data.mode == AT91_PM_BACKUP) { | 301 | if (soc_pm.data.mode == AT91_PM_BACKUP) { |
| 254 | pm_bu->suspended = 1; | 302 | pm_bu->suspended = 1; |
| 255 | 303 | ||
| 256 | cpu_suspend(0, at91_suspend_finish); | 304 | cpu_suspend(0, at91_suspend_finish); |
| @@ -289,7 +337,7 @@ static int at91_pm_enter(suspend_state_t state) | |||
| 289 | /* | 337 | /* |
| 290 | * Ensure that clocks are in a valid state. | 338 | * Ensure that clocks are in a valid state. |
| 291 | */ | 339 | */ |
| 292 | if (pm_data.mode >= AT91_PM_ULP0 && | 340 | if (soc_pm.data.mode >= AT91_PM_ULP0 && |
| 293 | !at91_pm_verify_clocks()) | 341 | !at91_pm_verify_clocks()) |
| 294 | goto error; | 342 | goto error; |
| 295 | 343 | ||
| @@ -318,7 +366,7 @@ error: | |||
| 318 | */ | 366 | */ |
| 319 | static void at91_pm_end(void) | 367 | static void at91_pm_end(void) |
| 320 | { | 368 | { |
| 321 | at91_pm_config_ws(pm_data.mode, false); | 369 | at91_pm_config_ws(soc_pm.data.mode, false); |
| 322 | } | 370 | } |
| 323 | 371 | ||
| 324 | 372 | ||
| @@ -351,7 +399,7 @@ static void at91rm9200_standby(void) | |||
| 351 | " str %2, [%1, %3]\n\t" | 399 | " str %2, [%1, %3]\n\t" |
| 352 | " mcr p15, 0, %0, c7, c0, 4\n\t" | 400 | " mcr p15, 0, %0, c7, c0, 4\n\t" |
| 353 | : | 401 | : |
| 354 | : "r" (0), "r" (pm_data.ramc[0]), | 402 | : "r" (0), "r" (soc_pm.data.ramc[0]), |
| 355 | "r" (1), "r" (AT91_MC_SDRAMC_SRR)); | 403 | "r" (1), "r" (AT91_MC_SDRAMC_SRR)); |
| 356 | } | 404 | } |
| 357 | 405 | ||
| @@ -374,7 +422,7 @@ static void at91_ddr_standby(void) | |||
| 374 | at91_ramc_write(0, AT91_DDRSDRC_MDR, mdr); | 422 | at91_ramc_write(0, AT91_DDRSDRC_MDR, mdr); |
| 375 | } | 423 | } |
| 376 | 424 | ||
| 377 | if (pm_data.ramc[1]) { | 425 | if (soc_pm.data.ramc[1]) { |
| 378 | saved_lpr1 = at91_ramc_read(1, AT91_DDRSDRC_LPR); | 426 | saved_lpr1 = at91_ramc_read(1, AT91_DDRSDRC_LPR); |
| 379 | lpr1 = saved_lpr1 & ~AT91_DDRSDRC_LPCB; | 427 | lpr1 = saved_lpr1 & ~AT91_DDRSDRC_LPCB; |
| 380 | lpr1 |= AT91_DDRSDRC_LPCB_SELF_REFRESH; | 428 | lpr1 |= AT91_DDRSDRC_LPCB_SELF_REFRESH; |
| @@ -392,14 +440,14 @@ static void at91_ddr_standby(void) | |||
| 392 | 440 | ||
| 393 | /* self-refresh mode now */ | 441 | /* self-refresh mode now */ |
| 394 | at91_ramc_write(0, AT91_DDRSDRC_LPR, lpr0); | 442 | at91_ramc_write(0, AT91_DDRSDRC_LPR, lpr0); |
| 395 | if (pm_data.ramc[1]) | 443 | if (soc_pm.data.ramc[1]) |
| 396 | at91_ramc_write(1, AT91_DDRSDRC_LPR, lpr1); | 444 | at91_ramc_write(1, AT91_DDRSDRC_LPR, lpr1); |
| 397 | 445 | ||
| 398 | cpu_do_idle(); | 446 | cpu_do_idle(); |
| 399 | 447 | ||
| 400 | at91_ramc_write(0, AT91_DDRSDRC_MDR, saved_mdr0); | 448 | at91_ramc_write(0, AT91_DDRSDRC_MDR, saved_mdr0); |
| 401 | at91_ramc_write(0, AT91_DDRSDRC_LPR, saved_lpr0); | 449 | at91_ramc_write(0, AT91_DDRSDRC_LPR, saved_lpr0); |
| 402 | if (pm_data.ramc[1]) { | 450 | if (soc_pm.data.ramc[1]) { |
| 403 | at91_ramc_write(0, AT91_DDRSDRC_MDR, saved_mdr1); | 451 | at91_ramc_write(0, AT91_DDRSDRC_MDR, saved_mdr1); |
| 404 | at91_ramc_write(1, AT91_DDRSDRC_LPR, saved_lpr1); | 452 | at91_ramc_write(1, AT91_DDRSDRC_LPR, saved_lpr1); |
| 405 | } | 453 | } |
| @@ -429,7 +477,7 @@ static void at91sam9_sdram_standby(void) | |||
| 429 | u32 lpr0, lpr1 = 0; | 477 | u32 lpr0, lpr1 = 0; |
| 430 | u32 saved_lpr0, saved_lpr1 = 0; | 478 | u32 saved_lpr0, saved_lpr1 = 0; |
| 431 | 479 | ||
| 432 | if (pm_data.ramc[1]) { | 480 | if (soc_pm.data.ramc[1]) { |
| 433 | saved_lpr1 = at91_ramc_read(1, AT91_SDRAMC_LPR); | 481 | saved_lpr1 = at91_ramc_read(1, AT91_SDRAMC_LPR); |
| 434 | lpr1 = saved_lpr1 & ~AT91_SDRAMC_LPCB; | 482 | lpr1 = saved_lpr1 & ~AT91_SDRAMC_LPCB; |
| 435 | lpr1 |= AT91_SDRAMC_LPCB_SELF_REFRESH; | 483 | lpr1 |= AT91_SDRAMC_LPCB_SELF_REFRESH; |
| @@ -441,13 +489,13 @@ static void at91sam9_sdram_standby(void) | |||
| 441 | 489 | ||
| 442 | /* self-refresh mode now */ | 490 | /* self-refresh mode now */ |
| 443 | at91_ramc_write(0, AT91_SDRAMC_LPR, lpr0); | 491 | at91_ramc_write(0, AT91_SDRAMC_LPR, lpr0); |
| 444 | if (pm_data.ramc[1]) | 492 | if (soc_pm.data.ramc[1]) |
| 445 | at91_ramc_write(1, AT91_SDRAMC_LPR, lpr1); | 493 | at91_ramc_write(1, AT91_SDRAMC_LPR, lpr1); |
| 446 | 494 | ||
| 447 | cpu_do_idle(); | 495 | cpu_do_idle(); |
| 448 | 496 | ||
| 449 | at91_ramc_write(0, AT91_SDRAMC_LPR, saved_lpr0); | 497 | at91_ramc_write(0, AT91_SDRAMC_LPR, saved_lpr0); |
| 450 | if (pm_data.ramc[1]) | 498 | if (soc_pm.data.ramc[1]) |
| 451 | at91_ramc_write(1, AT91_SDRAMC_LPR, saved_lpr1); | 499 | at91_ramc_write(1, AT91_SDRAMC_LPR, saved_lpr1); |
| 452 | } | 500 | } |
| 453 | 501 | ||
| @@ -480,14 +528,14 @@ static __init void at91_dt_ramc(void) | |||
| 480 | const struct ramc_info *ramc; | 528 | const struct ramc_info *ramc; |
| 481 | 529 | ||
| 482 | for_each_matching_node_and_match(np, ramc_ids, &of_id) { | 530 | for_each_matching_node_and_match(np, ramc_ids, &of_id) { |
| 483 | pm_data.ramc[idx] = of_iomap(np, 0); | 531 | soc_pm.data.ramc[idx] = of_iomap(np, 0); |
| 484 | if (!pm_data.ramc[idx]) | 532 | if (!soc_pm.data.ramc[idx]) |
| 485 | panic(pr_fmt("unable to map ramc[%d] cpu registers\n"), idx); | 533 | panic(pr_fmt("unable to map ramc[%d] cpu registers\n"), idx); |
| 486 | 534 | ||
| 487 | ramc = of_id->data; | 535 | ramc = of_id->data; |
| 488 | if (!standby) | 536 | if (!standby) |
| 489 | standby = ramc->idle; | 537 | standby = ramc->idle; |
| 490 | pm_data.memctrl = ramc->memctrl; | 538 | soc_pm.data.memctrl = ramc->memctrl; |
| 491 | 539 | ||
| 492 | idx++; | 540 | idx++; |
| 493 | } | 541 | } |
| @@ -509,12 +557,17 @@ static void at91rm9200_idle(void) | |||
| 509 | * Disable the processor clock. The processor will be automatically | 557 | * Disable the processor clock. The processor will be automatically |
| 510 | * re-enabled by an interrupt or by a reset. | 558 | * re-enabled by an interrupt or by a reset. |
| 511 | */ | 559 | */ |
| 512 | writel(AT91_PMC_PCK, pm_data.pmc + AT91_PMC_SCDR); | 560 | writel(AT91_PMC_PCK, soc_pm.data.pmc + AT91_PMC_SCDR); |
| 561 | } | ||
| 562 | |||
| 563 | static void at91sam9x60_idle(void) | ||
| 564 | { | ||
| 565 | cpu_do_idle(); | ||
| 513 | } | 566 | } |
| 514 | 567 | ||
| 515 | static void at91sam9_idle(void) | 568 | static void at91sam9_idle(void) |
| 516 | { | 569 | { |
| 517 | writel(AT91_PMC_PCK, pm_data.pmc + AT91_PMC_SCDR); | 570 | writel(AT91_PMC_PCK, soc_pm.data.pmc + AT91_PMC_SCDR); |
| 518 | cpu_do_idle(); | 571 | cpu_do_idle(); |
| 519 | } | 572 | } |
| 520 | 573 | ||
| @@ -566,8 +619,8 @@ static void __init at91_pm_sram_init(void) | |||
| 566 | 619 | ||
| 567 | static bool __init at91_is_pm_mode_active(int pm_mode) | 620 | static bool __init at91_is_pm_mode_active(int pm_mode) |
| 568 | { | 621 | { |
| 569 | return (pm_data.standby_mode == pm_mode || | 622 | return (soc_pm.data.standby_mode == pm_mode || |
| 570 | pm_data.suspend_mode == pm_mode); | 623 | soc_pm.data.suspend_mode == pm_mode); |
| 571 | } | 624 | } |
| 572 | 625 | ||
| 573 | static int __init at91_pm_backup_init(void) | 626 | static int __init at91_pm_backup_init(void) |
| @@ -577,6 +630,9 @@ static int __init at91_pm_backup_init(void) | |||
| 577 | struct platform_device *pdev = NULL; | 630 | struct platform_device *pdev = NULL; |
| 578 | int ret = -ENODEV; | 631 | int ret = -ENODEV; |
| 579 | 632 | ||
| 633 | if (!IS_ENABLED(CONFIG_SOC_SAMA5D2)) | ||
| 634 | return -EPERM; | ||
| 635 | |||
| 580 | if (!at91_is_pm_mode_active(AT91_PM_BACKUP)) | 636 | if (!at91_is_pm_mode_active(AT91_PM_BACKUP)) |
| 581 | return 0; | 637 | return 0; |
| 582 | 638 | ||
| @@ -586,7 +642,7 @@ static int __init at91_pm_backup_init(void) | |||
| 586 | return ret; | 642 | return ret; |
| 587 | } | 643 | } |
| 588 | 644 | ||
| 589 | pm_data.sfrbu = of_iomap(np, 0); | 645 | soc_pm.data.sfrbu = of_iomap(np, 0); |
| 590 | of_node_put(np); | 646 | of_node_put(np); |
| 591 | 647 | ||
| 592 | np = of_find_compatible_node(NULL, NULL, "atmel,sama5d2-securam"); | 648 | np = of_find_compatible_node(NULL, NULL, "atmel,sama5d2-securam"); |
| @@ -622,8 +678,8 @@ static int __init at91_pm_backup_init(void) | |||
| 622 | securam_fail: | 678 | securam_fail: |
| 623 | put_device(&pdev->dev); | 679 | put_device(&pdev->dev); |
| 624 | securam_fail_no_ref_dev: | 680 | securam_fail_no_ref_dev: |
| 625 | iounmap(pm_data.sfrbu); | 681 | iounmap(soc_pm.data.sfrbu); |
| 626 | pm_data.sfrbu = NULL; | 682 | soc_pm.data.sfrbu = NULL; |
| 627 | return ret; | 683 | return ret; |
| 628 | } | 684 | } |
| 629 | 685 | ||
| @@ -632,10 +688,10 @@ static void __init at91_pm_use_default_mode(int pm_mode) | |||
| 632 | if (pm_mode != AT91_PM_ULP1 && pm_mode != AT91_PM_BACKUP) | 688 | if (pm_mode != AT91_PM_ULP1 && pm_mode != AT91_PM_BACKUP) |
| 633 | return; | 689 | return; |
| 634 | 690 | ||
| 635 | if (pm_data.standby_mode == pm_mode) | 691 | if (soc_pm.data.standby_mode == pm_mode) |
| 636 | pm_data.standby_mode = AT91_PM_ULP0; | 692 | soc_pm.data.standby_mode = AT91_PM_ULP0; |
| 637 | if (pm_data.suspend_mode == pm_mode) | 693 | if (soc_pm.data.suspend_mode == pm_mode) |
| 638 | pm_data.suspend_mode = AT91_PM_ULP0; | 694 | soc_pm.data.suspend_mode = AT91_PM_ULP0; |
| 639 | } | 695 | } |
| 640 | 696 | ||
| 641 | static void __init at91_pm_modes_init(void) | 697 | static void __init at91_pm_modes_init(void) |
| @@ -653,7 +709,7 @@ static void __init at91_pm_modes_init(void) | |||
| 653 | goto ulp1_default; | 709 | goto ulp1_default; |
| 654 | } | 710 | } |
| 655 | 711 | ||
| 656 | pm_data.shdwc = of_iomap(np, 0); | 712 | soc_pm.data.shdwc = of_iomap(np, 0); |
| 657 | of_node_put(np); | 713 | of_node_put(np); |
| 658 | 714 | ||
| 659 | ret = at91_pm_backup_init(); | 715 | ret = at91_pm_backup_init(); |
| @@ -667,8 +723,8 @@ static void __init at91_pm_modes_init(void) | |||
| 667 | return; | 723 | return; |
| 668 | 724 | ||
| 669 | unmap: | 725 | unmap: |
| 670 | iounmap(pm_data.shdwc); | 726 | iounmap(soc_pm.data.shdwc); |
| 671 | pm_data.shdwc = NULL; | 727 | soc_pm.data.shdwc = NULL; |
| 672 | ulp1_default: | 728 | ulp1_default: |
| 673 | at91_pm_use_default_mode(AT91_PM_ULP1); | 729 | at91_pm_use_default_mode(AT91_PM_ULP1); |
| 674 | backup_default: | 730 | backup_default: |
| @@ -711,14 +767,14 @@ static void __init at91_pm_init(void (*pm_idle)(void)) | |||
| 711 | platform_device_register(&at91_cpuidle_device); | 767 | platform_device_register(&at91_cpuidle_device); |
| 712 | 768 | ||
| 713 | pmc_np = of_find_matching_node_and_match(NULL, atmel_pmc_ids, &of_id); | 769 | pmc_np = of_find_matching_node_and_match(NULL, atmel_pmc_ids, &of_id); |
| 714 | pm_data.pmc = of_iomap(pmc_np, 0); | 770 | soc_pm.data.pmc = of_iomap(pmc_np, 0); |
| 715 | if (!pm_data.pmc) { | 771 | if (!soc_pm.data.pmc) { |
| 716 | pr_err("AT91: PM not supported, PMC not found\n"); | 772 | pr_err("AT91: PM not supported, PMC not found\n"); |
| 717 | return; | 773 | return; |
| 718 | } | 774 | } |
| 719 | 775 | ||
| 720 | pmc = of_id->data; | 776 | pmc = of_id->data; |
| 721 | pm_data.uhp_udp_mask = pmc->uhp_udp_mask; | 777 | soc_pm.data.uhp_udp_mask = pmc->uhp_udp_mask; |
| 722 | 778 | ||
| 723 | if (pm_idle) | 779 | if (pm_idle) |
| 724 | arm_pm_idle = pm_idle; | 780 | arm_pm_idle = pm_idle; |
| @@ -728,8 +784,8 @@ static void __init at91_pm_init(void (*pm_idle)(void)) | |||
| 728 | if (at91_suspend_sram_fn) { | 784 | if (at91_suspend_sram_fn) { |
| 729 | suspend_set_ops(&at91_pm_ops); | 785 | suspend_set_ops(&at91_pm_ops); |
| 730 | pr_info("AT91: PM: standby: %s, suspend: %s\n", | 786 | pr_info("AT91: PM: standby: %s, suspend: %s\n", |
| 731 | pm_modes[pm_data.standby_mode].pattern, | 787 | pm_modes[soc_pm.data.standby_mode].pattern, |
| 732 | pm_modes[pm_data.suspend_mode].pattern); | 788 | pm_modes[soc_pm.data.suspend_mode].pattern); |
| 733 | } else { | 789 | } else { |
| 734 | pr_info("AT91: PM not supported, due to no SRAM allocated\n"); | 790 | pr_info("AT91: PM not supported, due to no SRAM allocated\n"); |
| 735 | } | 791 | } |
| @@ -750,6 +806,19 @@ void __init at91rm9200_pm_init(void) | |||
| 750 | at91_pm_init(at91rm9200_idle); | 806 | at91_pm_init(at91rm9200_idle); |
| 751 | } | 807 | } |
| 752 | 808 | ||
| 809 | void __init sam9x60_pm_init(void) | ||
| 810 | { | ||
| 811 | if (!IS_ENABLED(CONFIG_SOC_AT91SAM9)) | ||
| 812 | return; | ||
| 813 | |||
| 814 | at91_pm_modes_init(); | ||
| 815 | at91_dt_ramc(); | ||
| 816 | at91_pm_init(at91sam9x60_idle); | ||
| 817 | |||
| 818 | soc_pm.ws_ids = sam9x60_ws_ids; | ||
| 819 | soc_pm.config_pmc_ws = at91_sam9x60_config_pmc_ws; | ||
| 820 | } | ||
| 821 | |||
| 753 | void __init at91sam9_pm_init(void) | 822 | void __init at91sam9_pm_init(void) |
| 754 | { | 823 | { |
| 755 | if (!IS_ENABLED(CONFIG_SOC_AT91SAM9)) | 824 | if (!IS_ENABLED(CONFIG_SOC_AT91SAM9)) |
| @@ -775,6 +844,10 @@ void __init sama5d2_pm_init(void) | |||
| 775 | 844 | ||
| 776 | at91_pm_modes_init(); | 845 | at91_pm_modes_init(); |
| 777 | sama5_pm_init(); | 846 | sama5_pm_init(); |
| 847 | |||
| 848 | soc_pm.ws_ids = sama5d2_ws_ids; | ||
| 849 | soc_pm.config_shdwc_ws = at91_sama5d2_config_shdwc_ws; | ||
| 850 | soc_pm.config_pmc_ws = at91_sama5d2_config_pmc_ws; | ||
| 778 | } | 851 | } |
| 779 | 852 | ||
| 780 | static int __init at91_pm_modes_select(char *str) | 853 | static int __init at91_pm_modes_select(char *str) |
| @@ -795,8 +868,8 @@ static int __init at91_pm_modes_select(char *str) | |||
| 795 | if (suspend < 0) | 868 | if (suspend < 0) |
| 796 | return 0; | 869 | return 0; |
| 797 | 870 | ||
| 798 | pm_data.standby_mode = standby; | 871 | soc_pm.data.standby_mode = standby; |
| 799 | pm_data.suspend_mode = suspend; | 872 | soc_pm.data.suspend_mode = suspend; |
| 800 | 873 | ||
| 801 | return 0; | 874 | return 0; |
| 802 | } | 875 | } |
diff --git a/arch/arm/mach-at91/pm_suspend.S b/arch/arm/mach-at91/pm_suspend.S index bfe1c4d06901..77e29309cc6e 100644 --- a/arch/arm/mach-at91/pm_suspend.S +++ b/arch/arm/mach-at91/pm_suspend.S | |||
| @@ -51,15 +51,6 @@ tmp2 .req r5 | |||
| 51 | .endm | 51 | .endm |
| 52 | 52 | ||
| 53 | /* | 53 | /* |
| 54 | * Wait until PLLA has locked. | ||
| 55 | */ | ||
| 56 | .macro wait_pllalock | ||
| 57 | 1: ldr tmp1, [pmc, #AT91_PMC_SR] | ||
| 58 | tst tmp1, #AT91_PMC_LOCKA | ||
| 59 | beq 1b | ||
| 60 | .endm | ||
| 61 | |||
| 62 | /* | ||
| 63 | * Put the processor to enter the idle state | 54 | * Put the processor to enter the idle state |
| 64 | */ | 55 | */ |
| 65 | .macro at91_cpu_idle | 56 | .macro at91_cpu_idle |
| @@ -178,11 +169,46 @@ ENDPROC(at91_backup_mode) | |||
| 178 | orr tmp1, tmp1, #AT91_PMC_KEY | 169 | orr tmp1, tmp1, #AT91_PMC_KEY |
| 179 | str tmp1, [pmc, #AT91_CKGR_MOR] | 170 | str tmp1, [pmc, #AT91_CKGR_MOR] |
| 180 | 171 | ||
| 172 | /* Save RC oscillator state */ | ||
| 173 | ldr tmp1, [pmc, #AT91_PMC_SR] | ||
| 174 | str tmp1, .saved_osc_status | ||
| 175 | tst tmp1, #AT91_PMC_MOSCRCS | ||
| 176 | bne 1f | ||
| 177 | |||
| 178 | /* Turn off RC oscillator */ | ||
| 179 | ldr tmp1, [pmc, #AT91_CKGR_MOR] | ||
| 180 | bic tmp1, tmp1, #AT91_PMC_MOSCRCEN | ||
| 181 | bic tmp1, tmp1, #AT91_PMC_KEY_MASK | ||
| 182 | orr tmp1, tmp1, #AT91_PMC_KEY | ||
| 183 | str tmp1, [pmc, #AT91_CKGR_MOR] | ||
| 184 | |||
| 185 | /* Wait main RC disabled done */ | ||
| 186 | 2: ldr tmp1, [pmc, #AT91_PMC_SR] | ||
| 187 | tst tmp1, #AT91_PMC_MOSCRCS | ||
| 188 | bne 2b | ||
| 189 | |||
| 181 | /* Wait for interrupt */ | 190 | /* Wait for interrupt */ |
| 182 | at91_cpu_idle | 191 | 1: at91_cpu_idle |
| 183 | 192 | ||
| 184 | /* Turn on the crystal oscillator */ | 193 | /* Restore RC oscillator state */ |
| 194 | ldr tmp1, .saved_osc_status | ||
| 195 | tst tmp1, #AT91_PMC_MOSCRCS | ||
| 196 | beq 4f | ||
| 197 | |||
| 198 | /* Turn on RC oscillator */ | ||
| 185 | ldr tmp1, [pmc, #AT91_CKGR_MOR] | 199 | ldr tmp1, [pmc, #AT91_CKGR_MOR] |
| 200 | orr tmp1, tmp1, #AT91_PMC_MOSCRCEN | ||
| 201 | bic tmp1, tmp1, #AT91_PMC_KEY_MASK | ||
| 202 | orr tmp1, tmp1, #AT91_PMC_KEY | ||
| 203 | str tmp1, [pmc, #AT91_CKGR_MOR] | ||
| 204 | |||
| 205 | /* Wait main RC stabilization */ | ||
| 206 | 3: ldr tmp1, [pmc, #AT91_PMC_SR] | ||
| 207 | tst tmp1, #AT91_PMC_MOSCRCS | ||
| 208 | beq 3b | ||
| 209 | |||
| 210 | /* Turn on the crystal oscillator */ | ||
| 211 | 4: ldr tmp1, [pmc, #AT91_CKGR_MOR] | ||
| 186 | orr tmp1, tmp1, #AT91_PMC_MOSCEN | 212 | orr tmp1, tmp1, #AT91_PMC_MOSCEN |
| 187 | orr tmp1, tmp1, #AT91_PMC_KEY | 213 | orr tmp1, tmp1, #AT91_PMC_KEY |
| 188 | str tmp1, [pmc, #AT91_CKGR_MOR] | 214 | str tmp1, [pmc, #AT91_CKGR_MOR] |
| @@ -197,8 +223,26 @@ ENDPROC(at91_backup_mode) | |||
| 197 | .macro at91_pm_ulp1_mode | 223 | .macro at91_pm_ulp1_mode |
| 198 | ldr pmc, .pmc_base | 224 | ldr pmc, .pmc_base |
| 199 | 225 | ||
| 200 | /* Switch the main clock source to 12-MHz RC oscillator */ | 226 | /* Save RC oscillator state and check if it is enabled. */ |
| 227 | ldr tmp1, [pmc, #AT91_PMC_SR] | ||
| 228 | str tmp1, .saved_osc_status | ||
| 229 | tst tmp1, #AT91_PMC_MOSCRCS | ||
| 230 | bne 2f | ||
| 231 | |||
| 232 | /* Enable RC oscillator */ | ||
| 201 | ldr tmp1, [pmc, #AT91_CKGR_MOR] | 233 | ldr tmp1, [pmc, #AT91_CKGR_MOR] |
| 234 | orr tmp1, tmp1, #AT91_PMC_MOSCRCEN | ||
| 235 | bic tmp1, tmp1, #AT91_PMC_KEY_MASK | ||
| 236 | orr tmp1, tmp1, #AT91_PMC_KEY | ||
| 237 | str tmp1, [pmc, #AT91_CKGR_MOR] | ||
| 238 | |||
| 239 | /* Wait main RC stabilization */ | ||
| 240 | 1: ldr tmp1, [pmc, #AT91_PMC_SR] | ||
| 241 | tst tmp1, #AT91_PMC_MOSCRCS | ||
| 242 | beq 1b | ||
| 243 | |||
| 244 | /* Switch the main clock source to 12-MHz RC oscillator */ | ||
| 245 | 2: ldr tmp1, [pmc, #AT91_CKGR_MOR] | ||
| 202 | bic tmp1, tmp1, #AT91_PMC_MOSCSEL | 246 | bic tmp1, tmp1, #AT91_PMC_MOSCSEL |
| 203 | bic tmp1, tmp1, #AT91_PMC_KEY_MASK | 247 | bic tmp1, tmp1, #AT91_PMC_KEY_MASK |
| 204 | orr tmp1, tmp1, #AT91_PMC_KEY | 248 | orr tmp1, tmp1, #AT91_PMC_KEY |
| @@ -262,6 +306,25 @@ ENDPROC(at91_backup_mode) | |||
| 262 | str tmp1, [pmc, #AT91_PMC_MCKR] | 306 | str tmp1, [pmc, #AT91_PMC_MCKR] |
| 263 | 307 | ||
| 264 | wait_mckrdy | 308 | wait_mckrdy |
| 309 | |||
| 310 | /* Restore RC oscillator state */ | ||
| 311 | ldr tmp1, .saved_osc_status | ||
| 312 | tst tmp1, #AT91_PMC_MOSCRCS | ||
| 313 | bne 3f | ||
| 314 | |||
| 315 | /* Disable RC oscillator */ | ||
| 316 | ldr tmp1, [pmc, #AT91_CKGR_MOR] | ||
| 317 | bic tmp1, tmp1, #AT91_PMC_MOSCRCEN | ||
| 318 | bic tmp1, tmp1, #AT91_PMC_KEY_MASK | ||
| 319 | orr tmp1, tmp1, #AT91_PMC_KEY | ||
| 320 | str tmp1, [pmc, #AT91_CKGR_MOR] | ||
| 321 | |||
| 322 | /* Wait RC oscillator disable done */ | ||
| 323 | 4: ldr tmp1, [pmc, #AT91_PMC_SR] | ||
| 324 | tst tmp1, #AT91_PMC_MOSCRCS | ||
| 325 | bne 4b | ||
| 326 | |||
| 327 | 3: | ||
| 265 | .endm | 328 | .endm |
| 266 | 329 | ||
| 267 | ENTRY(at91_ulp_mode) | 330 | ENTRY(at91_ulp_mode) |
| @@ -279,14 +342,6 @@ ENTRY(at91_ulp_mode) | |||
| 279 | 342 | ||
| 280 | wait_mckrdy | 343 | wait_mckrdy |
| 281 | 344 | ||
| 282 | /* Save PLLA setting and disable it */ | ||
| 283 | ldr tmp1, [pmc, #AT91_CKGR_PLLAR] | ||
| 284 | str tmp1, .saved_pllar | ||
| 285 | |||
| 286 | mov tmp1, #AT91_PMC_PLLCOUNT | ||
| 287 | orr tmp1, tmp1, #(1 << 29) /* bit 29 always set */ | ||
| 288 | str tmp1, [pmc, #AT91_CKGR_PLLAR] | ||
| 289 | |||
| 290 | ldr r0, .pm_mode | 345 | ldr r0, .pm_mode |
| 291 | cmp r0, #AT91_PM_ULP1 | 346 | cmp r0, #AT91_PM_ULP1 |
| 292 | beq ulp1_mode | 347 | beq ulp1_mode |
| @@ -301,18 +356,6 @@ ulp1_mode: | |||
| 301 | ulp_exit: | 356 | ulp_exit: |
| 302 | ldr pmc, .pmc_base | 357 | ldr pmc, .pmc_base |
| 303 | 358 | ||
| 304 | /* Restore PLLA setting */ | ||
| 305 | ldr tmp1, .saved_pllar | ||
| 306 | str tmp1, [pmc, #AT91_CKGR_PLLAR] | ||
| 307 | |||
| 308 | tst tmp1, #(AT91_PMC_MUL & 0xff0000) | ||
| 309 | bne 3f | ||
| 310 | tst tmp1, #(AT91_PMC_MUL & ~0xff0000) | ||
| 311 | beq 4f | ||
| 312 | 3: | ||
| 313 | wait_pllalock | ||
| 314 | 4: | ||
| 315 | |||
| 316 | /* | 359 | /* |
| 317 | * Restore master clock setting | 360 | * Restore master clock setting |
| 318 | */ | 361 | */ |
| @@ -465,8 +508,6 @@ ENDPROC(at91_sramc_self_refresh) | |||
| 465 | .word 0 | 508 | .word 0 |
| 466 | .saved_mckr: | 509 | .saved_mckr: |
| 467 | .word 0 | 510 | .word 0 |
| 468 | .saved_pllar: | ||
| 469 | .word 0 | ||
| 470 | .saved_sam9_lpr: | 511 | .saved_sam9_lpr: |
| 471 | .word 0 | 512 | .word 0 |
| 472 | .saved_sam9_lpr1: | 513 | .saved_sam9_lpr1: |
| @@ -475,6 +516,8 @@ ENDPROC(at91_sramc_self_refresh) | |||
| 475 | .word 0 | 516 | .word 0 |
| 476 | .saved_sam9_mdr1: | 517 | .saved_sam9_mdr1: |
| 477 | .word 0 | 518 | .word 0 |
| 519 | .saved_osc_status: | ||
| 520 | .word 0 | ||
| 478 | 521 | ||
| 479 | ENTRY(at91_pm_suspend_in_sram_sz) | 522 | ENTRY(at91_pm_suspend_in_sram_sz) |
| 480 | .word .-at91_pm_suspend_in_sram | 523 | .word .-at91_pm_suspend_in_sram |
diff --git a/arch/arm/mach-ixp4xx/common.c b/arch/arm/mach-ixp4xx/common.c index cc5f15679d29..381f452de28d 100644 --- a/arch/arm/mach-ixp4xx/common.c +++ b/arch/arm/mach-ixp4xx/common.c | |||
| @@ -27,7 +27,6 @@ | |||
| 27 | #include <linux/cpu.h> | 27 | #include <linux/cpu.h> |
| 28 | #include <linux/pci.h> | 28 | #include <linux/pci.h> |
| 29 | #include <linux/sched_clock.h> | 29 | #include <linux/sched_clock.h> |
| 30 | #include <linux/bitops.h> | ||
| 31 | #include <linux/irqchip/irq-ixp4xx.h> | 30 | #include <linux/irqchip/irq-ixp4xx.h> |
| 32 | #include <linux/platform_data/timer-ixp4xx.h> | 31 | #include <linux/platform_data/timer-ixp4xx.h> |
| 33 | #include <mach/udc.h> | 32 | #include <mach/udc.h> |
diff --git a/arch/arm/mach-mvebu/board-v7.c b/arch/arm/mach-mvebu/board-v7.c index 0b10acd7d1b9..d2df5ef9382b 100644 --- a/arch/arm/mach-mvebu/board-v7.c +++ b/arch/arm/mach-mvebu/board-v7.c | |||
| @@ -136,7 +136,6 @@ static void __init i2c_quirk(void) | |||
| 136 | 136 | ||
| 137 | of_update_property(np, new_compat); | 137 | of_update_property(np, new_compat); |
| 138 | } | 138 | } |
| 139 | return; | ||
| 140 | } | 139 | } |
| 141 | 140 | ||
| 142 | static void __init mvebu_dt_init(void) | 141 | static void __init mvebu_dt_init(void) |
diff --git a/arch/arm/mach-mvebu/coherency_ll.S b/arch/arm/mach-mvebu/coherency_ll.S index 8b2fbc8b6bc6..2d962fe48821 100644 --- a/arch/arm/mach-mvebu/coherency_ll.S +++ b/arch/arm/mach-mvebu/coherency_ll.S | |||
| @@ -66,7 +66,7 @@ ENDPROC(ll_get_coherency_base) | |||
| 66 | * fabric registers | 66 | * fabric registers |
| 67 | */ | 67 | */ |
| 68 | ENTRY(ll_get_coherency_cpumask) | 68 | ENTRY(ll_get_coherency_cpumask) |
| 69 | mrc 15, 0, r3, cr0, cr0, 5 | 69 | mrc p15, 0, r3, cr0, cr0, 5 |
| 70 | and r3, r3, #15 | 70 | and r3, r3, #15 |
| 71 | mov r2, #(1 << 24) | 71 | mov r2, #(1 << 24) |
| 72 | lsl r3, r2, r3 | 72 | lsl r3, r2, r3 |
diff --git a/arch/arm/mach-mvebu/kirkwood.c b/arch/arm/mach-mvebu/kirkwood.c index 9b5f4d665374..ceaad6d5927e 100644 --- a/arch/arm/mach-mvebu/kirkwood.c +++ b/arch/arm/mach-mvebu/kirkwood.c | |||
| @@ -108,8 +108,6 @@ static void __init kirkwood_dt_eth_fixup(void) | |||
| 108 | clk_prepare_enable(clk); | 108 | clk_prepare_enable(clk); |
| 109 | 109 | ||
| 110 | /* store MAC address register contents in local-mac-address */ | 110 | /* store MAC address register contents in local-mac-address */ |
| 111 | pr_err(FW_INFO "%pOF: local-mac-address is not set\n", np); | ||
| 112 | |||
| 113 | pmac = kzalloc(sizeof(*pmac) + 6, GFP_KERNEL); | 111 | pmac = kzalloc(sizeof(*pmac) + 6, GFP_KERNEL); |
| 114 | if (!pmac) | 112 | if (!pmac) |
| 115 | goto eth_fixup_no_mem; | 113 | goto eth_fixup_no_mem; |
diff --git a/arch/arm/mach-mvebu/pm-board.c b/arch/arm/mach-mvebu/pm-board.c index db17121d7d63..070552511699 100644 --- a/arch/arm/mach-mvebu/pm-board.c +++ b/arch/arm/mach-mvebu/pm-board.c | |||
| @@ -79,7 +79,7 @@ static void mvebu_armada_pm_enter(void __iomem *sdram_reg, u32 srcmd) | |||
| 79 | static int __init mvebu_armada_pm_init(void) | 79 | static int __init mvebu_armada_pm_init(void) |
| 80 | { | 80 | { |
| 81 | struct device_node *np; | 81 | struct device_node *np; |
| 82 | struct device_node *gpio_ctrl_np; | 82 | struct device_node *gpio_ctrl_np = NULL; |
| 83 | int ret = 0, i; | 83 | int ret = 0, i; |
| 84 | 84 | ||
| 85 | if (!of_machine_is_compatible("marvell,axp-gp")) | 85 | if (!of_machine_is_compatible("marvell,axp-gp")) |
| @@ -126,18 +126,23 @@ static int __init mvebu_armada_pm_init(void) | |||
| 126 | goto out; | 126 | goto out; |
| 127 | } | 127 | } |
| 128 | 128 | ||
| 129 | if (gpio_ctrl_np) | ||
| 130 | of_node_put(gpio_ctrl_np); | ||
| 129 | gpio_ctrl_np = args.np; | 131 | gpio_ctrl_np = args.np; |
| 130 | pic_raw_gpios[i] = args.args[0]; | 132 | pic_raw_gpios[i] = args.args[0]; |
| 131 | } | 133 | } |
| 132 | 134 | ||
| 133 | gpio_ctrl = of_iomap(gpio_ctrl_np, 0); | 135 | gpio_ctrl = of_iomap(gpio_ctrl_np, 0); |
| 134 | if (!gpio_ctrl) | 136 | if (!gpio_ctrl) { |
| 135 | return -ENOMEM; | 137 | ret = -ENOMEM; |
| 138 | goto out; | ||
| 139 | } | ||
| 136 | 140 | ||
| 137 | mvebu_pm_suspend_init(mvebu_armada_pm_enter); | 141 | mvebu_pm_suspend_init(mvebu_armada_pm_enter); |
| 138 | 142 | ||
| 139 | out: | 143 | out: |
| 140 | of_node_put(np); | 144 | of_node_put(np); |
| 145 | of_node_put(gpio_ctrl_np); | ||
| 141 | return ret; | 146 | return ret; |
| 142 | } | 147 | } |
| 143 | 148 | ||
diff --git a/arch/arm/mach-mvebu/pmsu_ll.S b/arch/arm/mach-mvebu/pmsu_ll.S index 88651221dbdd..7aae9a25cfeb 100644 --- a/arch/arm/mach-mvebu/pmsu_ll.S +++ b/arch/arm/mach-mvebu/pmsu_ll.S | |||
| @@ -16,7 +16,7 @@ | |||
| 16 | ENTRY(armada_38x_scu_power_up) | 16 | ENTRY(armada_38x_scu_power_up) |
| 17 | mrc p15, 4, r1, c15, c0 @ get SCU base address | 17 | mrc p15, 4, r1, c15, c0 @ get SCU base address |
| 18 | orr r1, r1, #0x8 @ SCU CPU Power Status Register | 18 | orr r1, r1, #0x8 @ SCU CPU Power Status Register |
| 19 | mrc 15, 0, r0, cr0, cr0, 5 @ get the CPU ID | 19 | mrc p15, 0, r0, cr0, cr0, 5 @ get the CPU ID |
| 20 | and r0, r0, #15 | 20 | and r0, r0, #15 |
| 21 | add r1, r1, r0 | 21 | add r1, r1, r0 |
| 22 | mov r0, #0x0 | 22 | mov r0, #0x0 |
| @@ -56,7 +56,6 @@ ENDPROC(armada_38x_cpu_resume) | |||
| 56 | 56 | ||
| 57 | /* The following code will be executed from SRAM */ | 57 | /* The following code will be executed from SRAM */ |
| 58 | ENTRY(mvebu_boot_wa_start) | 58 | ENTRY(mvebu_boot_wa_start) |
| 59 | mvebu_boot_wa_start: | ||
| 60 | ARM_BE8(setend be) | 59 | ARM_BE8(setend be) |
| 61 | adr r0, 1f | 60 | adr r0, 1f |
| 62 | ldr r0, [r0] @ load the address of the | 61 | ldr r0, [r0] @ load the address of the |
diff --git a/arch/arm/mach-omap1/board-ams-delta.c b/arch/arm/mach-omap1/board-ams-delta.c index 1b15d593837e..b6e814166ee0 100644 --- a/arch/arm/mach-omap1/board-ams-delta.c +++ b/arch/arm/mach-omap1/board-ams-delta.c | |||
| @@ -749,7 +749,7 @@ static void __init ams_delta_init(void) | |||
| 749 | ARRAY_SIZE(ams_delta_gpio_tables)); | 749 | ARRAY_SIZE(ams_delta_gpio_tables)); |
| 750 | 750 | ||
| 751 | leds_pdev = gpio_led_register_device(PLATFORM_DEVID_NONE, &leds_pdata); | 751 | leds_pdev = gpio_led_register_device(PLATFORM_DEVID_NONE, &leds_pdata); |
| 752 | if (!IS_ERR(leds_pdev)) { | 752 | if (!IS_ERR_OR_NULL(leds_pdev)) { |
| 753 | leds_gpio_table.dev_id = dev_name(&leds_pdev->dev); | 753 | leds_gpio_table.dev_id = dev_name(&leds_pdev->dev); |
| 754 | gpiod_add_lookup_table(&leds_gpio_table); | 754 | gpiod_add_lookup_table(&leds_gpio_table); |
| 755 | } | 755 | } |
diff --git a/arch/arm64/Kconfig.platforms b/arch/arm64/Kconfig.platforms index 0f4d91824e4b..1001410c4782 100644 --- a/arch/arm64/Kconfig.platforms +++ b/arch/arm64/Kconfig.platforms | |||
| @@ -215,6 +215,7 @@ config ARCH_SYNQUACER | |||
| 215 | config ARCH_TEGRA | 215 | config ARCH_TEGRA |
| 216 | bool "NVIDIA Tegra SoC Family" | 216 | bool "NVIDIA Tegra SoC Family" |
| 217 | select ARCH_HAS_RESET_CONTROLLER | 217 | select ARCH_HAS_RESET_CONTROLLER |
| 218 | select ARM_GIC_PM | ||
| 218 | select CLKDEV_LOOKUP | 219 | select CLKDEV_LOOKUP |
| 219 | select CLKSRC_MMIO | 220 | select CLKSRC_MMIO |
| 220 | select TIMER_OF | 221 | select TIMER_OF |
diff --git a/arch/arm64/boot/dts/nvidia/tegra186-p2771-0000.dts b/arch/arm64/boot/dts/nvidia/tegra186-p2771-0000.dts index 75ee6cf1e1b4..14d7fea82daf 100644 --- a/arch/arm64/boot/dts/nvidia/tegra186-p2771-0000.dts +++ b/arch/arm64/boot/dts/nvidia/tegra186-p2771-0000.dts | |||
| @@ -59,7 +59,7 @@ | |||
| 59 | }; | 59 | }; |
| 60 | 60 | ||
| 61 | padctl@3520000 { | 61 | padctl@3520000 { |
| 62 | status = "okay"; | 62 | status = "disabled"; |
| 63 | 63 | ||
| 64 | avdd-pll-erefeut-supply = <&vdd_1v8_pll>; | 64 | avdd-pll-erefeut-supply = <&vdd_1v8_pll>; |
| 65 | avdd-usb-supply = <&vdd_3v3_sys>; | 65 | avdd-usb-supply = <&vdd_3v3_sys>; |
| @@ -137,7 +137,7 @@ | |||
| 137 | }; | 137 | }; |
| 138 | 138 | ||
| 139 | usb@3530000 { | 139 | usb@3530000 { |
| 140 | status = "okay"; | 140 | status = "disabled"; |
| 141 | 141 | ||
| 142 | phys = <&{/padctl@3520000/pads/usb2/lanes/usb2-0}>, | 142 | phys = <&{/padctl@3520000/pads/usb2/lanes/usb2-0}>, |
| 143 | <&{/padctl@3520000/pads/usb2/lanes/usb2-1}>, | 143 | <&{/padctl@3520000/pads/usb2/lanes/usb2-1}>, |
diff --git a/arch/arm64/boot/dts/nvidia/tegra186.dtsi b/arch/arm64/boot/dts/nvidia/tegra186.dtsi index f0bb6ced4976..426ac0bdf6a6 100644 --- a/arch/arm64/boot/dts/nvidia/tegra186.dtsi +++ b/arch/arm64/boot/dts/nvidia/tegra186.dtsi | |||
| @@ -60,6 +60,7 @@ | |||
| 60 | clock-names = "master_bus", "slave_bus", "rx", "tx", "ptp_ref"; | 60 | clock-names = "master_bus", "slave_bus", "rx", "tx", "ptp_ref"; |
| 61 | resets = <&bpmp TEGRA186_RESET_EQOS>; | 61 | resets = <&bpmp TEGRA186_RESET_EQOS>; |
| 62 | reset-names = "eqos"; | 62 | reset-names = "eqos"; |
| 63 | iommus = <&smmu TEGRA186_SID_EQOS>; | ||
| 63 | status = "disabled"; | 64 | status = "disabled"; |
| 64 | 65 | ||
| 65 | snps,write-requests = <1>; | 66 | snps,write-requests = <1>; |
| @@ -338,6 +339,7 @@ | |||
| 338 | <&bpmp TEGRA186_RESET_HDA2CODEC_2X>; | 339 | <&bpmp TEGRA186_RESET_HDA2CODEC_2X>; |
| 339 | reset-names = "hda", "hda2hdmi", "hda2codec_2x"; | 340 | reset-names = "hda", "hda2hdmi", "hda2codec_2x"; |
| 340 | power-domains = <&bpmp TEGRA186_POWER_DOMAIN_DISP>; | 341 | power-domains = <&bpmp TEGRA186_POWER_DOMAIN_DISP>; |
| 342 | iommus = <&smmu TEGRA186_SID_HDA>; | ||
| 341 | status = "disabled"; | 343 | status = "disabled"; |
| 342 | }; | 344 | }; |
| 343 | 345 | ||
| @@ -671,6 +673,10 @@ | |||
| 671 | <&bpmp TEGRA186_RESET_PCIEXCLK>; | 673 | <&bpmp TEGRA186_RESET_PCIEXCLK>; |
| 672 | reset-names = "afi", "pex", "pcie_x"; | 674 | reset-names = "afi", "pex", "pcie_x"; |
| 673 | 675 | ||
| 676 | iommus = <&smmu TEGRA186_SID_AFI>; | ||
| 677 | iommu-map = <0x0 &smmu TEGRA186_SID_AFI 0x1000>; | ||
| 678 | iommu-map-mask = <0x0>; | ||
| 679 | |||
| 674 | status = "disabled"; | 680 | status = "disabled"; |
| 675 | 681 | ||
| 676 | pci@1,0 { | 682 | pci@1,0 { |
| @@ -1158,6 +1164,7 @@ | |||
| 1158 | 1164 | ||
| 1159 | bpmp: bpmp { | 1165 | bpmp: bpmp { |
| 1160 | compatible = "nvidia,tegra186-bpmp"; | 1166 | compatible = "nvidia,tegra186-bpmp"; |
| 1167 | iommus = <&smmu TEGRA186_SID_BPMP>; | ||
| 1161 | mboxes = <&hsp_top0 TEGRA_HSP_MBOX_TYPE_DB | 1168 | mboxes = <&hsp_top0 TEGRA_HSP_MBOX_TYPE_DB |
| 1162 | TEGRA_HSP_DB_MASTER_BPMP>; | 1169 | TEGRA_HSP_DB_MASTER_BPMP>; |
| 1163 | shmem = <&cpu_bpmp_tx &cpu_bpmp_rx>; | 1170 | shmem = <&cpu_bpmp_tx &cpu_bpmp_rx>; |
diff --git a/arch/arm64/boot/dts/sprd/whale2.dtsi b/arch/arm64/boot/dts/sprd/whale2.dtsi index eb6be5675f79..4bb862c6b083 100644 --- a/arch/arm64/boot/dts/sprd/whale2.dtsi +++ b/arch/arm64/boot/dts/sprd/whale2.dtsi | |||
| @@ -75,7 +75,9 @@ | |||
| 75 | "sprd,sc9836-uart"; | 75 | "sprd,sc9836-uart"; |
| 76 | reg = <0x0 0x100>; | 76 | reg = <0x0 0x100>; |
| 77 | interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>; | 77 | interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>; |
| 78 | clocks = <&ext_26m>; | 78 | clock-names = "enable", "uart", "source"; |
| 79 | clocks = <&apapb_gate CLK_UART0_EB>, | ||
| 80 | <&ap_clk CLK_UART0>, <&ext_26m>; | ||
| 79 | status = "disabled"; | 81 | status = "disabled"; |
| 80 | }; | 82 | }; |
| 81 | 83 | ||
| @@ -84,7 +86,9 @@ | |||
| 84 | "sprd,sc9836-uart"; | 86 | "sprd,sc9836-uart"; |
| 85 | reg = <0x100000 0x100>; | 87 | reg = <0x100000 0x100>; |
| 86 | interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>; | 88 | interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>; |
| 87 | clocks = <&ext_26m>; | 89 | clock-names = "enable", "uart", "source"; |
| 90 | clocks = <&apapb_gate CLK_UART1_EB>, | ||
| 91 | <&ap_clk CLK_UART1>, <&ext_26m>; | ||
| 88 | status = "disabled"; | 92 | status = "disabled"; |
| 89 | }; | 93 | }; |
| 90 | 94 | ||
| @@ -93,7 +97,9 @@ | |||
| 93 | "sprd,sc9836-uart"; | 97 | "sprd,sc9836-uart"; |
| 94 | reg = <0x200000 0x100>; | 98 | reg = <0x200000 0x100>; |
| 95 | interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>; | 99 | interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>; |
| 96 | clocks = <&ext_26m>; | 100 | clock-names = "enable", "uart", "source"; |
| 101 | clocks = <&apapb_gate CLK_UART2_EB>, | ||
| 102 | <&ap_clk CLK_UART2>, <&ext_26m>; | ||
| 97 | status = "disabled"; | 103 | status = "disabled"; |
| 98 | }; | 104 | }; |
| 99 | 105 | ||
| @@ -102,7 +108,9 @@ | |||
| 102 | "sprd,sc9836-uart"; | 108 | "sprd,sc9836-uart"; |
| 103 | reg = <0x300000 0x100>; | 109 | reg = <0x300000 0x100>; |
| 104 | interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>; | 110 | interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>; |
| 105 | clocks = <&ext_26m>; | 111 | clock-names = "enable", "uart", "source"; |
| 112 | clocks = <&apapb_gate CLK_UART3_EB>, | ||
| 113 | <&ap_clk CLK_UART3>, <&ext_26m>; | ||
| 106 | status = "disabled"; | 114 | status = "disabled"; |
| 107 | }; | 115 | }; |
| 108 | }; | 116 | }; |
diff --git a/drivers/amba/tegra-ahb.c b/drivers/amba/tegra-ahb.c index b0b688c481e8..3751d811be39 100644 --- a/drivers/amba/tegra-ahb.c +++ b/drivers/amba/tegra-ahb.c | |||
| @@ -170,8 +170,7 @@ int tegra_ahb_enable_smmu(struct device_node *dn) | |||
| 170 | EXPORT_SYMBOL(tegra_ahb_enable_smmu); | 170 | EXPORT_SYMBOL(tegra_ahb_enable_smmu); |
| 171 | #endif | 171 | #endif |
| 172 | 172 | ||
| 173 | #ifdef CONFIG_PM | 173 | static int __maybe_unused tegra_ahb_suspend(struct device *dev) |
| 174 | static int tegra_ahb_suspend(struct device *dev) | ||
| 175 | { | 174 | { |
| 176 | int i; | 175 | int i; |
| 177 | struct tegra_ahb *ahb = dev_get_drvdata(dev); | 176 | struct tegra_ahb *ahb = dev_get_drvdata(dev); |
| @@ -181,7 +180,7 @@ static int tegra_ahb_suspend(struct device *dev) | |||
| 181 | return 0; | 180 | return 0; |
| 182 | } | 181 | } |
| 183 | 182 | ||
| 184 | static int tegra_ahb_resume(struct device *dev) | 183 | static int __maybe_unused tegra_ahb_resume(struct device *dev) |
| 185 | { | 184 | { |
| 186 | int i; | 185 | int i; |
| 187 | struct tegra_ahb *ahb = dev_get_drvdata(dev); | 186 | struct tegra_ahb *ahb = dev_get_drvdata(dev); |
| @@ -190,7 +189,6 @@ static int tegra_ahb_resume(struct device *dev) | |||
| 190 | gizmo_writel(ahb, ahb->ctx[i], tegra_ahb_gizmo[i]); | 189 | gizmo_writel(ahb, ahb->ctx[i], tegra_ahb_gizmo[i]); |
| 191 | return 0; | 190 | return 0; |
| 192 | } | 191 | } |
| 193 | #endif | ||
| 194 | 192 | ||
| 195 | static UNIVERSAL_DEV_PM_OPS(tegra_ahb_pm, | 193 | static UNIVERSAL_DEV_PM_OPS(tegra_ahb_pm, |
| 196 | tegra_ahb_suspend, | 194 | tegra_ahb_suspend, |
diff --git a/drivers/soc/fsl/qe/gpio.c b/drivers/soc/fsl/qe/gpio.c index 819bed0f5667..51b3a47b5a55 100644 --- a/drivers/soc/fsl/qe/gpio.c +++ b/drivers/soc/fsl/qe/gpio.c | |||
| @@ -179,8 +179,10 @@ struct qe_pin *qe_pin_request(struct device_node *np, int index) | |||
| 179 | if (err < 0) | 179 | if (err < 0) |
| 180 | goto err0; | 180 | goto err0; |
| 181 | gc = gpio_to_chip(err); | 181 | gc = gpio_to_chip(err); |
| 182 | if (WARN_ON(!gc)) | 182 | if (WARN_ON(!gc)) { |
| 183 | err = -ENODEV; | ||
| 183 | goto err0; | 184 | goto err0; |
| 185 | } | ||
| 184 | 186 | ||
| 185 | if (!of_device_is_compatible(gc->of_node, "fsl,mpc8323-qe-pario-bank")) { | 187 | if (!of_device_is_compatible(gc->of_node, "fsl,mpc8323-qe-pario-bank")) { |
| 186 | pr_debug("%s: tried to get a non-qe pin\n", __func__); | 188 | pr_debug("%s: tried to get a non-qe pin\n", __func__); |
diff --git a/drivers/soc/ixp4xx/ixp4xx-qmgr.c b/drivers/soc/ixp4xx/ixp4xx-qmgr.c index 13a8a13c9b01..bb90670ec160 100644 --- a/drivers/soc/ixp4xx/ixp4xx-qmgr.c +++ b/drivers/soc/ixp4xx/ixp4xx-qmgr.c | |||
| @@ -385,8 +385,8 @@ static int ixp4xx_qmgr_probe(struct platform_device *pdev) | |||
| 385 | if (!res) | 385 | if (!res) |
| 386 | return -ENODEV; | 386 | return -ENODEV; |
| 387 | qmgr_regs = devm_ioremap_resource(dev, res); | 387 | qmgr_regs = devm_ioremap_resource(dev, res); |
| 388 | if (!qmgr_regs) | 388 | if (IS_ERR(qmgr_regs)) |
| 389 | return -ENOMEM; | 389 | return PTR_ERR(qmgr_regs); |
| 390 | 390 | ||
| 391 | irq1 = platform_get_irq(pdev, 0); | 391 | irq1 = platform_get_irq(pdev, 0); |
| 392 | if (irq1 <= 0) | 392 | if (irq1 <= 0) |
diff --git a/include/linux/clk/at91_pmc.h b/include/linux/clk/at91_pmc.h index 0c53f26ae3d3..44e8fc30b889 100644 --- a/include/linux/clk/at91_pmc.h +++ b/include/linux/clk/at91_pmc.h | |||
| @@ -161,6 +161,7 @@ | |||
| 161 | 161 | ||
| 162 | #define AT91_PMC_FSMR 0x70 /* Fast Startup Mode Register */ | 162 | #define AT91_PMC_FSMR 0x70 /* Fast Startup Mode Register */ |
| 163 | #define AT91_PMC_FSTT(n) BIT(n) | 163 | #define AT91_PMC_FSTT(n) BIT(n) |
| 164 | #define AT91_PMC_RTTAL BIT(16) | ||
| 164 | #define AT91_PMC_RTCAL BIT(17) /* RTC Alarm Enable */ | 165 | #define AT91_PMC_RTCAL BIT(17) /* RTC Alarm Enable */ |
| 165 | #define AT91_PMC_USBAL BIT(18) /* USB Resume Enable */ | 166 | #define AT91_PMC_USBAL BIT(18) /* USB Resume Enable */ |
| 166 | #define AT91_PMC_SDMMC_CD BIT(19) /* SDMMC Card Detect Enable */ | 167 | #define AT91_PMC_SDMMC_CD BIT(19) /* SDMMC Card Detect Enable */ |
