diff --git a/3rdparty/packaging/builddeb b/3rdparty/packaging/builddeb index f9dba415d068073499f05619b828dee14372ab84..1d46d7dcd6b0230c82654696b0381fca5e54650b 100755 --- a/3rdparty/packaging/builddeb +++ b/3rdparty/packaging/builddeb @@ -51,7 +51,7 @@ set_debarch() { debarch=hppa ;; mips*) debarch=mips$(grep -q CPU_LITTLE_ENDIAN=y $KCONFIG_CONFIG && echo el || true) ;; - arm64) + aarch64|arm64) debarch=arm64 ;; arm*) if grep -q CONFIG_AEABI=y $KCONFIG_CONFIG; then diff --git a/patch.sh b/patch.sh index 84c9eebb3dc3fe61fcaad41130c97f5a35241f4a..050c461a8012fbc5a8532ba0cb7c52027959cb73 100644 --- a/patch.sh +++ b/patch.sh @@ -104,7 +104,26 @@ external_git () { } sync_cherrypicks () { - dir 'ti_4.9.x/pm_opp' + echo "dir: ti_4.9.x/pm_opp" + #regenerate="enable" + if [ "x${regenerate}" = "xenable" ] ; then + start_cleanup + fi + + ${git} "${DIR}/patches/ti_4.9.x/pm_opp/0001-Documentation-dt-add-bindings-for-ti-cpufreq.patch" + ${git} "${DIR}/patches/ti_4.9.x/pm_opp/0002-cpufreq-ti-Add-cpufreq-driver-to-determine-available.patch" + ${git} "${DIR}/patches/ti_4.9.x/pm_opp/0003-cpufreq-dt-Don-t-use-generic-platdev-driver-for-ti-c.patch" + ${git} "${DIR}/patches/ti_4.9.x/pm_opp/0004-ARM-dts-am33xx-Add-updated-operating-points-v2-table.patch" + ${git} "${DIR}/patches/ti_4.9.x/pm_opp/0005-ARM-dts-am335x-boneblack-Enable-1GHz-OPP-for-cpu.patch" + ${git} "${DIR}/patches/ti_4.9.x/pm_opp/0006-ARM-dts-am4372-Update-operating-points-v2-table-for-.patch" + ${git} "${DIR}/patches/ti_4.9.x/pm_opp/0007-ARM-dts-dra7-Add-updated-operating-points-v2-table-f.patch" + ${git} "${DIR}/patches/ti_4.9.x/pm_opp/0008-PM-OPP-Expose-_of_get_opp_desc_node-as-dev_pm_opp-AP.patch" + + if [ "x${regenerate}" = "xenable" ] ; then + wdir="ti_4.9.x/pm_opp" + number=8 + cleanup + fi } aufs_fail () { @@ -275,8 +294,8 @@ local_patch () { } #external_git -sync_cherrypicks -aufs4 +#sync_cherrypicks +#aufs4 #rt tinydrm #local_patch @@ -357,10 +376,6 @@ reverts () { drivers () { dir 'drivers/pm_bus' - - #[PATCH V5 00/10] PM / OPP: Multiple regulator support - dir 'drivers/pm_opp' - dir 'drivers/spi' dir 'drivers/tsl2550' dir 'drivers/tps65217' @@ -477,9 +492,7 @@ drivers () { dir 'drivers/ti/eqep' dir 'drivers/ti/mcasp' dir 'drivers/ti/mmc' - dir 'drivers/ti/omapdrm' dir 'drivers/ti/rpmsg' - dir 'drivers/ti/rtc' dir 'drivers/ti/serial' dir 'drivers/ti/spi' dir 'drivers/ti/uio' diff --git a/patches/beaglebone/dtbs/0001-sync-am335x-peripheral-pinmux.patch b/patches/beaglebone/dtbs/0001-sync-am335x-peripheral-pinmux.patch index f9ccfb86174cebac314996d1089c7bad8a14c4fe..08ed5226e8358a47aa76bb0dec942477d36d44c7 100644 --- a/patches/beaglebone/dtbs/0001-sync-am335x-peripheral-pinmux.patch +++ b/patches/beaglebone/dtbs/0001-sync-am335x-peripheral-pinmux.patch @@ -1,6 +1,6 @@ -From d46fa33ce8dd5c8446047481fdfdf73b032254f6 Mon Sep 17 00:00:00 2001 +From b7c3ce3ef04c37e456d1a9f11bcde3006ddf623d Mon Sep 17 00:00:00 2001 From: Robert Nelson <robertcnelson@gmail.com> -Date: Tue, 8 Nov 2016 09:50:56 -0600 +Date: Sun, 25 Dec 2016 11:06:52 -0600 Subject: [PATCH] sync: am335x-peripheral/pinmux Signed-off-by: Robert Nelson <robertcnelson@gmail.com> @@ -14,14 +14,14 @@ Signed-off-by: Robert Nelson <robertcnelson@gmail.com> arch/arm/boot/dts/am335x-bone-pinmux-spi1.dtsi | 27 +++++ arch/arm/boot/dts/am335x-bone-pinmux-spi1a.dtsi | 28 +++++ arch/arm/boot/dts/am335x-bone-pinmux-ttyS5.dtsi | 48 +++++++++ - arch/arm/boot/dts/am335x-boneblack-bbb-exp-c.dts | 11 +- - arch/arm/boot/dts/am335x-boneblack-bbb-exp-r.dts | 11 +- + arch/arm/boot/dts/am335x-boneblack-bbb-exp-c.dts | 13 ++- + arch/arm/boot/dts/am335x-boneblack-bbb-exp-r.dts | 13 ++- arch/arm/boot/dts/am335x-boneblack-bbbmini.dts | 15 ++- .../boot/dts/am335x-boneblack-cape-bone-argus.dts | 15 ++- .../arm/boot/dts/am335x-boneblack-emmc-overlay.dts | 11 ++ .../arm/boot/dts/am335x-boneblack-hdmi-overlay.dts | 11 ++ .../boot/dts/am335x-boneblack-nhdmi-overlay.dts | 11 ++ - arch/arm/boot/dts/am335x-boneblack-overlay.dts | 11 +- + arch/arm/boot/dts/am335x-boneblack-overlay.dts | 13 ++- arch/arm/boot/dts/am335x-boneblack-wl1835mod.dts | 15 ++- arch/arm/boot/dts/am335x-cape-rtc-ds1307.dtsi | 31 ++++++ arch/arm/boot/dts/am335x-peripheral-can1.dtsi | 13 +++ @@ -32,7 +32,7 @@ Signed-off-by: Robert Nelson <robertcnelson@gmail.com> arch/arm/boot/dts/am335x-peripheral-spi1.dtsi | 13 +++ arch/arm/boot/dts/am335x-peripheral-spi1a.dtsi | 13 +++ arch/arm/boot/dts/am335x-peripheral-ttyS5.dtsi | 13 +++ - 27 files changed, 716 insertions(+), 18 deletions(-) + 27 files changed, 719 insertions(+), 21 deletions(-) create mode 100644 arch/arm/boot/dts/am335x-bone-emmc-in-reset.dtsi create mode 100644 arch/arm/boot/dts/am335x-bone-pinmux-can1.dtsi create mode 100644 arch/arm/boot/dts/am335x-bone-pinmux-emmc.dtsi @@ -54,7 +54,7 @@ Signed-off-by: Robert Nelson <robertcnelson@gmail.com> diff --git a/arch/arm/boot/dts/am335x-bone-emmc-in-reset.dtsi b/arch/arm/boot/dts/am335x-bone-emmc-in-reset.dtsi new file mode 100644 -index 0000000..7d8f673 +index 000000000000..7d8f673229c0 --- /dev/null +++ b/arch/arm/boot/dts/am335x-bone-emmc-in-reset.dtsi @@ -0,0 +1,18 @@ @@ -78,7 +78,7 @@ index 0000000..7d8f673 +}; diff --git a/arch/arm/boot/dts/am335x-bone-pinmux-can1.dtsi b/arch/arm/boot/dts/am335x-bone-pinmux-can1.dtsi new file mode 100644 -index 0000000..9e26413 +index 000000000000..9e264132cc46 --- /dev/null +++ b/arch/arm/boot/dts/am335x-bone-pinmux-can1.dtsi @@ -0,0 +1,45 @@ @@ -129,7 +129,7 @@ index 0000000..9e26413 +}; diff --git a/arch/arm/boot/dts/am335x-bone-pinmux-emmc.dtsi b/arch/arm/boot/dts/am335x-bone-pinmux-emmc.dtsi new file mode 100644 -index 0000000..22cf462 +index 000000000000..22cf4621b357 --- /dev/null +++ b/arch/arm/boot/dts/am335x-bone-pinmux-emmc.dtsi @@ -0,0 +1,88 @@ @@ -223,7 +223,7 @@ index 0000000..22cf462 +}; diff --git a/arch/arm/boot/dts/am335x-bone-pinmux-i2c2.dtsi b/arch/arm/boot/dts/am335x-bone-pinmux-i2c2.dtsi new file mode 100644 -index 0000000..abf3b57 +index 000000000000..abf3b57522e3 --- /dev/null +++ b/arch/arm/boot/dts/am335x-bone-pinmux-i2c2.dtsi @@ -0,0 +1,45 @@ @@ -274,7 +274,7 @@ index 0000000..abf3b57 +}; diff --git a/arch/arm/boot/dts/am335x-bone-pinmux-nxp-hdmi.dtsi b/arch/arm/boot/dts/am335x-bone-pinmux-nxp-hdmi.dtsi new file mode 100644 -index 0000000..5205fa0 +index 000000000000..5205fa0f9a95 --- /dev/null +++ b/arch/arm/boot/dts/am335x-bone-pinmux-nxp-hdmi.dtsi @@ -0,0 +1,120 @@ @@ -400,7 +400,7 @@ index 0000000..5205fa0 +}; diff --git a/arch/arm/boot/dts/am335x-bone-pinmux-spi0.dtsi b/arch/arm/boot/dts/am335x-bone-pinmux-spi0.dtsi new file mode 100644 -index 0000000..354e66a +index 000000000000..354e66ad4f04 --- /dev/null +++ b/arch/arm/boot/dts/am335x-bone-pinmux-spi0.dtsi @@ -0,0 +1,51 @@ @@ -457,7 +457,7 @@ index 0000000..354e66a +}; diff --git a/arch/arm/boot/dts/am335x-bone-pinmux-spi1.dtsi b/arch/arm/boot/dts/am335x-bone-pinmux-spi1.dtsi new file mode 100644 -index 0000000..bff7f8d +index 000000000000..bff7f8dae839 --- /dev/null +++ b/arch/arm/boot/dts/am335x-bone-pinmux-spi1.dtsi @@ -0,0 +1,27 @@ @@ -490,7 +490,7 @@ index 0000000..bff7f8d +}; diff --git a/arch/arm/boot/dts/am335x-bone-pinmux-spi1a.dtsi b/arch/arm/boot/dts/am335x-bone-pinmux-spi1a.dtsi new file mode 100644 -index 0000000..62874c8 +index 000000000000..62874c892ff7 --- /dev/null +++ b/arch/arm/boot/dts/am335x-bone-pinmux-spi1a.dtsi @@ -0,0 +1,28 @@ @@ -524,7 +524,7 @@ index 0000000..62874c8 +}; diff --git a/arch/arm/boot/dts/am335x-bone-pinmux-ttyS5.dtsi b/arch/arm/boot/dts/am335x-bone-pinmux-ttyS5.dtsi new file mode 100644 -index 0000000..01d0aec +index 000000000000..01d0aec1de44 --- /dev/null +++ b/arch/arm/boot/dts/am335x-bone-pinmux-ttyS5.dtsi @@ -0,0 +1,48 @@ @@ -577,7 +577,7 @@ index 0000000..01d0aec + pinctrl-0 = <&uart5_pins>; +}; diff --git a/arch/arm/boot/dts/am335x-boneblack-bbb-exp-c.dts b/arch/arm/boot/dts/am335x-boneblack-bbb-exp-c.dts -index 857c21e..8d795c0 100644 +index 857c21ea4834..f4cd428dabf7 100644 --- a/arch/arm/boot/dts/am335x-boneblack-bbb-exp-c.dts +++ b/arch/arm/boot/dts/am335x-boneblack-bbb-exp-c.dts @@ -33,8 +33,15 @@ @@ -586,20 +586,21 @@ index 857c21e..8d795c0 100644 -&rtc { - system-power-controller; -+&cpu0_opp_table { -+ /* -+ * All PG 2.0 silicon may not support 1GHz but some of the early -+ * BeagleBone Blacks have PG 2.0 silicon which is guaranteed -+ * to support 1GHz OPP so enable it for PG 2.0 on this board. -+ */ -+ oppnitro@1000000000 { -+ opp-supported-hw = <0x06 0x0100>; -+ }; - }; +-}; ++//&cpu0_opp_table { ++// /* ++// * All PG 2.0 silicon may not support 1GHz but some of the early ++// * BeagleBone Blacks have PG 2.0 silicon which is guaranteed ++// * to support 1GHz OPP so enable it for PG 2.0 on this board. ++// */ ++// oppnitro@1000000000 { ++// opp-supported-hw = <0x06 0x0100>; ++// }; ++//}; #include "am335x-cape-bbb-exp-c.dtsi" diff --git a/arch/arm/boot/dts/am335x-boneblack-bbb-exp-r.dts b/arch/arm/boot/dts/am335x-boneblack-bbb-exp-r.dts -index b834fa2..5df881e 100644 +index b834fa2ee098..dd961c6580ca 100644 --- a/arch/arm/boot/dts/am335x-boneblack-bbb-exp-r.dts +++ b/arch/arm/boot/dts/am335x-boneblack-bbb-exp-r.dts @@ -33,8 +33,15 @@ @@ -608,36 +609,37 @@ index b834fa2..5df881e 100644 -&rtc { - system-power-controller; -+&cpu0_opp_table { -+ /* -+ * All PG 2.0 silicon may not support 1GHz but some of the early -+ * BeagleBone Blacks have PG 2.0 silicon which is guaranteed -+ * to support 1GHz OPP so enable it for PG 2.0 on this board. -+ */ -+ oppnitro@1000000000 { -+ opp-supported-hw = <0x06 0x0100>; -+ }; - }; +-}; ++//&cpu0_opp_table { ++// /* ++// * All PG 2.0 silicon may not support 1GHz but some of the early ++// * BeagleBone Blacks have PG 2.0 silicon which is guaranteed ++// * to support 1GHz OPP so enable it for PG 2.0 on this board. ++// */ ++// oppnitro@1000000000 { ++// opp-supported-hw = <0x06 0x0100>; ++// }; ++//}; #include "am335x-cape-bbb-exp-r.dtsi" diff --git a/arch/arm/boot/dts/am335x-boneblack-bbbmini.dts b/arch/arm/boot/dts/am335x-boneblack-bbbmini.dts -index adb317c..5ed89a2 100644 +index adb317ceed7a..29a8de2e6381 100644 --- a/arch/arm/boot/dts/am335x-boneblack-bbbmini.dts +++ b/arch/arm/boot/dts/am335x-boneblack-bbbmini.dts @@ -37,6 +37,17 @@ status = "okay"; }; -+&cpu0_opp_table { -+ /* -+ * All PG 2.0 silicon may not support 1GHz but some of the early -+ * BeagleBone Blacks have PG 2.0 silicon which is guaranteed -+ * to support 1GHz OPP so enable it for PG 2.0 on this board. -+ */ -+ oppnitro@1000000000 { -+ opp-supported-hw = <0x06 0x0100>; -+ }; -+}; ++//&cpu0_opp_table { ++// /* ++// * All PG 2.0 silicon may not support 1GHz but some of the early ++// * BeagleBone Blacks have PG 2.0 silicon which is guaranteed ++// * to support 1GHz OPP so enable it for PG 2.0 on this board. ++// */ ++// oppnitro@1000000000 { ++// opp-supported-hw = <0x06 0x0100>; ++// }; ++//}; + &am33xx_pinmux { dcan1_pins: pinmux_dcan1_pins { @@ -651,23 +653,23 @@ index adb317c..5ed89a2 100644 - system-power-controller; -}; diff --git a/arch/arm/boot/dts/am335x-boneblack-cape-bone-argus.dts b/arch/arm/boot/dts/am335x-boneblack-cape-bone-argus.dts -index cecb0fcc..c97c912 100644 +index cecb0fccc70b..e381ff209643 100644 --- a/arch/arm/boot/dts/am335x-boneblack-cape-bone-argus.dts +++ b/arch/arm/boot/dts/am335x-boneblack-cape-bone-argus.dts @@ -33,6 +33,17 @@ status = "okay"; }; -+&cpu0_opp_table { -+ /* -+ * All PG 2.0 silicon may not support 1GHz but some of the early -+ * BeagleBone Blacks have PG 2.0 silicon which is guaranteed -+ * to support 1GHz OPP so enable it for PG 2.0 on this board. -+ */ -+ oppnitro@1000000000 { -+ opp-supported-hw = <0x06 0x0100>; -+ }; -+}; ++//&cpu0_opp_table { ++// /* ++// * All PG 2.0 silicon may not support 1GHz but some of the early ++// * BeagleBone Blacks have PG 2.0 silicon which is guaranteed ++// * to support 1GHz OPP so enable it for PG 2.0 on this board. ++// */ ++// oppnitro@1000000000 { ++// opp-supported-hw = <0x06 0x0100>; ++// }; ++//}; + &am33xx_pinmux { nxp_hdmi_bonelt_pins: nxp_hdmi_bonelt_pins { @@ -682,7 +684,7 @@ index cecb0fcc..c97c912 100644 - #include "am335x-bone-argus.dtsi" diff --git a/arch/arm/boot/dts/am335x-boneblack-emmc-overlay.dts b/arch/arm/boot/dts/am335x-boneblack-emmc-overlay.dts -index f3eeb88..ccd358e 100644 +index f3eeb88da02f..39c802a3941e 100644 --- a/arch/arm/boot/dts/am335x-boneblack-emmc-overlay.dts +++ b/arch/arm/boot/dts/am335x-boneblack-emmc-overlay.dts @@ -34,3 +34,14 @@ @@ -690,62 +692,62 @@ index f3eeb88..ccd358e 100644 status = "okay"; }; + -+&cpu0_opp_table { -+ /* -+ * All PG 2.0 silicon may not support 1GHz but some of the early -+ * BeagleBone Blacks have PG 2.0 silicon which is guaranteed -+ * to support 1GHz OPP so enable it for PG 2.0 on this board. -+ */ -+ oppnitro@1000000000 { -+ opp-supported-hw = <0x06 0x0100>; -+ }; -+}; ++//&cpu0_opp_table { ++// /* ++// * All PG 2.0 silicon may not support 1GHz but some of the early ++// * BeagleBone Blacks have PG 2.0 silicon which is guaranteed ++// * to support 1GHz OPP so enable it for PG 2.0 on this board. ++// */ ++// oppnitro@1000000000 { ++// opp-supported-hw = <0x06 0x0100>; ++// }; ++//}; diff --git a/arch/arm/boot/dts/am335x-boneblack-hdmi-overlay.dts b/arch/arm/boot/dts/am335x-boneblack-hdmi-overlay.dts -index 4875da9..0582e572 100644 +index 4875da950015..266725144a95 100644 --- a/arch/arm/boot/dts/am335x-boneblack-hdmi-overlay.dts +++ b/arch/arm/boot/dts/am335x-boneblack-hdmi-overlay.dts @@ -37,6 +37,17 @@ }; }; -+&cpu0_opp_table { -+ /* -+ * All PG 2.0 silicon may not support 1GHz but some of the early -+ * BeagleBone Blacks have PG 2.0 silicon which is guaranteed -+ * to support 1GHz OPP so enable it for PG 2.0 on this board. -+ */ -+ oppnitro@1000000000 { -+ opp-supported-hw = <0x06 0x0100>; -+ }; -+}; ++//&cpu0_opp_table { ++// /* ++// * All PG 2.0 silicon may not support 1GHz but some of the early ++// * BeagleBone Blacks have PG 2.0 silicon which is guaranteed ++// * to support 1GHz OPP so enable it for PG 2.0 on this board. ++// */ ++// oppnitro@1000000000 { ++// opp-supported-hw = <0x06 0x0100>; ++// }; ++//}; + &am33xx_pinmux { nxp_hdmi_bonelt_pins: nxp_hdmi_bonelt_pins { pinctrl-single,pins = < diff --git a/arch/arm/boot/dts/am335x-boneblack-nhdmi-overlay.dts b/arch/arm/boot/dts/am335x-boneblack-nhdmi-overlay.dts -index 361b78b..c166c90 100644 +index 361b78bbb416..8fd74bef0ad6 100644 --- a/arch/arm/boot/dts/am335x-boneblack-nhdmi-overlay.dts +++ b/arch/arm/boot/dts/am335x-boneblack-nhdmi-overlay.dts @@ -37,6 +37,17 @@ }; }; -+&cpu0_opp_table { -+ /* -+ * All PG 2.0 silicon may not support 1GHz but some of the early -+ * BeagleBone Blacks have PG 2.0 silicon which is guaranteed -+ * to support 1GHz OPP so enable it for PG 2.0 on this board. -+ */ -+ oppnitro@1000000000 { -+ opp-supported-hw = <0x06 0x0100>; -+ }; -+}; ++//&cpu0_opp_table { ++// /* ++// * All PG 2.0 silicon may not support 1GHz but some of the early ++// * BeagleBone Blacks have PG 2.0 silicon which is guaranteed ++// * to support 1GHz OPP so enable it for PG 2.0 on this board. ++// */ ++// oppnitro@1000000000 { ++// opp-supported-hw = <0x06 0x0100>; ++// }; ++//}; + &am33xx_pinmux { nxp_hdmi_bonelt_pins: nxp_hdmi_bonelt_pins { pinctrl-single,pins = < diff --git a/arch/arm/boot/dts/am335x-boneblack-overlay.dts b/arch/arm/boot/dts/am335x-boneblack-overlay.dts -index f4f0c10..e9bbd93 100644 +index f4f0c100e210..11df99b2cba8 100644 --- a/arch/arm/boot/dts/am335x-boneblack-overlay.dts +++ b/arch/arm/boot/dts/am335x-boneblack-overlay.dts @@ -37,6 +37,13 @@ @@ -754,18 +756,19 @@ index f4f0c10..e9bbd93 100644 -&rtc { - system-power-controller; -+&cpu0_opp_table { -+ /* -+ * All PG 2.0 silicon may not support 1GHz but some of the early -+ * BeagleBone Blacks have PG 2.0 silicon which is guaranteed -+ * to support 1GHz OPP so enable it for PG 2.0 on this board. -+ */ -+ oppnitro@1000000000 { -+ opp-supported-hw = <0x06 0x0100>; -+ }; - }; +-}; ++//&cpu0_opp_table { ++// /* ++// * All PG 2.0 silicon may not support 1GHz but some of the early ++// * BeagleBone Blacks have PG 2.0 silicon which is guaranteed ++// * to support 1GHz OPP so enable it for PG 2.0 on this board. ++// */ ++// oppnitro@1000000000 { ++// opp-supported-hw = <0x06 0x0100>; ++// }; ++//}; diff --git a/arch/arm/boot/dts/am335x-boneblack-wl1835mod.dts b/arch/arm/boot/dts/am335x-boneblack-wl1835mod.dts -index e376613..f35b64a 100644 +index e376613cce21..3713ce38b820 100644 --- a/arch/arm/boot/dts/am335x-boneblack-wl1835mod.dts +++ b/arch/arm/boot/dts/am335x-boneblack-wl1835mod.dts @@ -25,10 +25,6 @@ @@ -783,21 +786,21 @@ index e376613..f35b64a 100644 }; }; -+&cpu0_opp_table { -+ /* -+ * All PG 2.0 silicon may not support 1GHz but some of the early -+ * BeagleBone Blacks have PG 2.0 silicon which is guaranteed -+ * to support 1GHz OPP so enable it for PG 2.0 on this board. -+ */ -+ oppnitro@1000000000 { -+ opp-supported-hw = <0x06 0x0100>; -+ }; -+}; ++//&cpu0_opp_table { ++// /* ++// * All PG 2.0 silicon may not support 1GHz but some of the early ++// * BeagleBone Blacks have PG 2.0 silicon which is guaranteed ++// * to support 1GHz OPP so enable it for PG 2.0 on this board. ++// */ ++// oppnitro@1000000000 { ++// opp-supported-hw = <0x06 0x0100>; ++// }; ++//}; + #include "am335x-boneblack-wl1835mod-cape.dtsi" diff --git a/arch/arm/boot/dts/am335x-cape-rtc-ds1307.dtsi b/arch/arm/boot/dts/am335x-cape-rtc-ds1307.dtsi new file mode 100644 -index 0000000..bce6ac5 +index 000000000000..bce6ac50cd89 --- /dev/null +++ b/arch/arm/boot/dts/am335x-cape-rtc-ds1307.dtsi @@ -0,0 +1,31 @@ @@ -834,7 +837,7 @@ index 0000000..bce6ac5 +}; diff --git a/arch/arm/boot/dts/am335x-peripheral-can1.dtsi b/arch/arm/boot/dts/am335x-peripheral-can1.dtsi new file mode 100644 -index 0000000..02b5bd1 +index 000000000000..02b5bd17066e --- /dev/null +++ b/arch/arm/boot/dts/am335x-peripheral-can1.dtsi @@ -0,0 +1,13 @@ @@ -853,7 +856,7 @@ index 0000000..02b5bd1 +}; diff --git a/arch/arm/boot/dts/am335x-peripheral-emmc.dtsi b/arch/arm/boot/dts/am335x-peripheral-emmc.dtsi new file mode 100644 -index 0000000..603f34e +index 000000000000..603f34ec6dc4 --- /dev/null +++ b/arch/arm/boot/dts/am335x-peripheral-emmc.dtsi @@ -0,0 +1,15 @@ @@ -874,7 +877,7 @@ index 0000000..603f34e +}; diff --git a/arch/arm/boot/dts/am335x-peripheral-i2c2.dtsi b/arch/arm/boot/dts/am335x-peripheral-i2c2.dtsi new file mode 100644 -index 0000000..ed9a0b5 +index 000000000000..ed9a0b52f913 --- /dev/null +++ b/arch/arm/boot/dts/am335x-peripheral-i2c2.dtsi @@ -0,0 +1,13 @@ @@ -893,7 +896,7 @@ index 0000000..ed9a0b5 +}; diff --git a/arch/arm/boot/dts/am335x-peripheral-nxp-hdmi.dtsi b/arch/arm/boot/dts/am335x-peripheral-nxp-hdmi.dtsi new file mode 100644 -index 0000000..1dfd26a +index 000000000000..1dfd26a691a6 --- /dev/null +++ b/arch/arm/boot/dts/am335x-peripheral-nxp-hdmi.dtsi @@ -0,0 +1,29 @@ @@ -928,7 +931,7 @@ index 0000000..1dfd26a +}; diff --git a/arch/arm/boot/dts/am335x-peripheral-spi0.dtsi b/arch/arm/boot/dts/am335x-peripheral-spi0.dtsi new file mode 100644 -index 0000000..969e352 +index 000000000000..969e35259979 --- /dev/null +++ b/arch/arm/boot/dts/am335x-peripheral-spi0.dtsi @@ -0,0 +1,13 @@ @@ -947,7 +950,7 @@ index 0000000..969e352 +}; diff --git a/arch/arm/boot/dts/am335x-peripheral-spi1.dtsi b/arch/arm/boot/dts/am335x-peripheral-spi1.dtsi new file mode 100644 -index 0000000..ac5fe97 +index 000000000000..ac5fe97b65d9 --- /dev/null +++ b/arch/arm/boot/dts/am335x-peripheral-spi1.dtsi @@ -0,0 +1,13 @@ @@ -966,7 +969,7 @@ index 0000000..ac5fe97 +}; diff --git a/arch/arm/boot/dts/am335x-peripheral-spi1a.dtsi b/arch/arm/boot/dts/am335x-peripheral-spi1a.dtsi new file mode 100644 -index 0000000..ac5fe97 +index 000000000000..ac5fe97b65d9 --- /dev/null +++ b/arch/arm/boot/dts/am335x-peripheral-spi1a.dtsi @@ -0,0 +1,13 @@ @@ -985,7 +988,7 @@ index 0000000..ac5fe97 +}; diff --git a/arch/arm/boot/dts/am335x-peripheral-ttyS5.dtsi b/arch/arm/boot/dts/am335x-peripheral-ttyS5.dtsi new file mode 100644 -index 0000000..8b42fb0 +index 000000000000..8b42fb02b9b4 --- /dev/null +++ b/arch/arm/boot/dts/am335x-peripheral-ttyS5.dtsi @@ -0,0 +1,13 @@ @@ -1003,5 +1006,5 @@ index 0000000..8b42fb0 + status = "okay"; +}; -- -2.10.2 +2.11.0 diff --git a/patches/debian-armmp b/patches/debian-armmp index 26d42a514ebc90812cfdaf55feca3aca1d213b57..c196929a47eee35bf0f2685b0b20c3983846be2f 100644 --- a/patches/debian-armmp +++ b/patches/debian-armmp @@ -1,6 +1,6 @@ # # Automatically generated file; DO NOT EDIT. -# Linux/arm 4.9.0-rc5 Kernel Configuration +# Linux/arm 4.9.0-rc8 Kernel Configuration # CONFIG_ARM=y CONFIG_ARM_HAS_SG_CHAIN=y @@ -2623,7 +2623,6 @@ CONFIG_STMMAC_PLATFORM=m CONFIG_DWMAC_GENERIC=m CONFIG_DWMAC_ROCKCHIP=m CONFIG_DWMAC_SOCFPGA=m -# CONFIG_DWMAC_STM32 is not set CONFIG_DWMAC_SUNXI=m # CONFIG_STMMAC_PCI is not set CONFIG_NET_VENDOR_SUN=y @@ -3586,7 +3585,6 @@ CONFIG_PINCTRL_WMT=y CONFIG_PINCTRL_WM8850=y CONFIG_ARCH_HAVE_CUSTOM_GPIO_H=y CONFIG_GPIOLIB=y -CONFIG_GPIO_DEVRES=y CONFIG_OF_GPIO=y CONFIG_GPIOLIB_IRQCHIP=y # CONFIG_DEBUG_GPIO is not set diff --git a/patches/defconfig b/patches/defconfig index e53a6431eee154adfd9c40fb28890c92be9d134d..ff2ca02f8c582507228167b2df9beecc132c78ac 100644 --- a/patches/defconfig +++ b/patches/defconfig @@ -1,6 +1,6 @@ # # Automatically generated file; DO NOT EDIT. -# Linux/arm 4.9.0 Kernel Configuration +# Linux/arm 4.10.0-rc1 Kernel Configuration # CONFIG_ARM=y CONFIG_ARM_HAS_SG_CHAIN=y @@ -137,6 +137,7 @@ CONFIG_PROC_PID_CPUSET=y CONFIG_CGROUP_DEVICE=y CONFIG_CGROUP_CPUACCT=y CONFIG_CGROUP_PERF=y +# CONFIG_CGROUP_BPF is not set # CONFIG_CGROUP_DEBUG is not set CONFIG_CHECKPOINT_RESTORE=y CONFIG_NAMESPACES=y @@ -156,6 +157,7 @@ CONFIG_RD_LZMA=y CONFIG_RD_XZ=y CONFIG_RD_LZO=y CONFIG_RD_LZ4=y +CONFIG_INITRAMFS_COMPRESSION=".gz" CONFIG_CC_OPTIMIZE_FOR_PERFORMANCE=y # CONFIG_CC_OPTIMIZE_FOR_SIZE is not set CONFIG_SYSCTL=y @@ -168,6 +170,7 @@ CONFIG_MULTIUSER=y # CONFIG_SGETMASK_SYSCALL is not set CONFIG_SYSFS_SYSCALL=y CONFIG_SYSCTL_SYSCALL=y +CONFIG_POSIX_TIMERS=y CONFIG_KALLSYMS=y CONFIG_KALLSYMS_ALL=y # CONFIG_KALLSYMS_ABSOLUTE_PERCPU is not set @@ -284,8 +287,10 @@ CONFIG_LBDAF=y CONFIG_BLK_DEV_BSG=y CONFIG_BLK_DEV_BSGLIB=y CONFIG_BLK_DEV_INTEGRITY=y +# CONFIG_BLK_DEV_ZONED is not set CONFIG_BLK_DEV_THROTTLING=y # CONFIG_BLK_CMDLINE_PARSER is not set +# CONFIG_BLK_WBT is not set # # Partition Types @@ -391,9 +396,6 @@ CONFIG_ARCH_OMAP=y # OMAP Feature Selections # CONFIG_OMAP_RESET_CLOCKS=y -CONFIG_OMAP_MUX=y -# CONFIG_OMAP_MUX_DEBUG is not set -CONFIG_OMAP_MUX_WARNINGS=y CONFIG_OMAP_32K_TIMER=y CONFIG_OMAP_DM_TIMER=y CONFIG_OMAP_PM_NOOP=y @@ -636,7 +638,6 @@ CONFIG_CPUFREQ_DT=m CONFIG_CPUFREQ_DT_PLATDEV=y # CONFIG_ARM_KIRKWOOD_CPUFREQ is not set # CONFIG_ARM_OMAP2PLUS_CPUFREQ is not set -CONFIG_ARM_TI_CPUFREQ=y # CONFIG_QORIQ_CPUFREQ is not set # @@ -762,6 +763,7 @@ CONFIG_INET_XFRM_MODE_BEET=m CONFIG_INET_DIAG=m CONFIG_INET_TCP_DIAG=m CONFIG_INET_UDP_DIAG=m +# CONFIG_INET_RAW_DIAG is not set # CONFIG_INET_DIAG_DESTROY is not set CONFIG_TCP_CONG_ADVANCED=y CONFIG_TCP_CONG_BIC=m @@ -812,6 +814,8 @@ CONFIG_IPV6_SUBTREES=y CONFIG_IPV6_MROUTE=y CONFIG_IPV6_MROUTE_MULTIPLE_TABLES=y CONFIG_IPV6_PIMSM_V2=y +# CONFIG_IPV6_SEG6_LWTUNNEL is not set +# CONFIG_IPV6_SEG6_HMAC is not set CONFIG_NETLABEL=y CONFIG_NETWORK_SECMARK=y CONFIG_NET_PTP_CLASSIFY=y @@ -831,6 +835,7 @@ CONFIG_NETFILTER_NETLINK_QUEUE=m CONFIG_NETFILTER_NETLINK_LOG=m CONFIG_NF_CONNTRACK=m CONFIG_NF_LOG_COMMON=m +# CONFIG_NF_LOG_NETDEV is not set CONFIG_NF_CONNTRACK_MARK=y CONFIG_NF_CONNTRACK_SECMARK=y CONFIG_NF_CONNTRACK_ZONES=y @@ -839,10 +844,10 @@ CONFIG_NF_CONNTRACK_EVENTS=y CONFIG_NF_CONNTRACK_TIMEOUT=y CONFIG_NF_CONNTRACK_TIMESTAMP=y CONFIG_NF_CONNTRACK_LABELS=y -CONFIG_NF_CT_PROTO_DCCP=m +CONFIG_NF_CT_PROTO_DCCP=y CONFIG_NF_CT_PROTO_GRE=m -CONFIG_NF_CT_PROTO_SCTP=m -CONFIG_NF_CT_PROTO_UDPLITE=m +CONFIG_NF_CT_PROTO_SCTP=y +CONFIG_NF_CT_PROTO_UDPLITE=y CONFIG_NF_CONNTRACK_AMANDA=m CONFIG_NF_CONNTRACK_FTP=m CONFIG_NF_CONNTRACK_H323=m @@ -860,9 +865,9 @@ CONFIG_NF_CT_NETLINK_HELPER=m CONFIG_NETFILTER_NETLINK_GLUE_CT=y CONFIG_NF_NAT=m CONFIG_NF_NAT_NEEDED=y -CONFIG_NF_NAT_PROTO_DCCP=m -CONFIG_NF_NAT_PROTO_UDPLITE=m -CONFIG_NF_NAT_PROTO_SCTP=m +CONFIG_NF_NAT_PROTO_DCCP=y +CONFIG_NF_NAT_PROTO_UDPLITE=y +CONFIG_NF_NAT_PROTO_SCTP=y CONFIG_NF_NAT_AMANDA=m CONFIG_NF_NAT_FTP=m CONFIG_NF_NAT_IRC=m @@ -875,6 +880,7 @@ CONFIG_NF_TABLES_INET=m CONFIG_NF_TABLES_NETDEV=m CONFIG_NFT_EXTHDR=m CONFIG_NFT_META=m +# CONFIG_NFT_RT is not set # CONFIG_NFT_NUMGEN is not set CONFIG_NFT_CT=m CONFIG_NFT_SET_RBTREE=m @@ -885,6 +891,7 @@ CONFIG_NFT_LIMIT=m CONFIG_NFT_MASQ=m CONFIG_NFT_REDIR=m CONFIG_NFT_NAT=m +# CONFIG_NFT_OBJREF is not set CONFIG_NFT_QUEUE=m # CONFIG_NFT_QUOTA is not set CONFIG_NFT_REJECT=m @@ -975,7 +982,6 @@ CONFIG_NETFILTER_XT_MATCH_RATEEST=m CONFIG_NETFILTER_XT_MATCH_REALM=m CONFIG_NETFILTER_XT_MATCH_RECENT=m CONFIG_NETFILTER_XT_MATCH_SCTP=m -CONFIG_NETFILTER_XT_MATCH_SOCKET=m CONFIG_NETFILTER_XT_MATCH_STATE=m CONFIG_NETFILTER_XT_MATCH_STATISTIC=m CONFIG_NETFILTER_XT_MATCH_STRING=m @@ -992,6 +998,7 @@ CONFIG_IP_SET_HASH_IPMARK=m CONFIG_IP_SET_HASH_IPPORT=m CONFIG_IP_SET_HASH_IPPORTIP=m CONFIG_IP_SET_HASH_IPPORTNET=m +# CONFIG_IP_SET_HASH_IPMAC is not set CONFIG_IP_SET_HASH_MAC=m CONFIG_IP_SET_HASH_NETPORTNET=m CONFIG_IP_SET_HASH_NET=m @@ -1047,10 +1054,12 @@ CONFIG_IP_VS_PE_SIP=m # CONFIG_NF_DEFRAG_IPV4=m CONFIG_NF_CONNTRACK_IPV4=m +# CONFIG_NF_SOCKET_IPV4 is not set CONFIG_NF_TABLES_IPV4=m CONFIG_NFT_CHAIN_ROUTE_IPV4=m CONFIG_NFT_REJECT_IPV4=m CONFIG_NFT_DUP_IPV4=m +# CONFIG_NFT_FIB_IPV4 is not set CONFIG_NF_TABLES_ARP=m CONFIG_NF_DUP_IPV4=m CONFIG_NF_LOG_ARP=m @@ -1092,10 +1101,12 @@ CONFIG_IP_NF_ARP_MANGLE=m # CONFIG_NF_DEFRAG_IPV6=m CONFIG_NF_CONNTRACK_IPV6=m +# CONFIG_NF_SOCKET_IPV6 is not set CONFIG_NF_TABLES_IPV6=m CONFIG_NFT_CHAIN_ROUTE_IPV6=m CONFIG_NFT_REJECT_IPV6=m CONFIG_NFT_DUP_IPV6=m +# CONFIG_NFT_FIB_IPV6 is not set CONFIG_NF_DUP_IPV6=m CONFIG_NF_REJECT_IPV6=m CONFIG_NF_LOG_IPV6=m @@ -1547,6 +1558,7 @@ CONFIG_NFC_MICROREAD_I2C=m # CONFIG_NFC_S3FWRN5_I2C is not set # CONFIG_NFC_ST95HF is not set CONFIG_LWTUNNEL=y +CONFIG_LWTUNNEL_BPF=y CONFIG_DST_CACHE=y # CONFIG_NET_DEVLINK is not set CONFIG_MAY_USE_DEVLINK=y @@ -1577,6 +1589,7 @@ CONFIG_DEV_COREDUMP=y # CONFIG_DEBUG_DRIVER is not set # CONFIG_DEBUG_DEVRES is not set # CONFIG_DEBUG_TEST_DRIVER_REMOVE is not set +# CONFIG_TEST_ASYNC_DRIVER_PROBE is not set # CONFIG_SYS_HYPERVISOR is not set # CONFIG_GENERIC_CPU_DEVICES is not set CONFIG_SOC_BUS=y @@ -1586,7 +1599,7 @@ CONFIG_REGMAP_SPI=y CONFIG_REGMAP_MMIO=y CONFIG_REGMAP_IRQ=y CONFIG_DMA_SHARED_BUFFER=y -# CONFIG_FENCE_TRACE is not set +# CONFIG_DMA_FENCE_TRACE is not set CONFIG_DMA_CMA=y # @@ -1698,6 +1711,7 @@ CONFIG_MTD_NAND_IDS=y CONFIG_MTD_NAND_NANDSIM=m # CONFIG_MTD_NAND_BRCMNAND is not set # CONFIG_MTD_NAND_PLATFORM is not set +# CONFIG_MTD_NAND_OXNAS is not set # CONFIG_MTD_NAND_HISI504 is not set # CONFIG_MTD_NAND_MTK is not set CONFIG_MTD_ONENAND=y @@ -1757,6 +1771,7 @@ CONFIG_ATA_OVER_ETH=m # CONFIG_MG_DISK is not set CONFIG_VIRTIO_BLK=m CONFIG_BLK_DEV_RBD=m +# CONFIG_NVME_FC is not set # CONFIG_NVME_TARGET is not set # @@ -1959,7 +1974,7 @@ CONFIG_BLK_DEV_DM=m # CONFIG_DM_MQ_DEFAULT is not set # CONFIG_DM_DEBUG is not set CONFIG_DM_BUFIO=m -# CONFIG_DM_DEBUG_BLOCK_STACK_TRACING is not set +# CONFIG_DM_DEBUG_BLOCK_MANAGER_LOCKING is not set CONFIG_DM_BIO_PRISON=m CONFIG_DM_PERSISTENT_DATA=m CONFIG_DM_CRYPT=m @@ -2043,6 +2058,7 @@ CONFIG_NET_DSA_MV88E6XXX=m CONFIG_NET_DSA_MV88E6XXX_GLOBAL2=y # CONFIG_NET_DSA_QCA8K is not set CONFIG_ETHERNET=y +CONFIG_NET_VENDOR_ALACRITECH=y # CONFIG_ALTERA_TSE is not set CONFIG_NET_VENDOR_AMAZON=y # CONFIG_NET_VENDOR_ARC is not set @@ -2095,6 +2111,7 @@ CONFIG_NET_VENDOR_ROCKER=y CONFIG_NET_VENDOR_SAMSUNG=y # CONFIG_SXGBE_ETH is not set CONFIG_NET_VENDOR_SEEQ=y +CONFIG_NET_VENDOR_SOLARFLARE=y CONFIG_NET_VENDOR_SMSC=y CONFIG_SMC91X=m CONFIG_SMC911X=m @@ -2119,6 +2136,7 @@ CONFIG_NET_VENDOR_WIZNET=y # CONFIG_WIZNET_W5300 is not set CONFIG_PHYLIB=y CONFIG_SWPHY=y +# CONFIG_LED_TRIGGER_PHY is not set # # MDIO bus device drivers @@ -2149,6 +2167,7 @@ CONFIG_ICPLUS_PHY=m CONFIG_LSI_ET1011C_PHY=m CONFIG_LXT_PHY=m CONFIG_MARVELL_PHY=m +# CONFIG_MESON_GXL_PHY is not set CONFIG_MICREL_PHY=y CONFIG_MICROCHIP_PHY=m CONFIG_MICROSEMI_PHY=y @@ -2223,6 +2242,7 @@ CONFIG_USB_SIERRA_NET=m CONFIG_USB_VL600=m CONFIG_USB_NET_CH9200=m CONFIG_WLAN=y +# CONFIG_WIRELESS_WDS is not set CONFIG_WLAN_VENDOR_ADMTEK=y CONFIG_ATH_COMMON=m CONFIG_WLAN_VENDOR_ATH=y @@ -2718,7 +2738,6 @@ CONFIG_CONSOLE_POLL=y # CONFIG_SERIAL_FSL_LPUART is not set # CONFIG_SERIAL_CONEXANT_DIGICOLOR is not set # CONFIG_SERIAL_ST_ASC is not set -# CONFIG_SERIAL_STM32 is not set CONFIG_TTY_PRINTK=m CONFIG_HVC_DRIVER=y # CONFIG_HVC_DCC is not set @@ -2733,6 +2752,7 @@ CONFIG_HW_RANDOM_TPM=m # CONFIG_R3964 is not set # CONFIG_RAW_DRIVER is not set CONFIG_TCG_TPM=m +# CONFIG_TCG_TIS is not set # CONFIG_TCG_TIS_SPI is not set CONFIG_TCG_TIS_I2C_ATMEL=m # CONFIG_TCG_TIS_I2C_INFINEON is not set @@ -2762,6 +2782,7 @@ CONFIG_I2C_MUX_PCA954x=m CONFIG_I2C_MUX_PINCTRL=y # CONFIG_I2C_MUX_REG is not set # CONFIG_I2C_DEMUX_PINCTRL is not set +# CONFIG_I2C_MUX_MLXCPLD is not set CONFIG_I2C_HELPER_AUTO=y CONFIG_I2C_ALGOBIT=y CONFIG_I2C_ALGOPCA=m @@ -2886,6 +2907,7 @@ CONFIG_GENERIC_PINCONF=y CONFIG_PINCTRL_AS3722=y # CONFIG_PINCTRL_AMD is not set CONFIG_PINCTRL_SINGLE=y +CONFIG_PINCTRL_SX150X=y CONFIG_PINCTRL_TI_IODELAY=y CONFIG_PINCTRL_PALMAS=y CONFIG_ARCH_HAVE_CUSTOM_GPIO_H=y @@ -2905,7 +2927,6 @@ CONFIG_GPIO_MAX730X=m # CONFIG_GPIO_ALTERA is not set CONFIG_GPIO_AXP209=y # CONFIG_GPIO_DWAPB is not set -# CONFIG_GPIO_EM is not set CONFIG_GPIO_GENERIC_PLATFORM=y # CONFIG_GPIO_GRGPIO is not set # CONFIG_GPIO_MOCKUP is not set @@ -2914,7 +2935,6 @@ CONFIG_GPIO_OMAP=y CONFIG_GPIO_SYSCON=y CONFIG_GPIO_XILINX=y # CONFIG_GPIO_ZEVIO is not set -# CONFIG_GPIO_ZX is not set # # I2C GPIO expanders @@ -2928,7 +2948,6 @@ CONFIG_GPIO_PCA953X_IRQ=y CONFIG_GPIO_PCF857X=m CONFIG_GPIO_SX150X=y CONFIG_GPIO_TPIC2810=m -# CONFIG_GPIO_TS4900 is not set # # MFD GPIO expanders @@ -3105,6 +3124,7 @@ CONFIG_SENSORS_MAX6650=m CONFIG_SENSORS_MAX6697=m CONFIG_SENSORS_MAX31790=m CONFIG_SENSORS_MCP3021=m +# CONFIG_SENSORS_TC654 is not set CONFIG_SENSORS_ADCXX=m CONFIG_SENSORS_LM63=m CONFIG_SENSORS_LM70=m @@ -3173,6 +3193,7 @@ CONFIG_SENSORS_TC74=m CONFIG_SENSORS_THMC50=m CONFIG_SENSORS_TMP102=m CONFIG_SENSORS_TMP103=m +# CONFIG_SENSORS_TMP108 is not set CONFIG_SENSORS_TMP401=m CONFIG_SENSORS_TMP421=m CONFIG_SENSORS_TWL4030_MADC=m @@ -3299,7 +3320,6 @@ CONFIG_MFD_DA9055=y CONFIG_MFD_DA9063=y # CONFIG_MFD_DA9150 is not set CONFIG_MFD_DLN2=y -# CONFIG_MFD_EXYNOS_LPASS is not set CONFIG_MFD_MC13XXX=m CONFIG_MFD_MC13XXX_SPI=m CONFIG_MFD_MC13XXX_I2C=m @@ -3327,7 +3347,7 @@ CONFIG_MFD_VIPERBOARD=m # CONFIG_MFD_RETU is not set # CONFIG_MFD_PCF50633 is not set # CONFIG_UCB1400_CORE is not set -# CONFIG_MFD_PM8921_CORE is not set +# CONFIG_MFD_PM8XXX is not set # CONFIG_MFD_RT5033 is not set CONFIG_MFD_RTSX_USB=m # CONFIG_MFD_RC5T583 is not set @@ -3453,6 +3473,7 @@ CONFIG_MEDIA_DIGITAL_TV_SUPPORT=y CONFIG_MEDIA_RADIO_SUPPORT=y CONFIG_MEDIA_SDR_SUPPORT=y CONFIG_MEDIA_RC_SUPPORT=y +# CONFIG_MEDIA_CEC_SUPPORT is not set CONFIG_MEDIA_CEC_EDID=y CONFIG_MEDIA_CONTROLLER=y # CONFIG_MEDIA_CONTROLLER_DVB is not set @@ -3476,6 +3497,7 @@ CONFIG_DVB_NET=y CONFIG_TTPCI_EEPROM=m CONFIG_DVB_MAX_ADAPTERS=8 CONFIG_DVB_DYNAMIC_MINORS=y +# CONFIG_DVB_DEMUX_SECTION_LOSS_LOG is not set # # Media drivers @@ -3507,6 +3529,7 @@ CONFIG_IR_TTUSBIR=m # CONFIG_IR_RX51 is not set CONFIG_RC_LOOPBACK=m CONFIG_IR_GPIO_CIR=m +# CONFIG_IR_SERIAL is not set CONFIG_MEDIA_USB_SUPPORT=y # @@ -3969,9 +3992,11 @@ CONFIG_DVB_AF9033=m # # Graphics support # +# CONFIG_IMX_IPUV3_CORE is not set CONFIG_DRM=y CONFIG_DRM_MIPI_DSI=y # CONFIG_DRM_DP_AUX_CHARDEV is not set +# CONFIG_DRM_DEBUG_MM is not set CONFIG_DRM_KMS_HELPER=y CONFIG_DRM_KMS_FB_HELPER=y CONFIG_DRM_FBDEV_EMULATION=y @@ -4011,13 +4036,17 @@ CONFIG_DRM_BRIDGE=y # CONFIG_DRM_DUMB_VGA_DAC is not set # CONFIG_DRM_NXP_PTN3460 is not set # CONFIG_DRM_PARADE_PS8622 is not set +# CONFIG_DRM_SIL_SII8620 is not set # CONFIG_DRM_SII902X is not set # CONFIG_DRM_TOSHIBA_TC358767 is not set +# CONFIG_DRM_TI_TFP410 is not set CONFIG_DRM_I2C_ADV7511=m +# CONFIG_DRM_I2C_ADV7511_AUDIO is not set CONFIG_DRM_I2C_ADV7533=y # CONFIG_DRM_STI is not set # CONFIG_DRM_ETNAVIV is not set # CONFIG_DRM_ARCPGU is not set +# CONFIG_DRM_MXSFB is not set # CONFIG_DRM_LEGACY is not set CONFIG_DRM_TINYDRM=y CONFIG_TINYDRM_MIPI_DBI=m @@ -4210,6 +4239,8 @@ CONFIG_SND_SOC_I2C_AND_SPI=m # CONFIG_SND_SOC_BT_SCO is not set # CONFIG_SND_SOC_CS35L32 is not set # CONFIG_SND_SOC_CS35L33 is not set +# CONFIG_SND_SOC_CS35L34 is not set +# CONFIG_SND_SOC_CS42L42 is not set # CONFIG_SND_SOC_CS42L51_I2C is not set # CONFIG_SND_SOC_CS42L52 is not set # CONFIG_SND_SOC_CS42L56 is not set @@ -4227,6 +4258,7 @@ CONFIG_SND_SOC_ES8328=m # CONFIG_SND_SOC_INNO_RK3036 is not set # CONFIG_SND_SOC_MAX98504 is not set # CONFIG_SND_SOC_MAX9860 is not set +# CONFIG_SND_SOC_MSM8916_WCD_DIGITAL is not set # CONFIG_SND_SOC_PCM1681 is not set # CONFIG_SND_SOC_PCM179X_I2C is not set # CONFIG_SND_SOC_PCM179X_SPI is not set @@ -4250,7 +4282,7 @@ CONFIG_SND_SOC_SGTL5000=m # CONFIG_SND_SOC_TAS5086 is not set # CONFIG_SND_SOC_TAS571X is not set # CONFIG_SND_SOC_TAS5720 is not set -CONFIG_SND_SOC_TDM=m +# CONFIG_SND_SOC_TDM is not set # CONFIG_SND_SOC_TFA9879 is not set CONFIG_SND_SOC_TLV320AIC23=m CONFIG_SND_SOC_TLV320AIC23_I2C=m @@ -4344,6 +4376,7 @@ CONFIG_LOGIRUMBLEPAD2_FF=y CONFIG_LOGIG940_FF=y CONFIG_LOGIWHEELS_FF=y CONFIG_HID_MAGICMOUSE=m +# CONFIG_HID_MAYFLASH is not set CONFIG_HID_MICROSOFT=m CONFIG_HID_MONTEREY=m CONFIG_HID_MULTITOUCH=m @@ -4378,6 +4411,7 @@ CONFIG_HID_TOPSEED=m CONFIG_HID_THINGM=m CONFIG_HID_THRUSTMASTER=m CONFIG_THRUSTMASTER_FF=y +# CONFIG_HID_UDRAW_PS3 is not set CONFIG_HID_WACOM=m CONFIG_HID_WIIMOTE=m CONFIG_HID_XINMO=m @@ -4556,6 +4590,7 @@ CONFIG_USB_SERIAL_IR=m CONFIG_USB_SERIAL_EDGEPORT=m CONFIG_USB_SERIAL_EDGEPORT_TI=m CONFIG_USB_SERIAL_F81232=m +# CONFIG_USB_SERIAL_F8153X is not set CONFIG_USB_SERIAL_GARMIN=m CONFIG_USB_SERIAL_IPW=m CONFIG_USB_SERIAL_IUU=m @@ -4743,10 +4778,6 @@ CONFIG_MMC=y # CONFIG_MMC_DEBUG is not set CONFIG_PWRSEQ_EMMC=y CONFIG_PWRSEQ_SIMPLE=y - -# -# MMC/SD/SDIO Card Drivers -# CONFIG_MMC_BLOCK=y CONFIG_MMC_BLOCK_MINORS=8 CONFIG_MMC_BLOCK_BOUNCE=y @@ -4760,6 +4791,7 @@ CONFIG_MMC_SDHCI=y CONFIG_MMC_SDHCI_PLTFM=y CONFIG_MMC_SDHCI_OF_ARASAN=y # CONFIG_MMC_SDHCI_OF_AT91 is not set +# CONFIG_MMC_SDHCI_CADENCE is not set # CONFIG_MMC_SDHCI_F_SDH30 is not set CONFIG_MMC_OMAP=m CONFIG_MMC_OMAP_HS=y @@ -4827,6 +4859,7 @@ CONFIG_LEDS_IS31FL32XX=m # # CONFIG_LEDS_BLINKM is not set # CONFIG_LEDS_SYSCON is not set +# CONFIG_LEDS_USER is not set # # LED Triggers @@ -4974,6 +5007,7 @@ CONFIG_RTC_DRV_ZYNQMP=m CONFIG_RTC_DRV_OMAP=y CONFIG_RTC_DRV_MC13XXX=m CONFIG_RTC_DRV_SNVS=y +# CONFIG_RTC_DRV_R7301 is not set # # HID Sensor RTC drivers @@ -5009,7 +5043,8 @@ CONFIG_ASYNC_TX_DMA=y # # DMABUF options # -# CONFIG_SYNC_FILE is not set +CONFIG_SYNC_FILE=y +# CONFIG_SW_SYNC is not set # CONFIG_AUXDISPLAY is not set CONFIG_UIO=m CONFIG_UIO_PDRV_GENIRQ=m @@ -5053,7 +5088,6 @@ CONFIG_ADIS16201=m CONFIG_ADIS16203=m CONFIG_ADIS16209=m CONFIG_ADIS16240=m -CONFIG_SCA3000=m # # Analog to digital converters @@ -5099,9 +5133,7 @@ CONFIG_AD5933=m # # Light sensors # -CONFIG_SENSORS_ISL29018=m CONFIG_SENSORS_ISL29028=m -CONFIG_TSL2583=m # CONFIG_TSL2x7x is not set # @@ -5245,6 +5277,13 @@ CONFIG_COMMON_CLK_PALMAS=y # CONFIG_COMMON_CLK_PWM is not set # CONFIG_COMMON_CLK_PXA is not set # CONFIG_COMMON_CLK_PIC32 is not set +# CONFIG_COMMON_CLK_MT2701 is not set +# CONFIG_COMMON_CLK_MT2701_MMSYS is not set +# CONFIG_COMMON_CLK_MT2701_IMGSYS is not set +# CONFIG_COMMON_CLK_MT2701_VDECSYS is not set +# CONFIG_COMMON_CLK_MT2701_HIFSYS is not set +# CONFIG_COMMON_CLK_MT2701_ETHSYS is not set +# CONFIG_COMMON_CLK_MT2701_BDPSYS is not set CONFIG_COMMON_CLK_TI_ADPLL=y CONFIG_HWSPINLOCK=y @@ -5294,7 +5333,6 @@ CONFIG_ARM_SMMU=y # Remoteproc drivers # CONFIG_REMOTEPROC=y -# CONFIG_STE_MODEM_RPROC is not set CONFIG_WKUP_M3_RPROC=y # @@ -5365,8 +5403,11 @@ CONFIG_BMA220=m CONFIG_BMC150_ACCEL=m CONFIG_BMC150_ACCEL_I2C=m CONFIG_BMC150_ACCEL_SPI=m +# CONFIG_DA280 is not set +# CONFIG_DA311 is not set CONFIG_DMARD06=m CONFIG_DMARD09=m +# CONFIG_DMARD10 is not set CONFIG_HID_SENSOR_ACCEL_3D=m CONFIG_IIO_ST_ACCEL_3AXIS=m CONFIG_IIO_ST_ACCEL_I2C_3AXIS=m @@ -5386,6 +5427,7 @@ CONFIG_MMA9551=m CONFIG_MMA9553=m CONFIG_MXC4005=m CONFIG_MXC6255=m +CONFIG_SCA3000=m CONFIG_STK8312=m CONFIG_STK8BA50=m @@ -5397,6 +5439,7 @@ CONFIG_AD7266=m CONFIG_AD7291=m CONFIG_AD7298=m CONFIG_AD7476=m +# CONFIG_AD7766 is not set CONFIG_AD7791=m CONFIG_AD7793=m CONFIG_AD7887=m @@ -5404,6 +5447,7 @@ CONFIG_AD7923=m CONFIG_AD799X=m CONFIG_AXP288_ADC=m CONFIG_CC10001_ADC=m +# CONFIG_ENVELOPE_DETECTOR is not set CONFIG_HI8435=m CONFIG_INA2XX_ADC=m CONFIG_LTC2485=m @@ -5437,6 +5481,7 @@ CONFIG_AD8366=m CONFIG_ATLAS_PH_SENSOR=m CONFIG_IAQCORE=m CONFIG_VZ89X=m +# CONFIG_IIO_CROS_EC_SENSORS_CORE is not set # # Hid Sensor IIO Common @@ -5454,6 +5499,10 @@ CONFIG_IIO_ST_SENSORS_I2C=m CONFIG_IIO_ST_SENSORS_SPI=m CONFIG_IIO_ST_SENSORS_CORE=m +# +# Counters +# + # # Digital to analog converters # @@ -5475,6 +5524,7 @@ CONFIG_AD5764=m CONFIG_AD5791=m CONFIG_AD7303=m CONFIG_AD8801=m +# CONFIG_DPOT_DAC is not set CONFIG_M62332=m CONFIG_MAX517=m CONFIG_MAX5821=m @@ -5534,6 +5584,7 @@ CONFIG_MAX30100=m CONFIG_AM2315=m CONFIG_DHT11=m CONFIG_HDC100X=m +# CONFIG_HTS221 is not set CONFIG_HTU21=m CONFIG_SI7005=m CONFIG_SI7020=m @@ -5567,6 +5618,7 @@ CONFIG_CM3232=m CONFIG_CM3323=m CONFIG_CM36651=m CONFIG_GP2AP020A00F=m +CONFIG_SENSORS_ISL29018=m CONFIG_ISL29125=m CONFIG_HID_SENSOR_ALS=m CONFIG_HID_SENSOR_PROX=m @@ -5581,6 +5633,7 @@ CONFIG_STK3310=m CONFIG_TCS3414=m CONFIG_TCS3472=m CONFIG_SENSORS_TSL2563=m +CONFIG_TSL2583=m CONFIG_TSL4531=m CONFIG_US5182D=m CONFIG_VCNL4000=m @@ -5626,9 +5679,15 @@ CONFIG_MCP4131=m CONFIG_MCP4531=m CONFIG_TPL0102=m +# +# Digital potentiostats +# +# CONFIG_LMP91000 is not set + # # Pressure sensors # +# CONFIG_ABP060MG is not set CONFIG_BMP280=m CONFIG_BMP280_I2C=m CONFIG_BMP280_SPI=m @@ -5737,6 +5796,10 @@ CONFIG_ARM_PSCI_FW=y # CONFIG_FW_CFG_SYSFS is not set CONFIG_HAVE_ARM_SMCCC=y +# +# Tegra firmware driver +# + # # File systems # @@ -5818,6 +5881,7 @@ CONFIG_AUTOFS4_FS=y CONFIG_FUSE_FS=y CONFIG_CUSE=m CONFIG_OVERLAY_FS=y +# CONFIG_OVERLAY_FS_REDIRECT_DIR is not set # # Caches @@ -5903,7 +5967,7 @@ CONFIG_UBIFS_FS_ADVANCED_COMPR=y CONFIG_UBIFS_FS_LZO=y CONFIG_UBIFS_FS_ZLIB=y # CONFIG_UBIFS_ATIME_SUPPORT is not set -# CONFIG_LOGFS is not set +# CONFIG_UBIFS_FS_ENCRYPTION is not set # CONFIG_CRAMFS is not set CONFIG_SQUASHFS=m CONFIG_SQUASHFS_FILE_CACHE=y @@ -5939,23 +6003,6 @@ CONFIG_UFS_FS=m # CONFIG_UFS_DEBUG is not set CONFIG_EXOFS_FS=m # CONFIG_EXOFS_DEBUG is not set -CONFIG_AUFS_FS=m -CONFIG_AUFS_BRANCH_MAX_127=y -# CONFIG_AUFS_BRANCH_MAX_511 is not set -# CONFIG_AUFS_BRANCH_MAX_1023 is not set -# CONFIG_AUFS_BRANCH_MAX_32767 is not set -CONFIG_AUFS_SBILIST=y -# CONFIG_AUFS_HNOTIFY is not set -CONFIG_AUFS_EXPORT=y -CONFIG_AUFS_XATTR=y -# CONFIG_AUFS_FHSM is not set -# CONFIG_AUFS_RDU is not set -# CONFIG_AUFS_SHWH is not set -# CONFIG_AUFS_BR_RAMFS is not set -# CONFIG_AUFS_BR_FUSE is not set -CONFIG_AUFS_BR_HFSPLUS=y -CONFIG_AUFS_BDEV_LOOP=y -# CONFIG_AUFS_DEBUG is not set CONFIG_ORE=m CONFIG_NETWORK_FILESYSTEMS=y CONFIG_NFS_FS=y @@ -6094,6 +6141,7 @@ CONFIG_DLM_DEBUG=y # printk and dmesg options # CONFIG_PRINTK_TIME=y +CONFIG_CONSOLE_LOGLEVEL_DEFAULT=7 CONFIG_MESSAGE_LOGLEVEL_DEFAULT=4 CONFIG_BOOT_PRINTK_DELAY=y CONFIG_DYNAMIC_DEBUG=y @@ -6265,6 +6313,7 @@ CONFIG_TEST_FIRMWARE=m # CONFIG_TEST_UDELAY is not set # CONFIG_MEMTEST is not set CONFIG_TEST_STATIC_KEYS=m +# CONFIG_BUG_ON_DATA_CORRUPTION is not set # CONFIG_SAMPLES is not set CONFIG_HAVE_ARCH_KGDB=y CONFIG_KGDB=y @@ -6363,6 +6412,7 @@ CONFIG_CRYPTO_RNG_DEFAULT=y CONFIG_CRYPTO_AKCIPHER2=y CONFIG_CRYPTO_AKCIPHER=y CONFIG_CRYPTO_KPP2=y +CONFIG_CRYPTO_ACOMP2=y CONFIG_CRYPTO_RSA=y # CONFIG_CRYPTO_DH is not set # CONFIG_CRYPTO_ECDH is not set @@ -6378,7 +6428,7 @@ CONFIG_CRYPTO_CRYPTD=m # CONFIG_CRYPTO_MCRYPTD is not set CONFIG_CRYPTO_AUTHENC=m CONFIG_CRYPTO_TEST=m -CONFIG_CRYPTO_ABLK_HELPER=m +CONFIG_CRYPTO_SIMD=m CONFIG_CRYPTO_ENGINE=m # @@ -6481,9 +6531,11 @@ CONFIG_CRYPTO_USER_API_SKCIPHER=m CONFIG_CRYPTO_USER_API_AEAD=m CONFIG_CRYPTO_HASH_INFO=y CONFIG_CRYPTO_HW=y +# CONFIG_CRYPTO_DEV_FSL_CAAM_CRYPTO_API_DESC is not set CONFIG_CRYPTO_DEV_OMAP_SHAM=m CONFIG_CRYPTO_DEV_OMAP_AES=m CONFIG_CRYPTO_DEV_OMAP_DES=m +CONFIG_CRYPTO_DEV_VIRTIO=m CONFIG_ASYMMETRIC_KEY_TYPE=y CONFIG_ASYMMETRIC_PUBLIC_KEY_SUBTYPE=y CONFIG_X509_CERTIFICATE_PARSER=y @@ -6504,6 +6556,8 @@ CONFIG_CRYPTO_AES_ARM=m CONFIG_CRYPTO_AES_ARM_BS=m # CONFIG_CRYPTO_AES_ARM_CE is not set # CONFIG_CRYPTO_GHASH_ARM_CE is not set +# CONFIG_CRYPTO_CRCT10DIF_ARM_CE is not set +# CONFIG_CRYPTO_CRC32_ARM_CE is not set CONFIG_BINARY_PRINTF=y # diff --git a/patches/defconfig-bone b/patches/defconfig-bone index 30e31257d29b3dcf4d7b183b896b1cc654a617b5..acf1edd0d0367f25305df7913f95d7d8dc650d71 100644 --- a/patches/defconfig-bone +++ b/patches/defconfig-bone @@ -1,6 +1,6 @@ # # Automatically generated file; DO NOT EDIT. -# Linux/arm 4.9.0 Kernel Configuration +# Linux/arm 4.10.0-rc1 Kernel Configuration # CONFIG_ARM=y CONFIG_ARM_HAS_SG_CHAIN=y @@ -137,6 +137,7 @@ CONFIG_PROC_PID_CPUSET=y CONFIG_CGROUP_DEVICE=y CONFIG_CGROUP_CPUACCT=y CONFIG_CGROUP_PERF=y +# CONFIG_CGROUP_BPF is not set # CONFIG_CGROUP_DEBUG is not set CONFIG_CHECKPOINT_RESTORE=y CONFIG_NAMESPACES=y @@ -156,6 +157,7 @@ CONFIG_RD_LZMA=y CONFIG_RD_XZ=y CONFIG_RD_LZO=y CONFIG_RD_LZ4=y +CONFIG_INITRAMFS_COMPRESSION=".gz" CONFIG_CC_OPTIMIZE_FOR_PERFORMANCE=y # CONFIG_CC_OPTIMIZE_FOR_SIZE is not set CONFIG_SYSCTL=y @@ -168,6 +170,7 @@ CONFIG_MULTIUSER=y # CONFIG_SGETMASK_SYSCALL is not set CONFIG_SYSFS_SYSCALL=y CONFIG_SYSCTL_SYSCALL=y +CONFIG_POSIX_TIMERS=y CONFIG_KALLSYMS=y CONFIG_KALLSYMS_ALL=y # CONFIG_KALLSYMS_ABSOLUTE_PERCPU is not set @@ -284,8 +287,10 @@ CONFIG_LBDAF=y CONFIG_BLK_DEV_BSG=y CONFIG_BLK_DEV_BSGLIB=y CONFIG_BLK_DEV_INTEGRITY=y +# CONFIG_BLK_DEV_ZONED is not set CONFIG_BLK_DEV_THROTTLING=y # CONFIG_BLK_CMDLINE_PARSER is not set +# CONFIG_BLK_WBT is not set # # Partition Types @@ -391,9 +396,6 @@ CONFIG_ARCH_OMAP=y # OMAP Feature Selections # CONFIG_OMAP_RESET_CLOCKS=y -CONFIG_OMAP_MUX=y -# CONFIG_OMAP_MUX_DEBUG is not set -CONFIG_OMAP_MUX_WARNINGS=y CONFIG_OMAP_32K_TIMER=y CONFIG_OMAP_DM_TIMER=y CONFIG_OMAP_PM_NOOP=y @@ -636,7 +638,6 @@ CONFIG_CPUFREQ_DT=m CONFIG_CPUFREQ_DT_PLATDEV=y # CONFIG_ARM_KIRKWOOD_CPUFREQ is not set # CONFIG_ARM_OMAP2PLUS_CPUFREQ is not set -CONFIG_ARM_TI_CPUFREQ=y # CONFIG_QORIQ_CPUFREQ is not set # @@ -762,6 +763,7 @@ CONFIG_INET_XFRM_MODE_BEET=m CONFIG_INET_DIAG=m CONFIG_INET_TCP_DIAG=m CONFIG_INET_UDP_DIAG=m +# CONFIG_INET_RAW_DIAG is not set # CONFIG_INET_DIAG_DESTROY is not set CONFIG_TCP_CONG_ADVANCED=y CONFIG_TCP_CONG_BIC=m @@ -812,6 +814,8 @@ CONFIG_IPV6_SUBTREES=y CONFIG_IPV6_MROUTE=y CONFIG_IPV6_MROUTE_MULTIPLE_TABLES=y CONFIG_IPV6_PIMSM_V2=y +# CONFIG_IPV6_SEG6_LWTUNNEL is not set +# CONFIG_IPV6_SEG6_HMAC is not set CONFIG_NETLABEL=y CONFIG_NETWORK_SECMARK=y CONFIG_NET_PTP_CLASSIFY=y @@ -831,6 +835,7 @@ CONFIG_NETFILTER_NETLINK_QUEUE=m CONFIG_NETFILTER_NETLINK_LOG=m CONFIG_NF_CONNTRACK=m CONFIG_NF_LOG_COMMON=m +# CONFIG_NF_LOG_NETDEV is not set CONFIG_NF_CONNTRACK_MARK=y CONFIG_NF_CONNTRACK_SECMARK=y CONFIG_NF_CONNTRACK_ZONES=y @@ -839,10 +844,10 @@ CONFIG_NF_CONNTRACK_EVENTS=y CONFIG_NF_CONNTRACK_TIMEOUT=y CONFIG_NF_CONNTRACK_TIMESTAMP=y CONFIG_NF_CONNTRACK_LABELS=y -CONFIG_NF_CT_PROTO_DCCP=m +CONFIG_NF_CT_PROTO_DCCP=y CONFIG_NF_CT_PROTO_GRE=m -CONFIG_NF_CT_PROTO_SCTP=m -CONFIG_NF_CT_PROTO_UDPLITE=m +CONFIG_NF_CT_PROTO_SCTP=y +CONFIG_NF_CT_PROTO_UDPLITE=y CONFIG_NF_CONNTRACK_AMANDA=m CONFIG_NF_CONNTRACK_FTP=m CONFIG_NF_CONNTRACK_H323=m @@ -860,9 +865,9 @@ CONFIG_NF_CT_NETLINK_HELPER=m CONFIG_NETFILTER_NETLINK_GLUE_CT=y CONFIG_NF_NAT=m CONFIG_NF_NAT_NEEDED=y -CONFIG_NF_NAT_PROTO_DCCP=m -CONFIG_NF_NAT_PROTO_UDPLITE=m -CONFIG_NF_NAT_PROTO_SCTP=m +CONFIG_NF_NAT_PROTO_DCCP=y +CONFIG_NF_NAT_PROTO_UDPLITE=y +CONFIG_NF_NAT_PROTO_SCTP=y CONFIG_NF_NAT_AMANDA=m CONFIG_NF_NAT_FTP=m CONFIG_NF_NAT_IRC=m @@ -875,6 +880,7 @@ CONFIG_NF_TABLES_INET=m CONFIG_NF_TABLES_NETDEV=m CONFIG_NFT_EXTHDR=m CONFIG_NFT_META=m +# CONFIG_NFT_RT is not set # CONFIG_NFT_NUMGEN is not set CONFIG_NFT_CT=m CONFIG_NFT_SET_RBTREE=m @@ -885,6 +891,7 @@ CONFIG_NFT_LIMIT=m CONFIG_NFT_MASQ=m CONFIG_NFT_REDIR=m CONFIG_NFT_NAT=m +# CONFIG_NFT_OBJREF is not set CONFIG_NFT_QUEUE=m # CONFIG_NFT_QUOTA is not set CONFIG_NFT_REJECT=m @@ -975,7 +982,6 @@ CONFIG_NETFILTER_XT_MATCH_RATEEST=m CONFIG_NETFILTER_XT_MATCH_REALM=m CONFIG_NETFILTER_XT_MATCH_RECENT=m CONFIG_NETFILTER_XT_MATCH_SCTP=m -CONFIG_NETFILTER_XT_MATCH_SOCKET=m CONFIG_NETFILTER_XT_MATCH_STATE=m CONFIG_NETFILTER_XT_MATCH_STATISTIC=m CONFIG_NETFILTER_XT_MATCH_STRING=m @@ -992,6 +998,7 @@ CONFIG_IP_SET_HASH_IPMARK=m CONFIG_IP_SET_HASH_IPPORT=m CONFIG_IP_SET_HASH_IPPORTIP=m CONFIG_IP_SET_HASH_IPPORTNET=m +# CONFIG_IP_SET_HASH_IPMAC is not set CONFIG_IP_SET_HASH_MAC=m CONFIG_IP_SET_HASH_NETPORTNET=m CONFIG_IP_SET_HASH_NET=m @@ -1047,10 +1054,12 @@ CONFIG_IP_VS_PE_SIP=m # CONFIG_NF_DEFRAG_IPV4=m CONFIG_NF_CONNTRACK_IPV4=m +# CONFIG_NF_SOCKET_IPV4 is not set CONFIG_NF_TABLES_IPV4=m CONFIG_NFT_CHAIN_ROUTE_IPV4=m CONFIG_NFT_REJECT_IPV4=m CONFIG_NFT_DUP_IPV4=m +# CONFIG_NFT_FIB_IPV4 is not set CONFIG_NF_TABLES_ARP=m CONFIG_NF_DUP_IPV4=m CONFIG_NF_LOG_ARP=m @@ -1092,10 +1101,12 @@ CONFIG_IP_NF_ARP_MANGLE=m # CONFIG_NF_DEFRAG_IPV6=m CONFIG_NF_CONNTRACK_IPV6=m +# CONFIG_NF_SOCKET_IPV6 is not set CONFIG_NF_TABLES_IPV6=m CONFIG_NFT_CHAIN_ROUTE_IPV6=m CONFIG_NFT_REJECT_IPV6=m CONFIG_NFT_DUP_IPV6=m +# CONFIG_NFT_FIB_IPV6 is not set CONFIG_NF_DUP_IPV6=m CONFIG_NF_REJECT_IPV6=m CONFIG_NF_LOG_IPV6=m @@ -1547,6 +1558,7 @@ CONFIG_NFC_MICROREAD_I2C=m # CONFIG_NFC_S3FWRN5_I2C is not set # CONFIG_NFC_ST95HF is not set CONFIG_LWTUNNEL=y +CONFIG_LWTUNNEL_BPF=y CONFIG_DST_CACHE=y # CONFIG_NET_DEVLINK is not set CONFIG_MAY_USE_DEVLINK=y @@ -1577,6 +1589,7 @@ CONFIG_DEV_COREDUMP=y # CONFIG_DEBUG_DRIVER is not set # CONFIG_DEBUG_DEVRES is not set # CONFIG_DEBUG_TEST_DRIVER_REMOVE is not set +# CONFIG_TEST_ASYNC_DRIVER_PROBE is not set # CONFIG_SYS_HYPERVISOR is not set # CONFIG_GENERIC_CPU_DEVICES is not set CONFIG_SOC_BUS=y @@ -1586,7 +1599,7 @@ CONFIG_REGMAP_SPI=y CONFIG_REGMAP_MMIO=y CONFIG_REGMAP_IRQ=y CONFIG_DMA_SHARED_BUFFER=y -# CONFIG_FENCE_TRACE is not set +# CONFIG_DMA_FENCE_TRACE is not set CONFIG_DMA_CMA=y # @@ -1698,6 +1711,7 @@ CONFIG_MTD_NAND_IDS=y CONFIG_MTD_NAND_NANDSIM=m # CONFIG_MTD_NAND_BRCMNAND is not set # CONFIG_MTD_NAND_PLATFORM is not set +# CONFIG_MTD_NAND_OXNAS is not set # CONFIG_MTD_NAND_HISI504 is not set # CONFIG_MTD_NAND_MTK is not set CONFIG_MTD_ONENAND=y @@ -1757,6 +1771,7 @@ CONFIG_ATA_OVER_ETH=m # CONFIG_MG_DISK is not set CONFIG_VIRTIO_BLK=m CONFIG_BLK_DEV_RBD=m +# CONFIG_NVME_FC is not set # CONFIG_NVME_TARGET is not set # @@ -1959,7 +1974,7 @@ CONFIG_BLK_DEV_DM=m # CONFIG_DM_MQ_DEFAULT is not set # CONFIG_DM_DEBUG is not set CONFIG_DM_BUFIO=m -# CONFIG_DM_DEBUG_BLOCK_STACK_TRACING is not set +# CONFIG_DM_DEBUG_BLOCK_MANAGER_LOCKING is not set CONFIG_DM_BIO_PRISON=m CONFIG_DM_PERSISTENT_DATA=m CONFIG_DM_CRYPT=m @@ -2043,6 +2058,7 @@ CONFIG_NET_DSA_MV88E6XXX=m CONFIG_NET_DSA_MV88E6XXX_GLOBAL2=y # CONFIG_NET_DSA_QCA8K is not set CONFIG_ETHERNET=y +CONFIG_NET_VENDOR_ALACRITECH=y # CONFIG_ALTERA_TSE is not set CONFIG_NET_VENDOR_AMAZON=y # CONFIG_NET_VENDOR_ARC is not set @@ -2095,6 +2111,7 @@ CONFIG_NET_VENDOR_ROCKER=y CONFIG_NET_VENDOR_SAMSUNG=y # CONFIG_SXGBE_ETH is not set CONFIG_NET_VENDOR_SEEQ=y +CONFIG_NET_VENDOR_SOLARFLARE=y CONFIG_NET_VENDOR_SMSC=y CONFIG_SMC91X=m CONFIG_SMC911X=m @@ -2119,6 +2136,7 @@ CONFIG_NET_VENDOR_WIZNET=y # CONFIG_WIZNET_W5300 is not set CONFIG_PHYLIB=y CONFIG_SWPHY=y +# CONFIG_LED_TRIGGER_PHY is not set # # MDIO bus device drivers @@ -2149,6 +2167,7 @@ CONFIG_ICPLUS_PHY=m CONFIG_LSI_ET1011C_PHY=m CONFIG_LXT_PHY=m CONFIG_MARVELL_PHY=m +# CONFIG_MESON_GXL_PHY is not set CONFIG_MICREL_PHY=y CONFIG_MICROCHIP_PHY=m CONFIG_MICROSEMI_PHY=y @@ -2223,6 +2242,7 @@ CONFIG_USB_SIERRA_NET=m CONFIG_USB_VL600=m CONFIG_USB_NET_CH9200=m CONFIG_WLAN=y +# CONFIG_WIRELESS_WDS is not set CONFIG_WLAN_VENDOR_ADMTEK=y CONFIG_ATH_COMMON=m CONFIG_WLAN_VENDOR_ATH=y @@ -2718,7 +2738,6 @@ CONFIG_CONSOLE_POLL=y # CONFIG_SERIAL_FSL_LPUART is not set # CONFIG_SERIAL_CONEXANT_DIGICOLOR is not set # CONFIG_SERIAL_ST_ASC is not set -# CONFIG_SERIAL_STM32 is not set CONFIG_TTY_PRINTK=m CONFIG_HVC_DRIVER=y # CONFIG_HVC_DCC is not set @@ -2733,6 +2752,7 @@ CONFIG_HW_RANDOM_TPM=m # CONFIG_R3964 is not set # CONFIG_RAW_DRIVER is not set CONFIG_TCG_TPM=m +# CONFIG_TCG_TIS is not set # CONFIG_TCG_TIS_SPI is not set CONFIG_TCG_TIS_I2C_ATMEL=m # CONFIG_TCG_TIS_I2C_INFINEON is not set @@ -2762,6 +2782,7 @@ CONFIG_I2C_MUX_PCA954x=m CONFIG_I2C_MUX_PINCTRL=y # CONFIG_I2C_MUX_REG is not set # CONFIG_I2C_DEMUX_PINCTRL is not set +# CONFIG_I2C_MUX_MLXCPLD is not set CONFIG_I2C_HELPER_AUTO=y CONFIG_I2C_ALGOBIT=y CONFIG_I2C_ALGOPCA=m @@ -2886,6 +2907,7 @@ CONFIG_GENERIC_PINCONF=y CONFIG_PINCTRL_AS3722=y # CONFIG_PINCTRL_AMD is not set CONFIG_PINCTRL_SINGLE=y +CONFIG_PINCTRL_SX150X=y CONFIG_PINCTRL_TI_IODELAY=y CONFIG_PINCTRL_PALMAS=y CONFIG_ARCH_HAVE_CUSTOM_GPIO_H=y @@ -2905,7 +2927,6 @@ CONFIG_GPIO_MAX730X=m # CONFIG_GPIO_ALTERA is not set CONFIG_GPIO_AXP209=y # CONFIG_GPIO_DWAPB is not set -# CONFIG_GPIO_EM is not set CONFIG_GPIO_GENERIC_PLATFORM=y # CONFIG_GPIO_GRGPIO is not set # CONFIG_GPIO_MOCKUP is not set @@ -2914,7 +2935,6 @@ CONFIG_GPIO_OMAP=y CONFIG_GPIO_SYSCON=y CONFIG_GPIO_XILINX=y # CONFIG_GPIO_ZEVIO is not set -# CONFIG_GPIO_ZX is not set # # I2C GPIO expanders @@ -2928,7 +2948,6 @@ CONFIG_GPIO_PCA953X_IRQ=y CONFIG_GPIO_PCF857X=m CONFIG_GPIO_SX150X=y CONFIG_GPIO_TPIC2810=m -# CONFIG_GPIO_TS4900 is not set # # MFD GPIO expanders @@ -3111,6 +3130,7 @@ CONFIG_SENSORS_MAX6650=m CONFIG_SENSORS_MAX6697=m CONFIG_SENSORS_MAX31790=m CONFIG_SENSORS_MCP3021=m +# CONFIG_SENSORS_TC654 is not set CONFIG_SENSORS_ADCXX=m CONFIG_SENSORS_LM63=m CONFIG_SENSORS_LM70=m @@ -3179,6 +3199,7 @@ CONFIG_SENSORS_TC74=m CONFIG_SENSORS_THMC50=m CONFIG_SENSORS_TMP102=m CONFIG_SENSORS_TMP103=m +# CONFIG_SENSORS_TMP108 is not set CONFIG_SENSORS_TMP401=m CONFIG_SENSORS_TMP421=m CONFIG_SENSORS_TWL4030_MADC=m @@ -3305,7 +3326,6 @@ CONFIG_MFD_DA9055=y CONFIG_MFD_DA9063=y # CONFIG_MFD_DA9150 is not set CONFIG_MFD_DLN2=y -# CONFIG_MFD_EXYNOS_LPASS is not set CONFIG_MFD_MC13XXX=m CONFIG_MFD_MC13XXX_SPI=m CONFIG_MFD_MC13XXX_I2C=m @@ -3333,7 +3353,7 @@ CONFIG_MFD_VIPERBOARD=m # CONFIG_MFD_RETU is not set # CONFIG_MFD_PCF50633 is not set # CONFIG_UCB1400_CORE is not set -# CONFIG_MFD_PM8921_CORE is not set +# CONFIG_MFD_PM8XXX is not set # CONFIG_MFD_RT5033 is not set CONFIG_MFD_RTSX_USB=m # CONFIG_MFD_RC5T583 is not set @@ -3459,6 +3479,7 @@ CONFIG_MEDIA_DIGITAL_TV_SUPPORT=y CONFIG_MEDIA_RADIO_SUPPORT=y CONFIG_MEDIA_SDR_SUPPORT=y CONFIG_MEDIA_RC_SUPPORT=y +# CONFIG_MEDIA_CEC_SUPPORT is not set CONFIG_MEDIA_CEC_EDID=y CONFIG_MEDIA_CONTROLLER=y # CONFIG_MEDIA_CONTROLLER_DVB is not set @@ -3482,6 +3503,7 @@ CONFIG_DVB_NET=y CONFIG_TTPCI_EEPROM=m CONFIG_DVB_MAX_ADAPTERS=8 CONFIG_DVB_DYNAMIC_MINORS=y +# CONFIG_DVB_DEMUX_SECTION_LOSS_LOG is not set # # Media drivers @@ -3513,6 +3535,7 @@ CONFIG_IR_TTUSBIR=m # CONFIG_IR_RX51 is not set CONFIG_RC_LOOPBACK=m CONFIG_IR_GPIO_CIR=m +# CONFIG_IR_SERIAL is not set CONFIG_MEDIA_USB_SUPPORT=y # @@ -3975,9 +3998,11 @@ CONFIG_DVB_AF9033=m # # Graphics support # +# CONFIG_IMX_IPUV3_CORE is not set CONFIG_DRM=y CONFIG_DRM_MIPI_DSI=y # CONFIG_DRM_DP_AUX_CHARDEV is not set +# CONFIG_DRM_DEBUG_MM is not set CONFIG_DRM_KMS_HELPER=y CONFIG_DRM_KMS_FB_HELPER=y CONFIG_DRM_FBDEV_EMULATION=y @@ -4017,13 +4042,17 @@ CONFIG_DRM_BRIDGE=y # CONFIG_DRM_DUMB_VGA_DAC is not set # CONFIG_DRM_NXP_PTN3460 is not set # CONFIG_DRM_PARADE_PS8622 is not set +# CONFIG_DRM_SIL_SII8620 is not set # CONFIG_DRM_SII902X is not set # CONFIG_DRM_TOSHIBA_TC358767 is not set +# CONFIG_DRM_TI_TFP410 is not set CONFIG_DRM_I2C_ADV7511=m +# CONFIG_DRM_I2C_ADV7511_AUDIO is not set CONFIG_DRM_I2C_ADV7533=y # CONFIG_DRM_STI is not set # CONFIG_DRM_ETNAVIV is not set # CONFIG_DRM_ARCPGU is not set +# CONFIG_DRM_MXSFB is not set # CONFIG_DRM_LEGACY is not set CONFIG_DRM_TINYDRM=y CONFIG_TINYDRM_MIPI_DBI=m @@ -4216,6 +4245,8 @@ CONFIG_SND_SOC_I2C_AND_SPI=m # CONFIG_SND_SOC_BT_SCO is not set # CONFIG_SND_SOC_CS35L32 is not set # CONFIG_SND_SOC_CS35L33 is not set +# CONFIG_SND_SOC_CS35L34 is not set +# CONFIG_SND_SOC_CS42L42 is not set # CONFIG_SND_SOC_CS42L51_I2C is not set # CONFIG_SND_SOC_CS42L52 is not set # CONFIG_SND_SOC_CS42L56 is not set @@ -4233,6 +4264,7 @@ CONFIG_SND_SOC_ES8328=m # CONFIG_SND_SOC_INNO_RK3036 is not set # CONFIG_SND_SOC_MAX98504 is not set # CONFIG_SND_SOC_MAX9860 is not set +# CONFIG_SND_SOC_MSM8916_WCD_DIGITAL is not set # CONFIG_SND_SOC_PCM1681 is not set # CONFIG_SND_SOC_PCM179X_I2C is not set # CONFIG_SND_SOC_PCM179X_SPI is not set @@ -4350,6 +4382,7 @@ CONFIG_LOGIRUMBLEPAD2_FF=y CONFIG_LOGIG940_FF=y CONFIG_LOGIWHEELS_FF=y CONFIG_HID_MAGICMOUSE=m +# CONFIG_HID_MAYFLASH is not set CONFIG_HID_MICROSOFT=m CONFIG_HID_MONTEREY=m CONFIG_HID_MULTITOUCH=m @@ -4384,6 +4417,7 @@ CONFIG_HID_TOPSEED=m CONFIG_HID_THINGM=m CONFIG_HID_THRUSTMASTER=m CONFIG_THRUSTMASTER_FF=y +# CONFIG_HID_UDRAW_PS3 is not set CONFIG_HID_WACOM=m CONFIG_HID_WIIMOTE=m CONFIG_HID_XINMO=m @@ -4562,6 +4596,7 @@ CONFIG_USB_SERIAL_IR=m CONFIG_USB_SERIAL_EDGEPORT=m CONFIG_USB_SERIAL_EDGEPORT_TI=m CONFIG_USB_SERIAL_F81232=m +# CONFIG_USB_SERIAL_F8153X is not set CONFIG_USB_SERIAL_GARMIN=m CONFIG_USB_SERIAL_IPW=m CONFIG_USB_SERIAL_IUU=m @@ -4749,10 +4784,6 @@ CONFIG_MMC=y # CONFIG_MMC_DEBUG is not set CONFIG_PWRSEQ_EMMC=y CONFIG_PWRSEQ_SIMPLE=y - -# -# MMC/SD/SDIO Card Drivers -# CONFIG_MMC_BLOCK=y CONFIG_MMC_BLOCK_MINORS=8 CONFIG_MMC_BLOCK_BOUNCE=y @@ -4766,6 +4797,7 @@ CONFIG_MMC_SDHCI=y CONFIG_MMC_SDHCI_PLTFM=y CONFIG_MMC_SDHCI_OF_ARASAN=y # CONFIG_MMC_SDHCI_OF_AT91 is not set +# CONFIG_MMC_SDHCI_CADENCE is not set # CONFIG_MMC_SDHCI_F_SDH30 is not set CONFIG_MMC_OMAP=m CONFIG_MMC_OMAP_HS=y @@ -4833,6 +4865,7 @@ CONFIG_LEDS_IS31FL32XX=m # # CONFIG_LEDS_BLINKM is not set # CONFIG_LEDS_SYSCON is not set +# CONFIG_LEDS_USER is not set # # LED Triggers @@ -4980,6 +5013,7 @@ CONFIG_RTC_DRV_ZYNQMP=m CONFIG_RTC_DRV_OMAP=y CONFIG_RTC_DRV_MC13XXX=m CONFIG_RTC_DRV_SNVS=y +# CONFIG_RTC_DRV_R7301 is not set # # HID Sensor RTC drivers @@ -5015,7 +5049,8 @@ CONFIG_ASYNC_TX_DMA=y # # DMABUF options # -# CONFIG_SYNC_FILE is not set +CONFIG_SYNC_FILE=y +# CONFIG_SW_SYNC is not set # CONFIG_AUXDISPLAY is not set CONFIG_UIO=m CONFIG_UIO_PDRV_GENIRQ=m @@ -5059,7 +5094,6 @@ CONFIG_ADIS16201=m CONFIG_ADIS16203=m CONFIG_ADIS16209=m CONFIG_ADIS16240=m -CONFIG_SCA3000=m # # Analog to digital converters @@ -5105,9 +5139,7 @@ CONFIG_AD5933=m # # Light sensors # -CONFIG_SENSORS_ISL29018=m CONFIG_SENSORS_ISL29028=m -CONFIG_TSL2583=m # CONFIG_TSL2x7x is not set # @@ -5251,6 +5283,13 @@ CONFIG_COMMON_CLK_PALMAS=y # CONFIG_COMMON_CLK_PWM is not set # CONFIG_COMMON_CLK_PXA is not set # CONFIG_COMMON_CLK_PIC32 is not set +# CONFIG_COMMON_CLK_MT2701 is not set +# CONFIG_COMMON_CLK_MT2701_MMSYS is not set +# CONFIG_COMMON_CLK_MT2701_IMGSYS is not set +# CONFIG_COMMON_CLK_MT2701_VDECSYS is not set +# CONFIG_COMMON_CLK_MT2701_HIFSYS is not set +# CONFIG_COMMON_CLK_MT2701_ETHSYS is not set +# CONFIG_COMMON_CLK_MT2701_BDPSYS is not set CONFIG_COMMON_CLK_TI_ADPLL=y CONFIG_HWSPINLOCK=y @@ -5300,7 +5339,6 @@ CONFIG_ARM_SMMU=y # Remoteproc drivers # CONFIG_REMOTEPROC=y -# CONFIG_STE_MODEM_RPROC is not set CONFIG_WKUP_M3_RPROC=y # @@ -5371,8 +5409,11 @@ CONFIG_BMA220=m CONFIG_BMC150_ACCEL=m CONFIG_BMC150_ACCEL_I2C=m CONFIG_BMC150_ACCEL_SPI=m +# CONFIG_DA280 is not set +# CONFIG_DA311 is not set CONFIG_DMARD06=m CONFIG_DMARD09=m +# CONFIG_DMARD10 is not set CONFIG_HID_SENSOR_ACCEL_3D=m CONFIG_IIO_ST_ACCEL_3AXIS=m CONFIG_IIO_ST_ACCEL_I2C_3AXIS=m @@ -5392,6 +5433,7 @@ CONFIG_MMA9551=m CONFIG_MMA9553=m CONFIG_MXC4005=m CONFIG_MXC6255=m +CONFIG_SCA3000=m CONFIG_STK8312=m CONFIG_STK8BA50=m @@ -5403,6 +5445,7 @@ CONFIG_AD7266=m CONFIG_AD7291=m CONFIG_AD7298=m CONFIG_AD7476=m +# CONFIG_AD7766 is not set CONFIG_AD7791=m CONFIG_AD7793=m CONFIG_AD7887=m @@ -5410,6 +5453,7 @@ CONFIG_AD7923=m CONFIG_AD799X=m CONFIG_AXP288_ADC=m CONFIG_CC10001_ADC=m +# CONFIG_ENVELOPE_DETECTOR is not set CONFIG_HI8435=m CONFIG_INA2XX_ADC=m CONFIG_LTC2485=m @@ -5443,6 +5487,7 @@ CONFIG_AD8366=m CONFIG_ATLAS_PH_SENSOR=m CONFIG_IAQCORE=m CONFIG_VZ89X=m +# CONFIG_IIO_CROS_EC_SENSORS_CORE is not set # # Hid Sensor IIO Common @@ -5460,6 +5505,10 @@ CONFIG_IIO_ST_SENSORS_I2C=m CONFIG_IIO_ST_SENSORS_SPI=m CONFIG_IIO_ST_SENSORS_CORE=m +# +# Counters +# + # # Digital to analog converters # @@ -5481,6 +5530,7 @@ CONFIG_AD5764=m CONFIG_AD5791=m CONFIG_AD7303=m CONFIG_AD8801=m +# CONFIG_DPOT_DAC is not set CONFIG_M62332=m CONFIG_MAX517=m CONFIG_MAX5821=m @@ -5540,6 +5590,7 @@ CONFIG_MAX30100=m CONFIG_AM2315=m CONFIG_DHT11=m CONFIG_HDC100X=m +# CONFIG_HTS221 is not set CONFIG_HTU21=m CONFIG_SI7005=m CONFIG_SI7020=m @@ -5573,6 +5624,7 @@ CONFIG_CM3232=m CONFIG_CM3323=m CONFIG_CM36651=m CONFIG_GP2AP020A00F=m +CONFIG_SENSORS_ISL29018=m CONFIG_ISL29125=m CONFIG_HID_SENSOR_ALS=m CONFIG_HID_SENSOR_PROX=m @@ -5587,6 +5639,7 @@ CONFIG_STK3310=m CONFIG_TCS3414=m CONFIG_TCS3472=m CONFIG_SENSORS_TSL2563=m +CONFIG_TSL2583=m CONFIG_TSL4531=m CONFIG_US5182D=m CONFIG_VCNL4000=m @@ -5632,9 +5685,15 @@ CONFIG_MCP4131=m CONFIG_MCP4531=m CONFIG_TPL0102=m +# +# Digital potentiostats +# +# CONFIG_LMP91000 is not set + # # Pressure sensors # +# CONFIG_ABP060MG is not set CONFIG_BMP280=m CONFIG_BMP280_I2C=m CONFIG_BMP280_SPI=m @@ -5743,6 +5802,10 @@ CONFIG_ARM_PSCI_FW=y # CONFIG_FW_CFG_SYSFS is not set CONFIG_HAVE_ARM_SMCCC=y +# +# Tegra firmware driver +# + # # File systems # @@ -5824,6 +5887,7 @@ CONFIG_AUTOFS4_FS=y CONFIG_FUSE_FS=y CONFIG_CUSE=m CONFIG_OVERLAY_FS=y +# CONFIG_OVERLAY_FS_REDIRECT_DIR is not set # # Caches @@ -5909,7 +5973,7 @@ CONFIG_UBIFS_FS_ADVANCED_COMPR=y CONFIG_UBIFS_FS_LZO=y CONFIG_UBIFS_FS_ZLIB=y # CONFIG_UBIFS_ATIME_SUPPORT is not set -# CONFIG_LOGFS is not set +# CONFIG_UBIFS_FS_ENCRYPTION is not set # CONFIG_CRAMFS is not set CONFIG_SQUASHFS=m CONFIG_SQUASHFS_FILE_CACHE=y @@ -6083,6 +6147,7 @@ CONFIG_DLM_DEBUG=y # printk and dmesg options # CONFIG_PRINTK_TIME=y +CONFIG_CONSOLE_LOGLEVEL_DEFAULT=7 CONFIG_MESSAGE_LOGLEVEL_DEFAULT=4 CONFIG_BOOT_PRINTK_DELAY=y CONFIG_DYNAMIC_DEBUG=y @@ -6254,6 +6319,7 @@ CONFIG_TEST_FIRMWARE=m # CONFIG_TEST_UDELAY is not set # CONFIG_MEMTEST is not set CONFIG_TEST_STATIC_KEYS=m +# CONFIG_BUG_ON_DATA_CORRUPTION is not set # CONFIG_SAMPLES is not set CONFIG_HAVE_ARCH_KGDB=y CONFIG_KGDB=y @@ -6352,6 +6418,7 @@ CONFIG_CRYPTO_RNG_DEFAULT=y CONFIG_CRYPTO_AKCIPHER2=y CONFIG_CRYPTO_AKCIPHER=y CONFIG_CRYPTO_KPP2=y +CONFIG_CRYPTO_ACOMP2=y CONFIG_CRYPTO_RSA=y # CONFIG_CRYPTO_DH is not set # CONFIG_CRYPTO_ECDH is not set @@ -6367,7 +6434,7 @@ CONFIG_CRYPTO_CRYPTD=m # CONFIG_CRYPTO_MCRYPTD is not set CONFIG_CRYPTO_AUTHENC=m CONFIG_CRYPTO_TEST=m -CONFIG_CRYPTO_ABLK_HELPER=m +CONFIG_CRYPTO_SIMD=m CONFIG_CRYPTO_ENGINE=m # @@ -6470,9 +6537,11 @@ CONFIG_CRYPTO_USER_API_SKCIPHER=m CONFIG_CRYPTO_USER_API_AEAD=m CONFIG_CRYPTO_HASH_INFO=y CONFIG_CRYPTO_HW=y +# CONFIG_CRYPTO_DEV_FSL_CAAM_CRYPTO_API_DESC is not set CONFIG_CRYPTO_DEV_OMAP_SHAM=m CONFIG_CRYPTO_DEV_OMAP_AES=m CONFIG_CRYPTO_DEV_OMAP_DES=m +CONFIG_CRYPTO_DEV_VIRTIO=m CONFIG_ASYMMETRIC_KEY_TYPE=y CONFIG_ASYMMETRIC_PUBLIC_KEY_SUBTYPE=y CONFIG_X509_CERTIFICATE_PARSER=y @@ -6493,6 +6562,8 @@ CONFIG_CRYPTO_AES_ARM=m CONFIG_CRYPTO_AES_ARM_BS=m # CONFIG_CRYPTO_AES_ARM_CE is not set # CONFIG_CRYPTO_GHASH_ARM_CE is not set +# CONFIG_CRYPTO_CRCT10DIF_ARM_CE is not set +# CONFIG_CRYPTO_CRC32_ARM_CE is not set CONFIG_BINARY_PRINTF=y # diff --git a/patches/drivers/pm_opp/0001-PM-OPP-Fix-incorrect-cpu-supply-property-in-binding.patch b/patches/drivers/pm_opp/0001-PM-OPP-Fix-incorrect-cpu-supply-property-in-binding.patch deleted file mode 100644 index 3194af2357d34ea1b8191f792905baa0d75f1e56..0000000000000000000000000000000000000000 --- a/patches/drivers/pm_opp/0001-PM-OPP-Fix-incorrect-cpu-supply-property-in-binding.patch +++ /dev/null @@ -1,42 +0,0 @@ -From cfa7e2dcfac1ff1a785bf6f667a0553a4c931452 Mon Sep 17 00:00:00 2001 -From: Viresh Kumar <viresh.kumar@linaro.org> -Date: Tue, 29 Nov 2016 12:06:48 +0530 -Subject: [PATCH 01/10] PM / OPP: Fix incorrect cpu-supply property in binding - -The regulator bindings allow the "<name>-supply" property to define a -single parent supply and not a list of parents. - -Fix the wrong example code present in OPP bindings. - -While at it also change the compatible string as Rob pointed out earlier -that none of A7 implementation have multiple supplies for the CPU core. - -Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org> -Acked-by: Rob Herring <robh@kernel.org> -Reviewed-by: Stephen Boyd <sboyd@codeaurora.org> ---- - Documentation/devicetree/bindings/opp/opp.txt | 6 ++++-- - 1 file changed, 4 insertions(+), 2 deletions(-) - -diff --git a/Documentation/devicetree/bindings/opp/opp.txt b/Documentation/devicetree/bindings/opp/opp.txt -index ee91cbd..f0239f6 100644 ---- a/Documentation/devicetree/bindings/opp/opp.txt -+++ b/Documentation/devicetree/bindings/opp/opp.txt -@@ -386,10 +386,12 @@ Example 4: Handling multiple regulators - / { - cpus { - cpu@0 { -- compatible = "arm,cortex-a7"; -+ compatible = "vendor,cpu-type"; - ... - -- cpu-supply = <&cpu_supply0>, <&cpu_supply1>, <&cpu_supply2>; -+ vcc0-supply = <&cpu_supply0>; -+ vcc1-supply = <&cpu_supply1>; -+ vcc2-supply = <&cpu_supply2>; - operating-points-v2 = <&cpu0_opp_table>; - }; - }; --- -2.10.2 - diff --git a/patches/drivers/pm_opp/0002-PM-OPP-Reword-binding-supporting-multiple-regulators.patch b/patches/drivers/pm_opp/0002-PM-OPP-Reword-binding-supporting-multiple-regulators.patch deleted file mode 100644 index 0f074807b912b760163ab3f89c27bac6915cafba..0000000000000000000000000000000000000000 --- a/patches/drivers/pm_opp/0002-PM-OPP-Reword-binding-supporting-multiple-regulators.patch +++ /dev/null @@ -1,74 +0,0 @@ -From bf6abad728eb4b0d749aeb0f461e3e6090356abf Mon Sep 17 00:00:00 2001 -From: Viresh Kumar <viresh.kumar@linaro.org> -Date: Tue, 29 Nov 2016 12:06:49 +0530 -Subject: [PATCH 02/10] PM / OPP: Reword binding supporting multiple regulators - per device - -On certain platforms (like TI), DVFS for a single device (CPU) requires -configuring multiple power supplies. - -The OPP bindings already contains binding and example to explain this -case, but it isn't sufficient. - -- There is no way for the code parsing these bindings to know which - voltage values belong to which power supply. - -- It is not possible to know the order in which the supplies need to be - configured while switching OPPs. - -This patch clarifies on those details by mentioning that such -information is left for the implementation specific bindings to explain. -They may want to hardcode such details or implement their own properties -to get such information. All implementations using multiple regulators -for their devices must provide a binding document explaining their -implementation. - -Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org> -Acked-by: Rob Herring <robh@kernel.org> -Reviewed-by: Stephen Boyd <sboyd@codeaurora.org> ---- - Documentation/devicetree/bindings/opp/opp.txt | 21 +++++++++++++++------ - 1 file changed, 15 insertions(+), 6 deletions(-) - -diff --git a/Documentation/devicetree/bindings/opp/opp.txt b/Documentation/devicetree/bindings/opp/opp.txt -index f0239f6..9f5ca44 100644 ---- a/Documentation/devicetree/bindings/opp/opp.txt -+++ b/Documentation/devicetree/bindings/opp/opp.txt -@@ -86,8 +86,14 @@ Optional properties: - Single entry is for target voltage and three entries are for <target min max> - voltages. - -- Entries for multiple regulators must be present in the same order as -- regulators are specified in device's DT node. -+ Entries for multiple regulators shall be provided in the same field separated -+ by angular brackets <>. The OPP binding doesn't provide any provisions to -+ relate the values to their power supplies or the order in which the supplies -+ need to be configured and that is left for the implementation specific -+ binding. -+ -+ Entries for all regulators shall be of the same size, i.e. either all use a -+ single value or triplets. - - - opp-microvolt-<name>: Named opp-microvolt property. This is exactly similar to - the above opp-microvolt property, but allows multiple voltage ranges to be -@@ -104,10 +110,13 @@ Optional properties: - - Should only be set if opp-microvolt is set for the OPP. - -- Entries for multiple regulators must be present in the same order as -- regulators are specified in device's DT node. If this property isn't required -- for few regulators, then this should be marked as zero for them. If it isn't -- required for any regulator, then this property need not be present. -+ Entries for multiple regulators shall be provided in the same field separated -+ by angular brackets <>. If current values aren't required for a regulator, -+ then it shall be filled with 0. If current values aren't required for any of -+ the regulators, then this field is not required. The OPP binding doesn't -+ provide any provisions to relate the values to their power supplies or the -+ order in which the supplies need to be configured and that is left for the -+ implementation specific binding. - - - opp-microamp-<name>: Named opp-microamp property. Similar to - opp-microvolt-<name> property, but for microamp instead. --- -2.10.2 - diff --git a/patches/drivers/pm_opp/0003-PM-OPP-Don-t-use-OPP-structure-outside-of-rcu-protec.patch b/patches/drivers/pm_opp/0003-PM-OPP-Don-t-use-OPP-structure-outside-of-rcu-protec.patch deleted file mode 100644 index cc1de26cb2f2f53a40d98a683d878fb289882866..0000000000000000000000000000000000000000 --- a/patches/drivers/pm_opp/0003-PM-OPP-Don-t-use-OPP-structure-outside-of-rcu-protec.patch +++ /dev/null @@ -1,61 +0,0 @@ -From e80c8ca60e39cdac162edb13e739eca38c2fff2c Mon Sep 17 00:00:00 2001 -From: Viresh Kumar <viresh.kumar@linaro.org> -Date: Tue, 29 Nov 2016 12:06:50 +0530 -Subject: [PATCH 03/10] PM / OPP: Don't use OPP structure outside of rcu - protected section - -The OPP structure must not be used out of the rcu protected section. -Cache the values to be used in separate variables instead. - -Cc: # v4.6+ <stable@vger.kernel.org> -Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org> -Reviewed-by: Stephen Boyd <sboyd@codeaurora.org> -Tested-by: Dave Gerlach <d-gerlach@ti.com> ---- - drivers/base/power/opp/core.c | 16 +++++++++++++--- - 1 file changed, 13 insertions(+), 3 deletions(-) - -diff --git a/drivers/base/power/opp/core.c b/drivers/base/power/opp/core.c -index 4c7c6da..056527a 100644 ---- a/drivers/base/power/opp/core.c -+++ b/drivers/base/power/opp/core.c -@@ -584,6 +584,7 @@ int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq) - struct clk *clk; - unsigned long freq, old_freq; - unsigned long u_volt, u_volt_min, u_volt_max; -+ unsigned long old_u_volt, old_u_volt_min, old_u_volt_max; - int ret; - - if (unlikely(!target_freq)) { -@@ -633,6 +634,14 @@ int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq) - return ret; - } - -+ if (IS_ERR(old_opp)) { -+ old_u_volt = 0; -+ } else { -+ old_u_volt = old_opp->u_volt; -+ old_u_volt_min = old_opp->u_volt_min; -+ old_u_volt_max = old_opp->u_volt_max; -+ } -+ - u_volt = opp->u_volt; - u_volt_min = opp->u_volt_min; - u_volt_max = opp->u_volt_max; -@@ -677,9 +686,10 @@ int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq) - __func__, old_freq); - restore_voltage: - /* This shouldn't harm even if the voltages weren't updated earlier */ -- if (!IS_ERR(old_opp)) -- _set_opp_voltage(dev, reg, old_opp->u_volt, -- old_opp->u_volt_min, old_opp->u_volt_max); -+ if (old_u_volt) { -+ _set_opp_voltage(dev, reg, old_u_volt, old_u_volt_min, -+ old_u_volt_max); -+ } - - return ret; - } --- -2.10.2 - diff --git a/patches/drivers/pm_opp/0004-PM-OPP-Manage-supply-s-voltage-current-in-a-separate.patch b/patches/drivers/pm_opp/0004-PM-OPP-Manage-supply-s-voltage-current-in-a-separate.patch deleted file mode 100644 index 1272041dc99b9b8cff565bd9d8742cd5c1954154..0000000000000000000000000000000000000000 --- a/patches/drivers/pm_opp/0004-PM-OPP-Manage-supply-s-voltage-current-in-a-separate.patch +++ /dev/null @@ -1,244 +0,0 @@ -From 6e9c4404b0545adea2ac88249dcf60297b4ac269 Mon Sep 17 00:00:00 2001 -From: Viresh Kumar <viresh.kumar@linaro.org> -Date: Tue, 29 Nov 2016 12:06:51 +0530 -Subject: [PATCH 04/10] PM / OPP: Manage supply's voltage/current in a separate - structure - -This is a preparatory step for multiple regulator per device support. -Move the voltage/current variables to a new structure. - -Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org> -Tested-by: Dave Gerlach <d-gerlach@ti.com> -Reviewed-by: Stephen Boyd <sboyd@codeaurora.org> ---- - drivers/base/power/opp/core.c | 44 +++++++++++++++++++++------------------- - drivers/base/power/opp/debugfs.c | 8 ++++---- - drivers/base/power/opp/of.c | 18 ++++++++-------- - drivers/base/power/opp/opp.h | 11 +++------- - include/linux/pm_opp.h | 16 +++++++++++++++ - 5 files changed, 55 insertions(+), 42 deletions(-) - -diff --git a/drivers/base/power/opp/core.c b/drivers/base/power/opp/core.c -index 056527a..8d60061 100644 ---- a/drivers/base/power/opp/core.c -+++ b/drivers/base/power/opp/core.c -@@ -112,7 +112,7 @@ unsigned long dev_pm_opp_get_voltage(struct dev_pm_opp *opp) - if (IS_ERR_OR_NULL(tmp_opp)) - pr_err("%s: Invalid parameters\n", __func__); - else -- v = tmp_opp->u_volt; -+ v = tmp_opp->supply.u_volt; - - return v; - } -@@ -246,10 +246,10 @@ unsigned long dev_pm_opp_get_max_volt_latency(struct device *dev) - if (!opp->available) - continue; - -- if (opp->u_volt_min < min_uV) -- min_uV = opp->u_volt_min; -- if (opp->u_volt_max > max_uV) -- max_uV = opp->u_volt_max; -+ if (opp->supply.u_volt_min < min_uV) -+ min_uV = opp->supply.u_volt_min; -+ if (opp->supply.u_volt_max > max_uV) -+ max_uV = opp->supply.u_volt_max; - } - - rcu_read_unlock(); -@@ -637,14 +637,14 @@ int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq) - if (IS_ERR(old_opp)) { - old_u_volt = 0; - } else { -- old_u_volt = old_opp->u_volt; -- old_u_volt_min = old_opp->u_volt_min; -- old_u_volt_max = old_opp->u_volt_max; -+ old_u_volt = old_opp->supply.u_volt; -+ old_u_volt_min = old_opp->supply.u_volt_min; -+ old_u_volt_max = old_opp->supply.u_volt_max; - } - -- u_volt = opp->u_volt; -- u_volt_min = opp->u_volt_min; -- u_volt_max = opp->u_volt_max; -+ u_volt = opp->supply.u_volt; -+ u_volt_min = opp->supply.u_volt_min; -+ u_volt_max = opp->supply.u_volt_max; - - reg = opp_table->regulator; - -@@ -957,10 +957,11 @@ static bool _opp_supported_by_regulators(struct dev_pm_opp *opp, - struct regulator *reg = opp_table->regulator; - - if (!IS_ERR(reg) && -- !regulator_is_supported_voltage(reg, opp->u_volt_min, -- opp->u_volt_max)) { -+ !regulator_is_supported_voltage(reg, opp->supply.u_volt_min, -+ opp->supply.u_volt_max)) { - pr_warn("%s: OPP minuV: %lu maxuV: %lu, not supported by regulator\n", -- __func__, opp->u_volt_min, opp->u_volt_max); -+ __func__, opp->supply.u_volt_min, -+ opp->supply.u_volt_max); - return false; - } - -@@ -993,11 +994,12 @@ int _opp_add(struct device *dev, struct dev_pm_opp *new_opp, - - /* Duplicate OPPs */ - dev_warn(dev, "%s: duplicate OPPs detected. Existing: freq: %lu, volt: %lu, enabled: %d. New: freq: %lu, volt: %lu, enabled: %d\n", -- __func__, opp->rate, opp->u_volt, opp->available, -- new_opp->rate, new_opp->u_volt, new_opp->available); -+ __func__, opp->rate, opp->supply.u_volt, -+ opp->available, new_opp->rate, new_opp->supply.u_volt, -+ new_opp->available); - -- return opp->available && new_opp->u_volt == opp->u_volt ? -- 0 : -EEXIST; -+ return opp->available && -+ new_opp->supply.u_volt == opp->supply.u_volt ? 0 : -EEXIST; - } - - new_opp->opp_table = opp_table; -@@ -1064,9 +1066,9 @@ int _opp_add_v1(struct device *dev, unsigned long freq, long u_volt, - /* populate the opp table */ - new_opp->rate = freq; - tol = u_volt * opp_table->voltage_tolerance_v1 / 100; -- new_opp->u_volt = u_volt; -- new_opp->u_volt_min = u_volt - tol; -- new_opp->u_volt_max = u_volt + tol; -+ new_opp->supply.u_volt = u_volt; -+ new_opp->supply.u_volt_min = u_volt - tol; -+ new_opp->supply.u_volt_max = u_volt + tol; - new_opp->available = true; - new_opp->dynamic = dynamic; - -diff --git a/drivers/base/power/opp/debugfs.c b/drivers/base/power/opp/debugfs.c -index ef1ae6b..c897676 100644 ---- a/drivers/base/power/opp/debugfs.c -+++ b/drivers/base/power/opp/debugfs.c -@@ -63,16 +63,16 @@ int opp_debug_create_one(struct dev_pm_opp *opp, struct opp_table *opp_table) - if (!debugfs_create_ulong("rate_hz", S_IRUGO, d, &opp->rate)) - return -ENOMEM; - -- if (!debugfs_create_ulong("u_volt_target", S_IRUGO, d, &opp->u_volt)) -+ if (!debugfs_create_ulong("u_volt_target", S_IRUGO, d, &opp->supply.u_volt)) - return -ENOMEM; - -- if (!debugfs_create_ulong("u_volt_min", S_IRUGO, d, &opp->u_volt_min)) -+ if (!debugfs_create_ulong("u_volt_min", S_IRUGO, d, &opp->supply.u_volt_min)) - return -ENOMEM; - -- if (!debugfs_create_ulong("u_volt_max", S_IRUGO, d, &opp->u_volt_max)) -+ if (!debugfs_create_ulong("u_volt_max", S_IRUGO, d, &opp->supply.u_volt_max)) - return -ENOMEM; - -- if (!debugfs_create_ulong("u_amp", S_IRUGO, d, &opp->u_amp)) -+ if (!debugfs_create_ulong("u_amp", S_IRUGO, d, &opp->supply.u_amp)) - return -ENOMEM; - - if (!debugfs_create_ulong("clock_latency_ns", S_IRUGO, d, -diff --git a/drivers/base/power/opp/of.c b/drivers/base/power/opp/of.c -index 5552211..b7fcd0a 100644 ---- a/drivers/base/power/opp/of.c -+++ b/drivers/base/power/opp/of.c -@@ -148,14 +148,14 @@ static int opp_parse_supplies(struct dev_pm_opp *opp, struct device *dev, - return -EINVAL; - } - -- opp->u_volt = microvolt[0]; -+ opp->supply.u_volt = microvolt[0]; - - if (count == 1) { -- opp->u_volt_min = opp->u_volt; -- opp->u_volt_max = opp->u_volt; -+ opp->supply.u_volt_min = opp->supply.u_volt; -+ opp->supply.u_volt_max = opp->supply.u_volt; - } else { -- opp->u_volt_min = microvolt[1]; -- opp->u_volt_max = microvolt[2]; -+ opp->supply.u_volt_min = microvolt[1]; -+ opp->supply.u_volt_max = microvolt[2]; - } - - /* Search for "opp-microamp-<name>" */ -@@ -173,7 +173,7 @@ static int opp_parse_supplies(struct dev_pm_opp *opp, struct device *dev, - } - - if (prop && !of_property_read_u32(opp->np, name, &val)) -- opp->u_amp = val; -+ opp->supply.u_amp = val; - - return 0; - } -@@ -303,9 +303,9 @@ static int _opp_add_static_v2(struct device *dev, struct device_node *np) - mutex_unlock(&opp_table_lock); - - pr_debug("%s: turbo:%d rate:%lu uv:%lu uvmin:%lu uvmax:%lu latency:%lu\n", -- __func__, new_opp->turbo, new_opp->rate, new_opp->u_volt, -- new_opp->u_volt_min, new_opp->u_volt_max, -- new_opp->clock_latency_ns); -+ __func__, new_opp->turbo, new_opp->rate, -+ new_opp->supply.u_volt, new_opp->supply.u_volt_min, -+ new_opp->supply.u_volt_max, new_opp->clock_latency_ns); - - /* - * Notify the changes in the availability of the operable -diff --git a/drivers/base/power/opp/opp.h b/drivers/base/power/opp/opp.h -index fabd5ca..7912131 100644 ---- a/drivers/base/power/opp/opp.h -+++ b/drivers/base/power/opp/opp.h -@@ -61,10 +61,7 @@ extern struct list_head opp_tables; - * @turbo: true if turbo (boost) OPP - * @suspend: true if suspend OPP - * @rate: Frequency in hertz -- * @u_volt: Target voltage in microvolts corresponding to this OPP -- * @u_volt_min: Minimum voltage in microvolts corresponding to this OPP -- * @u_volt_max: Maximum voltage in microvolts corresponding to this OPP -- * @u_amp: Maximum current drawn by the device in microamperes -+ * @supply: Power supply voltage/current values - * @clock_latency_ns: Latency (in nanoseconds) of switching to this OPP's - * frequency from any other OPP's frequency. - * @opp_table: points back to the opp_table struct this opp belongs to -@@ -83,10 +80,8 @@ struct dev_pm_opp { - bool suspend; - unsigned long rate; - -- unsigned long u_volt; -- unsigned long u_volt_min; -- unsigned long u_volt_max; -- unsigned long u_amp; -+ struct dev_pm_opp_supply supply; -+ - unsigned long clock_latency_ns; - - struct opp_table *opp_table; -diff --git a/include/linux/pm_opp.h b/include/linux/pm_opp.h -index bca2615..f69126e 100644 ---- a/include/linux/pm_opp.h -+++ b/include/linux/pm_opp.h -@@ -24,6 +24,22 @@ enum dev_pm_opp_event { - OPP_EVENT_ADD, OPP_EVENT_REMOVE, OPP_EVENT_ENABLE, OPP_EVENT_DISABLE, - }; - -+/** -+ * struct dev_pm_opp_supply - Power supply voltage/current values -+ * @u_volt: Target voltage in microvolts corresponding to this OPP -+ * @u_volt_min: Minimum voltage in microvolts corresponding to this OPP -+ * @u_volt_max: Maximum voltage in microvolts corresponding to this OPP -+ * @u_amp: Maximum current drawn by the device in microamperes -+ * -+ * This structure stores the voltage/current values for a single power supply. -+ */ -+struct dev_pm_opp_supply { -+ unsigned long u_volt; -+ unsigned long u_volt_min; -+ unsigned long u_volt_max; -+ unsigned long u_amp; -+}; -+ - #if defined(CONFIG_PM_OPP) - - unsigned long dev_pm_opp_get_voltage(struct dev_pm_opp *opp); --- -2.10.2 - diff --git a/patches/drivers/pm_opp/0005-PM-OPP-Pass-struct-dev_pm_opp_supply-to-_set_opp_vol.patch b/patches/drivers/pm_opp/0005-PM-OPP-Pass-struct-dev_pm_opp_supply-to-_set_opp_vol.patch deleted file mode 100644 index 2dffa67dfa3e82019d75fe48aaf1e0b937c8f855..0000000000000000000000000000000000000000 --- a/patches/drivers/pm_opp/0005-PM-OPP-Pass-struct-dev_pm_opp_supply-to-_set_opp_vol.patch +++ /dev/null @@ -1,119 +0,0 @@ -From 4ee34f511c2ce6c4c89f5db4ee7da932f0d90316 Mon Sep 17 00:00:00 2001 -From: Viresh Kumar <viresh.kumar@linaro.org> -Date: Tue, 29 Nov 2016 12:06:52 +0530 -Subject: [PATCH 05/10] PM / OPP: Pass struct dev_pm_opp_supply to - _set_opp_voltage() - -Pass the entire supply structure instead of all of its fields. - -Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org> -Tested-by: Dave Gerlach <d-gerlach@ti.com> -Reviewed-by: Stephen Boyd <sboyd@codeaurora.org> ---- - drivers/base/power/opp/core.c | 44 +++++++++++++++++-------------------------- - 1 file changed, 17 insertions(+), 27 deletions(-) - -diff --git a/drivers/base/power/opp/core.c b/drivers/base/power/opp/core.c -index 8d60061..37fad2e 100644 ---- a/drivers/base/power/opp/core.c -+++ b/drivers/base/power/opp/core.c -@@ -542,8 +542,7 @@ static struct clk *_get_opp_clk(struct device *dev) - } - - static int _set_opp_voltage(struct device *dev, struct regulator *reg, -- unsigned long u_volt, unsigned long u_volt_min, -- unsigned long u_volt_max) -+ struct dev_pm_opp_supply *supply) - { - int ret; - -@@ -554,14 +553,15 @@ static int _set_opp_voltage(struct device *dev, struct regulator *reg, - return 0; - } - -- dev_dbg(dev, "%s: voltages (mV): %lu %lu %lu\n", __func__, u_volt_min, -- u_volt, u_volt_max); -+ dev_dbg(dev, "%s: voltages (mV): %lu %lu %lu\n", __func__, -+ supply->u_volt_min, supply->u_volt, supply->u_volt_max); - -- ret = regulator_set_voltage_triplet(reg, u_volt_min, u_volt, -- u_volt_max); -+ ret = regulator_set_voltage_triplet(reg, supply->u_volt_min, -+ supply->u_volt, supply->u_volt_max); - if (ret) - dev_err(dev, "%s: failed to set voltage (%lu %lu %lu mV): %d\n", -- __func__, u_volt_min, u_volt, u_volt_max, ret); -+ __func__, supply->u_volt_min, supply->u_volt, -+ supply->u_volt_max, ret); - - return ret; - } -@@ -583,8 +583,7 @@ int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq) - struct regulator *reg; - struct clk *clk; - unsigned long freq, old_freq; -- unsigned long u_volt, u_volt_min, u_volt_max; -- unsigned long old_u_volt, old_u_volt_min, old_u_volt_max; -+ struct dev_pm_opp_supply old_supply, new_supply; - int ret; - - if (unlikely(!target_freq)) { -@@ -634,17 +633,12 @@ int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq) - return ret; - } - -- if (IS_ERR(old_opp)) { -- old_u_volt = 0; -- } else { -- old_u_volt = old_opp->supply.u_volt; -- old_u_volt_min = old_opp->supply.u_volt_min; -- old_u_volt_max = old_opp->supply.u_volt_max; -- } -+ if (IS_ERR(old_opp)) -+ old_supply.u_volt = 0; -+ else -+ memcpy(&old_supply, &old_opp->supply, sizeof(old_supply)); - -- u_volt = opp->supply.u_volt; -- u_volt_min = opp->supply.u_volt_min; -- u_volt_max = opp->supply.u_volt_max; -+ memcpy(&new_supply, &opp->supply, sizeof(new_supply)); - - reg = opp_table->regulator; - -@@ -652,8 +646,7 @@ int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq) - - /* Scaling up? Scale voltage before frequency */ - if (freq > old_freq) { -- ret = _set_opp_voltage(dev, reg, u_volt, u_volt_min, -- u_volt_max); -+ ret = _set_opp_voltage(dev, reg, &new_supply); - if (ret) - goto restore_voltage; - } -@@ -672,8 +665,7 @@ int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq) - - /* Scaling down? Scale voltage after frequency */ - if (freq < old_freq) { -- ret = _set_opp_voltage(dev, reg, u_volt, u_volt_min, -- u_volt_max); -+ ret = _set_opp_voltage(dev, reg, &new_supply); - if (ret) - goto restore_freq; - } -@@ -686,10 +678,8 @@ int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq) - __func__, old_freq); - restore_voltage: - /* This shouldn't harm even if the voltages weren't updated earlier */ -- if (old_u_volt) { -- _set_opp_voltage(dev, reg, old_u_volt, old_u_volt_min, -- old_u_volt_max); -- } -+ if (old_supply.u_volt) -+ _set_opp_voltage(dev, reg, &old_supply); - - return ret; - } --- -2.10.2 - diff --git a/patches/drivers/pm_opp/0006-PM-OPP-Add-infrastructure-to-manage-multiple-regulat.patch b/patches/drivers/pm_opp/0006-PM-OPP-Add-infrastructure-to-manage-multiple-regulat.patch deleted file mode 100644 index 5b8a48bb234d2ba1127a86bcd0c6e85a64a643b4..0000000000000000000000000000000000000000 --- a/patches/drivers/pm_opp/0006-PM-OPP-Add-infrastructure-to-manage-multiple-regulat.patch +++ /dev/null @@ -1,805 +0,0 @@ -From c70ebc79a570fa6f6f4702b10d4f80661ab57472 Mon Sep 17 00:00:00 2001 -From: Viresh Kumar <viresh.kumar@linaro.org> -Date: Tue, 29 Nov 2016 12:06:53 +0530 -Subject: [PATCH 06/10] PM / OPP: Add infrastructure to manage multiple - regulators - -This patch adds infrastructure to manage multiple regulators and updates -the only user (cpufreq-dt) of dev_pm_opp_set{put}_regulator(). - -This is preparatory work for adding full support for devices with -multiple regulators. - -Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org> -Tested-by: Dave Gerlach <d-gerlach@ti.com> ---- - drivers/base/power/opp/core.c | 246 +++++++++++++++++++++++++++------------ - drivers/base/power/opp/debugfs.c | 52 +++++++-- - drivers/base/power/opp/of.c | 103 +++++++++++----- - drivers/base/power/opp/opp.h | 10 +- - drivers/cpufreq/cpufreq-dt.c | 9 +- - include/linux/pm_opp.h | 8 +- - 6 files changed, 301 insertions(+), 127 deletions(-) - -diff --git a/drivers/base/power/opp/core.c b/drivers/base/power/opp/core.c -index 37fad2e..89a3fd7 100644 ---- a/drivers/base/power/opp/core.c -+++ b/drivers/base/power/opp/core.c -@@ -93,6 +93,8 @@ struct opp_table *_find_opp_table(struct device *dev) - * Return: voltage in micro volt corresponding to the opp, else - * return 0 - * -+ * This is useful only for devices with single power supply. -+ * - * Locking: This function must be called under rcu_read_lock(). opp is a rcu - * protected pointer. This means that opp which could have been fetched by - * opp_find_freq_{exact,ceil,floor} functions is valid as long as we are -@@ -112,7 +114,7 @@ unsigned long dev_pm_opp_get_voltage(struct dev_pm_opp *opp) - if (IS_ERR_OR_NULL(tmp_opp)) - pr_err("%s: Invalid parameters\n", __func__); - else -- v = tmp_opp->supply.u_volt; -+ v = tmp_opp->supplies[0].u_volt; - - return v; - } -@@ -210,6 +212,24 @@ unsigned long dev_pm_opp_get_max_clock_latency(struct device *dev) - } - EXPORT_SYMBOL_GPL(dev_pm_opp_get_max_clock_latency); - -+static int _get_regulator_count(struct device *dev) -+{ -+ struct opp_table *opp_table; -+ int count; -+ -+ rcu_read_lock(); -+ -+ opp_table = _find_opp_table(dev); -+ if (!IS_ERR(opp_table)) -+ count = opp_table->regulator_count; -+ else -+ count = 0; -+ -+ rcu_read_unlock(); -+ -+ return count; -+} -+ - /** - * dev_pm_opp_get_max_volt_latency() - Get max voltage latency in nanoseconds - * @dev: device for which we do this operation -@@ -222,34 +242,51 @@ unsigned long dev_pm_opp_get_max_volt_latency(struct device *dev) - { - struct opp_table *opp_table; - struct dev_pm_opp *opp; -- struct regulator *reg; -+ struct regulator *reg, **regulators; - unsigned long latency_ns = 0; -- unsigned long min_uV = ~0, max_uV = 0; -- int ret; -+ int ret, i, count; -+ struct { -+ unsigned long min; -+ unsigned long max; -+ } *uV; -+ -+ count = _get_regulator_count(dev); -+ -+ /* Regulator may not be required for the device */ -+ if (!count) -+ return 0; -+ -+ regulators = kmalloc_array(count, sizeof(*regulators), GFP_KERNEL); -+ if (!regulators) -+ return 0; -+ -+ uV = kmalloc_array(count, sizeof(*uV), GFP_KERNEL); -+ if (!uV) -+ goto free_regulators; - - rcu_read_lock(); - - opp_table = _find_opp_table(dev); - if (IS_ERR(opp_table)) { - rcu_read_unlock(); -- return 0; -+ goto free_uV; - } - -- reg = opp_table->regulator; -- if (IS_ERR(reg)) { -- /* Regulator may not be required for device */ -- rcu_read_unlock(); -- return 0; -- } -+ memcpy(regulators, opp_table->regulators, count * sizeof(*regulators)); - -- list_for_each_entry_rcu(opp, &opp_table->opp_list, node) { -- if (!opp->available) -- continue; -+ for (i = 0; i < count; i++) { -+ uV[i].min = ~0; -+ uV[i].max = 0; - -- if (opp->supply.u_volt_min < min_uV) -- min_uV = opp->supply.u_volt_min; -- if (opp->supply.u_volt_max > max_uV) -- max_uV = opp->supply.u_volt_max; -+ list_for_each_entry_rcu(opp, &opp_table->opp_list, node) { -+ if (!opp->available) -+ continue; -+ -+ if (opp->supplies[i].u_volt_min < uV[i].min) -+ uV[i].min = opp->supplies[i].u_volt_min; -+ if (opp->supplies[i].u_volt_max > uV[i].max) -+ uV[i].max = opp->supplies[i].u_volt_max; -+ } - } - - rcu_read_unlock(); -@@ -258,9 +295,16 @@ unsigned long dev_pm_opp_get_max_volt_latency(struct device *dev) - * The caller needs to ensure that opp_table (and hence the regulator) - * isn't freed, while we are executing this routine. - */ -- ret = regulator_set_voltage_time(reg, min_uV, max_uV); -- if (ret > 0) -- latency_ns = ret * 1000; -+ for (i = 0; reg = regulators[i], i < count; i++) { -+ ret = regulator_set_voltage_time(reg, uV[i].min, uV[i].max); -+ if (ret > 0) -+ latency_ns += ret * 1000; -+ } -+ -+free_uV: -+ kfree(uV); -+free_regulators: -+ kfree(regulators); - - return latency_ns; - } -@@ -580,7 +624,7 @@ int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq) - { - struct opp_table *opp_table; - struct dev_pm_opp *old_opp, *opp; -- struct regulator *reg; -+ struct regulator *reg = ERR_PTR(-ENXIO); - struct clk *clk; - unsigned long freq, old_freq; - struct dev_pm_opp_supply old_supply, new_supply; -@@ -633,14 +677,23 @@ int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq) - return ret; - } - -+ if (opp_table->regulators) { -+ /* This function only supports single regulator per device */ -+ if (WARN_ON(opp_table->regulator_count > 1)) { -+ dev_err(dev, "multiple regulators not supported\n"); -+ rcu_read_unlock(); -+ return -EINVAL; -+ } -+ -+ reg = opp_table->regulators[0]; -+ } -+ - if (IS_ERR(old_opp)) - old_supply.u_volt = 0; - else -- memcpy(&old_supply, &old_opp->supply, sizeof(old_supply)); -- -- memcpy(&new_supply, &opp->supply, sizeof(new_supply)); -+ memcpy(&old_supply, old_opp->supplies, sizeof(old_supply)); - -- reg = opp_table->regulator; -+ memcpy(&new_supply, opp->supplies, sizeof(new_supply)); - - rcu_read_unlock(); - -@@ -764,9 +817,6 @@ static struct opp_table *_add_opp_table(struct device *dev) - - _of_init_opp_table(opp_table, dev); - -- /* Set regulator to a non-NULL error value */ -- opp_table->regulator = ERR_PTR(-ENXIO); -- - /* Find clk for the device */ - opp_table->clk = clk_get(dev, NULL); - if (IS_ERR(opp_table->clk)) { -@@ -815,7 +865,7 @@ static void _remove_opp_table(struct opp_table *opp_table) - if (opp_table->prop_name) - return; - -- if (!IS_ERR(opp_table->regulator)) -+ if (opp_table->regulators) - return; - - /* Release clk */ -@@ -924,35 +974,50 @@ struct dev_pm_opp *_allocate_opp(struct device *dev, - struct opp_table **opp_table) - { - struct dev_pm_opp *opp; -+ int count, supply_size; -+ struct opp_table *table; - -- /* allocate new OPP node */ -- opp = kzalloc(sizeof(*opp), GFP_KERNEL); -- if (!opp) -+ table = _add_opp_table(dev); -+ if (!table) - return NULL; - -- INIT_LIST_HEAD(&opp->node); -+ /* Allocate space for at least one supply */ -+ count = table->regulator_count ? table->regulator_count : 1; -+ supply_size = sizeof(*opp->supplies) * count; - -- *opp_table = _add_opp_table(dev); -- if (!*opp_table) { -- kfree(opp); -+ /* allocate new OPP node and supplies structures */ -+ opp = kzalloc(sizeof(*opp) + supply_size, GFP_KERNEL); -+ if (!opp) { -+ kfree(table); - return NULL; - } - -+ /* Put the supplies at the end of the OPP structure as an empty array */ -+ opp->supplies = (struct dev_pm_opp_supply *)(opp + 1); -+ INIT_LIST_HEAD(&opp->node); -+ -+ *opp_table = table; -+ - return opp; - } - - static bool _opp_supported_by_regulators(struct dev_pm_opp *opp, - struct opp_table *opp_table) - { -- struct regulator *reg = opp_table->regulator; -- -- if (!IS_ERR(reg) && -- !regulator_is_supported_voltage(reg, opp->supply.u_volt_min, -- opp->supply.u_volt_max)) { -- pr_warn("%s: OPP minuV: %lu maxuV: %lu, not supported by regulator\n", -- __func__, opp->supply.u_volt_min, -- opp->supply.u_volt_max); -- return false; -+ struct regulator *reg; -+ int i; -+ -+ for (i = 0; i < opp_table->regulator_count; i++) { -+ reg = opp_table->regulators[i]; -+ -+ if (!regulator_is_supported_voltage(reg, -+ opp->supplies[i].u_volt_min, -+ opp->supplies[i].u_volt_max)) { -+ pr_warn("%s: OPP minuV: %lu maxuV: %lu, not supported by regulator\n", -+ __func__, opp->supplies[i].u_volt_min, -+ opp->supplies[i].u_volt_max); -+ return false; -+ } - } - - return true; -@@ -984,12 +1049,13 @@ int _opp_add(struct device *dev, struct dev_pm_opp *new_opp, - - /* Duplicate OPPs */ - dev_warn(dev, "%s: duplicate OPPs detected. Existing: freq: %lu, volt: %lu, enabled: %d. New: freq: %lu, volt: %lu, enabled: %d\n", -- __func__, opp->rate, opp->supply.u_volt, -- opp->available, new_opp->rate, new_opp->supply.u_volt, -- new_opp->available); -+ __func__, opp->rate, opp->supplies[0].u_volt, -+ opp->available, new_opp->rate, -+ new_opp->supplies[0].u_volt, new_opp->available); - -+ /* Should we compare voltages for all regulators here ? */ - return opp->available && -- new_opp->supply.u_volt == opp->supply.u_volt ? 0 : -EEXIST; -+ new_opp->supplies[0].u_volt == opp->supplies[0].u_volt ? 0 : -EEXIST; - } - - new_opp->opp_table = opp_table; -@@ -1056,9 +1122,9 @@ int _opp_add_v1(struct device *dev, unsigned long freq, long u_volt, - /* populate the opp table */ - new_opp->rate = freq; - tol = u_volt * opp_table->voltage_tolerance_v1 / 100; -- new_opp->supply.u_volt = u_volt; -- new_opp->supply.u_volt_min = u_volt - tol; -- new_opp->supply.u_volt_max = u_volt + tol; -+ new_opp->supplies[0].u_volt = u_volt; -+ new_opp->supplies[0].u_volt_min = u_volt - tol; -+ new_opp->supplies[0].u_volt_max = u_volt + tol; - new_opp->available = true; - new_opp->dynamic = dynamic; - -@@ -1303,12 +1369,14 @@ void dev_pm_opp_put_prop_name(struct device *dev) - EXPORT_SYMBOL_GPL(dev_pm_opp_put_prop_name); - - /** -- * dev_pm_opp_set_regulator() - Set regulator name for the device -+ * dev_pm_opp_set_regulators() - Set regulator names for the device - * @dev: Device for which regulator name is being set. -- * @name: Name of the regulator. -+ * @names: Array of pointers to the names of the regulator. -+ * @count: Number of regulators. - * - * In order to support OPP switching, OPP layer needs to know the name of the -- * device's regulator, as the core would be required to switch voltages as well. -+ * device's regulators, as the core would be required to switch voltages as -+ * well. - * - * This must be called before any OPPs are initialized for the device. - * -@@ -1318,11 +1386,12 @@ EXPORT_SYMBOL_GPL(dev_pm_opp_put_prop_name); - * that this function is *NOT* called under RCU protection or in contexts where - * mutex cannot be locked. - */ --int dev_pm_opp_set_regulator(struct device *dev, const char *name) -+int dev_pm_opp_set_regulators(struct device *dev, const char * const names[], -+ unsigned int count) - { - struct opp_table *opp_table; - struct regulator *reg; -- int ret; -+ int ret, i; - - mutex_lock(&opp_table_lock); - -@@ -1338,26 +1407,44 @@ int dev_pm_opp_set_regulator(struct device *dev, const char *name) - goto err; - } - -- /* Already have a regulator set */ -- if (WARN_ON(!IS_ERR(opp_table->regulator))) { -+ /* Already have regulators set */ -+ if (WARN_ON(opp_table->regulators)) { - ret = -EBUSY; - goto err; - } -- /* Allocate the regulator */ -- reg = regulator_get_optional(dev, name); -- if (IS_ERR(reg)) { -- ret = PTR_ERR(reg); -- if (ret != -EPROBE_DEFER) -- dev_err(dev, "%s: no regulator (%s) found: %d\n", -- __func__, name, ret); -+ -+ opp_table->regulators = kmalloc_array(count, -+ sizeof(*opp_table->regulators), -+ GFP_KERNEL); -+ if (!opp_table->regulators) { -+ ret = -ENOMEM; - goto err; - } - -- opp_table->regulator = reg; -+ for (i = 0; i < count; i++) { -+ reg = regulator_get_optional(dev, names[i]); -+ if (IS_ERR(reg)) { -+ ret = PTR_ERR(reg); -+ if (ret != -EPROBE_DEFER) -+ dev_err(dev, "%s: regulator (%s) not found: %d\n", -+ __func__, names[i], ret); -+ goto free_regulators; -+ } -+ -+ opp_table->regulators[i] = reg; -+ } -+ -+ opp_table->regulator_count = count; - - mutex_unlock(&opp_table_lock); - return 0; - -+free_regulators: -+ while (i != 0) -+ regulator_put(opp_table->regulators[--i]); -+ -+ kfree(opp_table->regulators); -+ opp_table->regulators = NULL; - err: - _remove_opp_table(opp_table); - unlock: -@@ -1365,11 +1452,11 @@ int dev_pm_opp_set_regulator(struct device *dev, const char *name) - - return ret; - } --EXPORT_SYMBOL_GPL(dev_pm_opp_set_regulator); -+EXPORT_SYMBOL_GPL(dev_pm_opp_set_regulators); - - /** -- * dev_pm_opp_put_regulator() - Releases resources blocked for regulator -- * @dev: Device for which regulator was set. -+ * dev_pm_opp_put_regulators() - Releases resources blocked for regulators -+ * @dev: Device for which regulators were set. - * - * Locking: The internal opp_table and opp structures are RCU protected. - * Hence this function internally uses RCU updater strategy with mutex locks -@@ -1377,9 +1464,10 @@ EXPORT_SYMBOL_GPL(dev_pm_opp_set_regulator); - * that this function is *NOT* called under RCU protection or in contexts where - * mutex cannot be locked. - */ --void dev_pm_opp_put_regulator(struct device *dev) -+void dev_pm_opp_put_regulators(struct device *dev) - { - struct opp_table *opp_table; -+ int i; - - mutex_lock(&opp_table_lock); - -@@ -1391,16 +1479,20 @@ void dev_pm_opp_put_regulator(struct device *dev) - goto unlock; - } - -- if (IS_ERR(opp_table->regulator)) { -- dev_err(dev, "%s: Doesn't have regulator set\n", __func__); -+ if (!opp_table->regulators) { -+ dev_err(dev, "%s: Doesn't have regulators set\n", __func__); - goto unlock; - } - - /* Make sure there are no concurrent readers while updating opp_table */ - WARN_ON(!list_empty(&opp_table->opp_list)); - -- regulator_put(opp_table->regulator); -- opp_table->regulator = ERR_PTR(-ENXIO); -+ for (i = opp_table->regulator_count - 1; i >= 0; i--) -+ regulator_put(opp_table->regulators[i]); -+ -+ kfree(opp_table->regulators); -+ opp_table->regulators = NULL; -+ opp_table->regulator_count = 0; - - /* Try freeing opp_table if this was the last blocking resource */ - _remove_opp_table(opp_table); -@@ -1408,7 +1500,7 @@ void dev_pm_opp_put_regulator(struct device *dev) - unlock: - mutex_unlock(&opp_table_lock); - } --EXPORT_SYMBOL_GPL(dev_pm_opp_put_regulator); -+EXPORT_SYMBOL_GPL(dev_pm_opp_put_regulators); - - /** - * dev_pm_opp_add() - Add an OPP table from a table definitions -diff --git a/drivers/base/power/opp/debugfs.c b/drivers/base/power/opp/debugfs.c -index c897676..95f433d 100644 ---- a/drivers/base/power/opp/debugfs.c -+++ b/drivers/base/power/opp/debugfs.c -@@ -15,6 +15,7 @@ - #include <linux/err.h> - #include <linux/init.h> - #include <linux/limits.h> -+#include <linux/slab.h> - - #include "opp.h" - -@@ -34,6 +35,46 @@ void opp_debug_remove_one(struct dev_pm_opp *opp) - debugfs_remove_recursive(opp->dentry); - } - -+static bool opp_debug_create_supplies(struct dev_pm_opp *opp, -+ struct opp_table *opp_table, -+ struct dentry *pdentry) -+{ -+ struct dentry *d; -+ int i = 0; -+ char *name; -+ -+ /* Always create at least supply-0 directory */ -+ do { -+ name = kasprintf(GFP_KERNEL, "supply-%d", i); -+ -+ /* Create per-opp directory */ -+ d = debugfs_create_dir(name, pdentry); -+ -+ kfree(name); -+ -+ if (!d) -+ return false; -+ -+ if (!debugfs_create_ulong("u_volt_target", S_IRUGO, d, -+ &opp->supplies[i].u_volt)) -+ return false; -+ -+ if (!debugfs_create_ulong("u_volt_min", S_IRUGO, d, -+ &opp->supplies[i].u_volt_min)) -+ return false; -+ -+ if (!debugfs_create_ulong("u_volt_max", S_IRUGO, d, -+ &opp->supplies[i].u_volt_max)) -+ return false; -+ -+ if (!debugfs_create_ulong("u_amp", S_IRUGO, d, -+ &opp->supplies[i].u_amp)) -+ return false; -+ } while (++i < opp_table->regulator_count); -+ -+ return true; -+} -+ - int opp_debug_create_one(struct dev_pm_opp *opp, struct opp_table *opp_table) - { - struct dentry *pdentry = opp_table->dentry; -@@ -63,16 +104,7 @@ int opp_debug_create_one(struct dev_pm_opp *opp, struct opp_table *opp_table) - if (!debugfs_create_ulong("rate_hz", S_IRUGO, d, &opp->rate)) - return -ENOMEM; - -- if (!debugfs_create_ulong("u_volt_target", S_IRUGO, d, &opp->supply.u_volt)) -- return -ENOMEM; -- -- if (!debugfs_create_ulong("u_volt_min", S_IRUGO, d, &opp->supply.u_volt_min)) -- return -ENOMEM; -- -- if (!debugfs_create_ulong("u_volt_max", S_IRUGO, d, &opp->supply.u_volt_max)) -- return -ENOMEM; -- -- if (!debugfs_create_ulong("u_amp", S_IRUGO, d, &opp->supply.u_amp)) -+ if (!opp_debug_create_supplies(opp, opp_table, d)) - return -ENOMEM; - - if (!debugfs_create_ulong("clock_latency_ns", S_IRUGO, d, -diff --git a/drivers/base/power/opp/of.c b/drivers/base/power/opp/of.c -index b7fcd0a..477beda 100644 ---- a/drivers/base/power/opp/of.c -+++ b/drivers/base/power/opp/of.c -@@ -17,6 +17,7 @@ - #include <linux/errno.h> - #include <linux/device.h> - #include <linux/of.h> -+#include <linux/slab.h> - #include <linux/export.h> - - #include "opp.h" -@@ -101,16 +102,16 @@ static bool _opp_is_supported(struct device *dev, struct opp_table *opp_table, - return true; - } - --/* TODO: Support multiple regulators */ - static int opp_parse_supplies(struct dev_pm_opp *opp, struct device *dev, - struct opp_table *opp_table) - { -- u32 microvolt[3] = {0}; -- u32 val; -- int count, ret; -+ u32 *microvolt, *microamp = NULL; -+ int supplies, vcount, icount, ret, i, j; - struct property *prop = NULL; - char name[NAME_MAX]; - -+ supplies = opp_table->regulator_count ? opp_table->regulator_count : 1; -+ - /* Search for "opp-microvolt-<name>" */ - if (opp_table->prop_name) { - snprintf(name, sizeof(name), "opp-microvolt-%s", -@@ -128,34 +129,29 @@ static int opp_parse_supplies(struct dev_pm_opp *opp, struct device *dev, - return 0; - } - -- count = of_property_count_u32_elems(opp->np, name); -- if (count < 0) { -+ vcount = of_property_count_u32_elems(opp->np, name); -+ if (vcount < 0) { - dev_err(dev, "%s: Invalid %s property (%d)\n", -- __func__, name, count); -- return count; -+ __func__, name, vcount); -+ return vcount; - } - -- /* There can be one or three elements here */ -- if (count != 1 && count != 3) { -- dev_err(dev, "%s: Invalid number of elements in %s property (%d)\n", -- __func__, name, count); -+ /* There can be one or three elements per supply */ -+ if (vcount != supplies && vcount != supplies * 3) { -+ dev_err(dev, "%s: Invalid number of elements in %s property (%d) with supplies (%d)\n", -+ __func__, name, vcount, supplies); - return -EINVAL; - } - -- ret = of_property_read_u32_array(opp->np, name, microvolt, count); -+ microvolt = kmalloc_array(vcount, sizeof(*microvolt), GFP_KERNEL); -+ if (!microvolt) -+ return -ENOMEM; -+ -+ ret = of_property_read_u32_array(opp->np, name, microvolt, vcount); - if (ret) { - dev_err(dev, "%s: error parsing %s: %d\n", __func__, name, ret); -- return -EINVAL; -- } -- -- opp->supply.u_volt = microvolt[0]; -- -- if (count == 1) { -- opp->supply.u_volt_min = opp->supply.u_volt; -- opp->supply.u_volt_max = opp->supply.u_volt; -- } else { -- opp->supply.u_volt_min = microvolt[1]; -- opp->supply.u_volt_max = microvolt[2]; -+ ret = -EINVAL; -+ goto free_microvolt; - } - - /* Search for "opp-microamp-<name>" */ -@@ -172,10 +168,59 @@ static int opp_parse_supplies(struct dev_pm_opp *opp, struct device *dev, - prop = of_find_property(opp->np, name, NULL); - } - -- if (prop && !of_property_read_u32(opp->np, name, &val)) -- opp->supply.u_amp = val; -+ if (prop) { -+ icount = of_property_count_u32_elems(opp->np, name); -+ if (icount < 0) { -+ dev_err(dev, "%s: Invalid %s property (%d)\n", __func__, -+ name, icount); -+ ret = icount; -+ goto free_microvolt; -+ } - -- return 0; -+ if (icount != supplies) { -+ dev_err(dev, "%s: Invalid number of elements in %s property (%d) with supplies (%d)\n", -+ __func__, name, icount, supplies); -+ ret = -EINVAL; -+ goto free_microvolt; -+ } -+ -+ microamp = kmalloc_array(icount, sizeof(*microamp), GFP_KERNEL); -+ if (!microamp) { -+ ret = -EINVAL; -+ goto free_microvolt; -+ } -+ -+ ret = of_property_read_u32_array(opp->np, name, microamp, -+ icount); -+ if (ret) { -+ dev_err(dev, "%s: error parsing %s: %d\n", __func__, -+ name, ret); -+ ret = -EINVAL; -+ goto free_microamp; -+ } -+ } -+ -+ for (i = 0, j = 0; i < supplies; i++) { -+ opp->supplies[i].u_volt = microvolt[j++]; -+ -+ if (vcount == supplies) { -+ opp->supplies[i].u_volt_min = opp->supplies[i].u_volt; -+ opp->supplies[i].u_volt_max = opp->supplies[i].u_volt; -+ } else { -+ opp->supplies[i].u_volt_min = microvolt[j++]; -+ opp->supplies[i].u_volt_max = microvolt[j++]; -+ } -+ -+ if (microamp) -+ opp->supplies[i].u_amp = microamp[i]; -+ } -+ -+free_microamp: -+ kfree(microamp); -+free_microvolt: -+ kfree(microvolt); -+ -+ return ret; - } - - /** -@@ -304,8 +349,8 @@ static int _opp_add_static_v2(struct device *dev, struct device_node *np) - - pr_debug("%s: turbo:%d rate:%lu uv:%lu uvmin:%lu uvmax:%lu latency:%lu\n", - __func__, new_opp->turbo, new_opp->rate, -- new_opp->supply.u_volt, new_opp->supply.u_volt_min, -- new_opp->supply.u_volt_max, new_opp->clock_latency_ns); -+ new_opp->supplies[0].u_volt, new_opp->supplies[0].u_volt_min, -+ new_opp->supplies[0].u_volt_max, new_opp->clock_latency_ns); - - /* - * Notify the changes in the availability of the operable -diff --git a/drivers/base/power/opp/opp.h b/drivers/base/power/opp/opp.h -index 7912131..d5f09ee 100644 ---- a/drivers/base/power/opp/opp.h -+++ b/drivers/base/power/opp/opp.h -@@ -61,7 +61,7 @@ extern struct list_head opp_tables; - * @turbo: true if turbo (boost) OPP - * @suspend: true if suspend OPP - * @rate: Frequency in hertz -- * @supply: Power supply voltage/current values -+ * @supplies: Power supplies voltage/current values - * @clock_latency_ns: Latency (in nanoseconds) of switching to this OPP's - * frequency from any other OPP's frequency. - * @opp_table: points back to the opp_table struct this opp belongs to -@@ -80,7 +80,7 @@ struct dev_pm_opp { - bool suspend; - unsigned long rate; - -- struct dev_pm_opp_supply supply; -+ struct dev_pm_opp_supply *supplies; - - unsigned long clock_latency_ns; - -@@ -139,7 +139,8 @@ enum opp_table_access { - * @supported_hw_count: Number of elements in supported_hw array. - * @prop_name: A name to postfix to many DT properties, while parsing them. - * @clk: Device's clock handle -- * @regulator: Supply regulator -+ * @regulators: Supply regulators -+ * @regulator_count: Number of power supply regulators - * @dentry: debugfs dentry pointer of the real device directory (not links). - * @dentry_name: Name of the real dentry. - * -@@ -174,7 +175,8 @@ struct opp_table { - unsigned int supported_hw_count; - const char *prop_name; - struct clk *clk; -- struct regulator *regulator; -+ struct regulator **regulators; -+ unsigned int regulator_count; - - #ifdef CONFIG_DEBUG_FS - struct dentry *dentry; -diff --git a/drivers/cpufreq/cpufreq-dt.c b/drivers/cpufreq/cpufreq-dt.c -index 5c07ae0..15cb261 100644 ---- a/drivers/cpufreq/cpufreq-dt.c -+++ b/drivers/cpufreq/cpufreq-dt.c -@@ -186,7 +186,10 @@ static int cpufreq_init(struct cpufreq_policy *policy) - */ - name = find_supply_name(cpu_dev); - if (name) { -- ret = dev_pm_opp_set_regulator(cpu_dev, name); -+ const char *names[] = {name}; -+ -+ ret = dev_pm_opp_set_regulators(cpu_dev, names, -+ ARRAY_SIZE(names)); - if (ret) { - dev_err(cpu_dev, "Failed to set regulator for cpu%d: %d\n", - policy->cpu, ret); -@@ -285,7 +288,7 @@ static int cpufreq_init(struct cpufreq_policy *policy) - out_free_opp: - dev_pm_opp_of_cpumask_remove_table(policy->cpus); - if (name) -- dev_pm_opp_put_regulator(cpu_dev); -+ dev_pm_opp_put_regulators(cpu_dev); - out_put_clk: - clk_put(cpu_clk); - -@@ -300,7 +303,7 @@ static int cpufreq_exit(struct cpufreq_policy *policy) - dev_pm_opp_free_cpufreq_table(priv->cpu_dev, &policy->freq_table); - dev_pm_opp_of_cpumask_remove_table(policy->related_cpus); - if (priv->reg_name) -- dev_pm_opp_put_regulator(priv->cpu_dev); -+ dev_pm_opp_put_regulators(priv->cpu_dev); - - clk_put(policy->clk); - kfree(priv); -diff --git a/include/linux/pm_opp.h b/include/linux/pm_opp.h -index f69126e..27eea9b 100644 ---- a/include/linux/pm_opp.h -+++ b/include/linux/pm_opp.h -@@ -78,8 +78,8 @@ int dev_pm_opp_set_supported_hw(struct device *dev, const u32 *versions, - void dev_pm_opp_put_supported_hw(struct device *dev); - int dev_pm_opp_set_prop_name(struct device *dev, const char *name); - void dev_pm_opp_put_prop_name(struct device *dev); --int dev_pm_opp_set_regulator(struct device *dev, const char *name); --void dev_pm_opp_put_regulator(struct device *dev); -+int dev_pm_opp_set_regulators(struct device *dev, const char * const names[], unsigned int count); -+void dev_pm_opp_put_regulators(struct device *dev); - int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq); - int dev_pm_opp_set_sharing_cpus(struct device *cpu_dev, const struct cpumask *cpumask); - int dev_pm_opp_get_sharing_cpus(struct device *cpu_dev, struct cpumask *cpumask); -@@ -186,12 +186,12 @@ static inline int dev_pm_opp_set_prop_name(struct device *dev, const char *name) - - static inline void dev_pm_opp_put_prop_name(struct device *dev) {} - --static inline int dev_pm_opp_set_regulator(struct device *dev, const char *name) -+static inline int dev_pm_opp_set_regulators(struct device *dev, const char *names[], unsigned int count) - { - return -ENOTSUPP; - } - --static inline void dev_pm_opp_put_regulator(struct device *dev) {} -+static inline void dev_pm_opp_put_regulators(struct device *dev) {} - - static inline int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq) - { --- -2.10.2 - diff --git a/patches/drivers/pm_opp/0007-PM-OPP-Separate-out-_generic_set_opp.patch b/patches/drivers/pm_opp/0007-PM-OPP-Separate-out-_generic_set_opp.patch deleted file mode 100644 index f2a17940e0b23a842a6f6b506fd5275d94579464..0000000000000000000000000000000000000000 --- a/patches/drivers/pm_opp/0007-PM-OPP-Separate-out-_generic_set_opp.patch +++ /dev/null @@ -1,340 +0,0 @@ -From 9d2e8fddd2ba4208de0cc0995cfbdc3fb86be055 Mon Sep 17 00:00:00 2001 -From: Viresh Kumar <viresh.kumar@linaro.org> -Date: Tue, 29 Nov 2016 12:06:54 +0530 -Subject: [PATCH 07/10] PM / OPP: Separate out _generic_set_opp() - -Later patches would add support for custom set_opp() callbacks. This -patch separates out the code for _generic_set_opp() handler in order to -prepare for that. - -Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org> -Tested-by: Dave Gerlach <d-gerlach@ti.com> -Reviewed-by: Stephen Boyd <sboyd@codeaurora.org> ---- - drivers/base/power/opp/core.c | 181 +++++++++++++++++++++++++++++------------- - drivers/base/power/opp/opp.h | 3 + - include/linux/pm_opp.h | 35 ++++++++ - 3 files changed, 166 insertions(+), 53 deletions(-) - -diff --git a/drivers/base/power/opp/core.c b/drivers/base/power/opp/core.c -index 89a3fd7..3a0b9d9 100644 ---- a/drivers/base/power/opp/core.c -+++ b/drivers/base/power/opp/core.c -@@ -610,6 +610,69 @@ static int _set_opp_voltage(struct device *dev, struct regulator *reg, - return ret; - } - -+static inline int -+_generic_set_opp_clk_only(struct device *dev, struct clk *clk, -+ unsigned long old_freq, unsigned long freq) -+{ -+ int ret; -+ -+ ret = clk_set_rate(clk, freq); -+ if (ret) { -+ dev_err(dev, "%s: failed to set clock rate: %d\n", __func__, -+ ret); -+ } -+ -+ return ret; -+} -+ -+static int _generic_set_opp(struct dev_pm_set_opp_data *data) -+{ -+ struct dev_pm_opp_supply *old_supply = data->old_opp.supplies; -+ struct dev_pm_opp_supply *new_supply = data->new_opp.supplies; -+ unsigned long old_freq = data->old_opp.rate, freq = data->new_opp.rate; -+ struct regulator *reg = data->regulators[0]; -+ struct device *dev= data->dev; -+ int ret; -+ -+ /* This function only supports single regulator per device */ -+ if (WARN_ON(data->regulator_count > 1)) { -+ dev_err(dev, "multiple regulators are not supported\n"); -+ return -EINVAL; -+ } -+ -+ /* Scaling up? Scale voltage before frequency */ -+ if (freq > old_freq) { -+ ret = _set_opp_voltage(dev, reg, new_supply); -+ if (ret) -+ goto restore_voltage; -+ } -+ -+ /* Change frequency */ -+ ret = _generic_set_opp_clk_only(dev, data->clk, old_freq, freq); -+ if (ret) -+ goto restore_voltage; -+ -+ /* Scaling down? Scale voltage after frequency */ -+ if (freq < old_freq) { -+ ret = _set_opp_voltage(dev, reg, new_supply); -+ if (ret) -+ goto restore_freq; -+ } -+ -+ return 0; -+ -+restore_freq: -+ if (_generic_set_opp_clk_only(dev, data->clk, freq, old_freq)) -+ dev_err(dev, "%s: failed to restore old-freq (%lu Hz)\n", -+ __func__, old_freq); -+restore_voltage: -+ /* This shouldn't harm even if the voltages weren't updated earlier */ -+ if (old_supply->u_volt) -+ _set_opp_voltage(dev, reg, old_supply); -+ -+ return ret; -+} -+ - /** - * dev_pm_opp_set_rate() - Configure new OPP based on frequency - * @dev: device for which we do this operation -@@ -623,12 +686,12 @@ static int _set_opp_voltage(struct device *dev, struct regulator *reg, - int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq) - { - struct opp_table *opp_table; -+ unsigned long freq, old_freq; - struct dev_pm_opp *old_opp, *opp; -- struct regulator *reg = ERR_PTR(-ENXIO); -+ struct regulator **regulators; -+ struct dev_pm_set_opp_data *data; - struct clk *clk; -- unsigned long freq, old_freq; -- struct dev_pm_opp_supply old_supply, new_supply; -- int ret; -+ int ret, size; - - if (unlikely(!target_freq)) { - dev_err(dev, "%s: Invalid target frequency %lu\n", __func__, -@@ -677,64 +740,36 @@ int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq) - return ret; - } - -- if (opp_table->regulators) { -- /* This function only supports single regulator per device */ -- if (WARN_ON(opp_table->regulator_count > 1)) { -- dev_err(dev, "multiple regulators not supported\n"); -- rcu_read_unlock(); -- return -EINVAL; -- } -+ dev_dbg(dev, "%s: switching OPP: %lu Hz --> %lu Hz\n", __func__, -+ old_freq, freq); - -- reg = opp_table->regulators[0]; -+ regulators = opp_table->regulators; -+ -+ /* Only frequency scaling */ -+ if (!regulators) { -+ rcu_read_unlock(); -+ return _generic_set_opp_clk_only(dev, clk, old_freq, freq); - } - -+ data = opp_table->set_opp_data; -+ data->regulators = regulators; -+ data->regulator_count = opp_table->regulator_count; -+ data->clk = clk; -+ data->dev = dev; -+ -+ data->old_opp.rate = old_freq; -+ size = sizeof(*opp->supplies) * opp_table->regulator_count; - if (IS_ERR(old_opp)) -- old_supply.u_volt = 0; -+ memset(data->old_opp.supplies, 0, size); - else -- memcpy(&old_supply, old_opp->supplies, sizeof(old_supply)); -+ memcpy(data->old_opp.supplies, old_opp->supplies, size); - -- memcpy(&new_supply, opp->supplies, sizeof(new_supply)); -+ data->new_opp.rate = freq; -+ memcpy(data->new_opp.supplies, opp->supplies, size); - - rcu_read_unlock(); - -- /* Scaling up? Scale voltage before frequency */ -- if (freq > old_freq) { -- ret = _set_opp_voltage(dev, reg, &new_supply); -- if (ret) -- goto restore_voltage; -- } -- -- /* Change frequency */ -- -- dev_dbg(dev, "%s: switching OPP: %lu Hz --> %lu Hz\n", -- __func__, old_freq, freq); -- -- ret = clk_set_rate(clk, freq); -- if (ret) { -- dev_err(dev, "%s: failed to set clock rate: %d\n", __func__, -- ret); -- goto restore_voltage; -- } -- -- /* Scaling down? Scale voltage after frequency */ -- if (freq < old_freq) { -- ret = _set_opp_voltage(dev, reg, &new_supply); -- if (ret) -- goto restore_freq; -- } -- -- return 0; -- --restore_freq: -- if (clk_set_rate(clk, old_freq)) -- dev_err(dev, "%s: failed to restore old-freq (%lu Hz)\n", -- __func__, old_freq); --restore_voltage: -- /* This shouldn't harm even if the voltages weren't updated earlier */ -- if (old_supply.u_volt) -- _set_opp_voltage(dev, reg, &old_supply); -- -- return ret; -+ return _generic_set_opp(data); - } - EXPORT_SYMBOL_GPL(dev_pm_opp_set_rate); - -@@ -1368,6 +1403,38 @@ void dev_pm_opp_put_prop_name(struct device *dev) - } - EXPORT_SYMBOL_GPL(dev_pm_opp_put_prop_name); - -+static int _allocate_set_opp_data(struct opp_table *opp_table) -+{ -+ struct dev_pm_set_opp_data *data; -+ int len, count = opp_table->regulator_count; -+ -+ if (WARN_ON(!count)) -+ return -EINVAL; -+ -+ /* space for set_opp_data */ -+ len = sizeof(*data); -+ -+ /* space for old_opp.supplies and new_opp.supplies */ -+ len += 2 * sizeof(struct dev_pm_opp_supply) * count; -+ -+ data = kzalloc(len, GFP_KERNEL); -+ if (!data) -+ return -ENOMEM; -+ -+ data->old_opp.supplies = (void *)(data + 1); -+ data->new_opp.supplies = data->old_opp.supplies + count; -+ -+ opp_table->set_opp_data = data; -+ -+ return 0; -+} -+ -+static void _free_set_opp_data(struct opp_table *opp_table) -+{ -+ kfree(opp_table->set_opp_data); -+ opp_table->set_opp_data = NULL; -+} -+ - /** - * dev_pm_opp_set_regulators() - Set regulator names for the device - * @dev: Device for which regulator name is being set. -@@ -1436,6 +1503,11 @@ int dev_pm_opp_set_regulators(struct device *dev, const char * const names[], - - opp_table->regulator_count = count; - -+ /* Allocate block only once to pass to set_opp() routines */ -+ ret = _allocate_set_opp_data(opp_table); -+ if (ret) -+ goto free_regulators; -+ - mutex_unlock(&opp_table_lock); - return 0; - -@@ -1445,6 +1517,7 @@ int dev_pm_opp_set_regulators(struct device *dev, const char * const names[], - - kfree(opp_table->regulators); - opp_table->regulators = NULL; -+ opp_table->regulator_count = 0; - err: - _remove_opp_table(opp_table); - unlock: -@@ -1490,6 +1563,8 @@ void dev_pm_opp_put_regulators(struct device *dev) - for (i = opp_table->regulator_count - 1; i >= 0; i--) - regulator_put(opp_table->regulators[i]); - -+ _free_set_opp_data(opp_table); -+ - kfree(opp_table->regulators); - opp_table->regulators = NULL; - opp_table->regulator_count = 0; -diff --git a/drivers/base/power/opp/opp.h b/drivers/base/power/opp/opp.h -index d5f09ee..ef70110 100644 ---- a/drivers/base/power/opp/opp.h -+++ b/drivers/base/power/opp/opp.h -@@ -141,6 +141,7 @@ enum opp_table_access { - * @clk: Device's clock handle - * @regulators: Supply regulators - * @regulator_count: Number of power supply regulators -+ * @set_opp_data: Data to be passed to set_opp callback - * @dentry: debugfs dentry pointer of the real device directory (not links). - * @dentry_name: Name of the real dentry. - * -@@ -178,6 +179,8 @@ struct opp_table { - struct regulator **regulators; - unsigned int regulator_count; - -+ struct dev_pm_set_opp_data *set_opp_data; -+ - #ifdef CONFIG_DEBUG_FS - struct dentry *dentry; - char dentry_name[NAME_MAX]; -diff --git a/include/linux/pm_opp.h b/include/linux/pm_opp.h -index 27eea9b..4723625 100644 ---- a/include/linux/pm_opp.h -+++ b/include/linux/pm_opp.h -@@ -17,6 +17,8 @@ - #include <linux/err.h> - #include <linux/notifier.h> - -+struct clk; -+struct regulator; - struct dev_pm_opp; - struct device; - -@@ -40,6 +42,39 @@ struct dev_pm_opp_supply { - unsigned long u_amp; - }; - -+/** -+ * struct dev_pm_opp_info - OPP freq/voltage/current values -+ * @rate: Target clk rate in hz -+ * @supplies: Array of voltage/current values for all power supplies -+ * -+ * This structure stores the freq/voltage/current values for a single OPP. -+ */ -+struct dev_pm_opp_info { -+ unsigned long rate; -+ struct dev_pm_opp_supply *supplies; -+}; -+ -+/** -+ * struct dev_pm_set_opp_data - Set OPP data -+ * @old_opp: Old OPP info -+ * @new_opp: New OPP info -+ * @regulators: Array of regulator pointers -+ * @regulator_count: Number of regulators -+ * @clk: Pointer to clk -+ * @dev: Pointer to the struct device -+ * -+ * This structure contains all information required for setting an OPP. -+ */ -+struct dev_pm_set_opp_data { -+ struct dev_pm_opp_info old_opp; -+ struct dev_pm_opp_info new_opp; -+ -+ struct regulator **regulators; -+ unsigned int regulator_count; -+ struct clk *clk; -+ struct device *dev; -+}; -+ - #if defined(CONFIG_PM_OPP) - - unsigned long dev_pm_opp_get_voltage(struct dev_pm_opp *opp); --- -2.10.2 - diff --git a/patches/drivers/pm_opp/0008-PM-OPP-Allow-platform-specific-custom-set_opp-callba.patch b/patches/drivers/pm_opp/0008-PM-OPP-Allow-platform-specific-custom-set_opp-callba.patch deleted file mode 100644 index 592112815488f8c4797aa2c5496e33826d5478ec..0000000000000000000000000000000000000000 --- a/patches/drivers/pm_opp/0008-PM-OPP-Allow-platform-specific-custom-set_opp-callba.patch +++ /dev/null @@ -1,227 +0,0 @@ -From db1d5ed6457eeda415b93d7d2a5f3fe28b832df2 Mon Sep 17 00:00:00 2001 -From: Viresh Kumar <viresh.kumar@linaro.org> -Date: Tue, 29 Nov 2016 12:06:55 +0530 -Subject: [PATCH 08/10] PM / OPP: Allow platform specific custom set_opp() - callbacks - -The generic set_opp() handler isn't sufficient for platforms with -complex DVFS. For example, some TI platforms have multiple regulators -for a CPU device. The order in which various supplies need to be -programmed is only known to the platform code and its best to leave it -to it. - -This patch implements APIs to register platform specific set_opp() -callback. - -Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org> -Tested-by: Dave Gerlach <d-gerlach@ti.com> ---- - drivers/base/power/opp/core.c | 114 +++++++++++++++++++++++++++++++++++++++++- - drivers/base/power/opp/opp.h | 2 + - include/linux/pm_opp.h | 10 ++++ - 3 files changed, 125 insertions(+), 1 deletion(-) - -diff --git a/drivers/base/power/opp/core.c b/drivers/base/power/opp/core.c -index 3a0b9d9..ddd4915 100644 ---- a/drivers/base/power/opp/core.c -+++ b/drivers/base/power/opp/core.c -@@ -687,6 +687,7 @@ int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq) - { - struct opp_table *opp_table; - unsigned long freq, old_freq; -+ int (*set_opp)(struct dev_pm_set_opp_data *data); - struct dev_pm_opp *old_opp, *opp; - struct regulator **regulators; - struct dev_pm_set_opp_data *data; -@@ -751,6 +752,11 @@ int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq) - return _generic_set_opp_clk_only(dev, clk, old_freq, freq); - } - -+ if (opp_table->set_opp) -+ set_opp = opp_table->set_opp; -+ else -+ set_opp = _generic_set_opp; -+ - data = opp_table->set_opp_data; - data->regulators = regulators; - data->regulator_count = opp_table->regulator_count; -@@ -769,7 +775,7 @@ int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq) - - rcu_read_unlock(); - -- return _generic_set_opp(data); -+ return set_opp(data); - } - EXPORT_SYMBOL_GPL(dev_pm_opp_set_rate); - -@@ -903,6 +909,9 @@ static void _remove_opp_table(struct opp_table *opp_table) - if (opp_table->regulators) - return; - -+ if (opp_table->set_opp) -+ return; -+ - /* Release clk */ - if (!IS_ERR(opp_table->clk)) - clk_put(opp_table->clk); -@@ -1578,6 +1587,109 @@ void dev_pm_opp_put_regulators(struct device *dev) - EXPORT_SYMBOL_GPL(dev_pm_opp_put_regulators); - - /** -+ * dev_pm_opp_register_set_opp_helper() - Register custom set OPP helper -+ * @dev: Device for which the helper is getting registered. -+ * @set_opp: Custom set OPP helper. -+ * -+ * This is useful to support complex platforms (like platforms with multiple -+ * regulators per device), instead of the generic OPP set rate helper. -+ * -+ * This must be called before any OPPs are initialized for the device. -+ * -+ * Locking: The internal opp_table and opp structures are RCU protected. -+ * Hence this function internally uses RCU updater strategy with mutex locks -+ * to keep the integrity of the internal data structures. Callers should ensure -+ * that this function is *NOT* called under RCU protection or in contexts where -+ * mutex cannot be locked. -+ */ -+int dev_pm_opp_register_set_opp_helper(struct device *dev, -+ int (*set_opp)(struct dev_pm_set_opp_data *data)) -+{ -+ struct opp_table *opp_table; -+ int ret; -+ -+ if (!set_opp) -+ return -EINVAL; -+ -+ mutex_lock(&opp_table_lock); -+ -+ opp_table = _add_opp_table(dev); -+ if (!opp_table) { -+ ret = -ENOMEM; -+ goto unlock; -+ } -+ -+ /* This should be called before OPPs are initialized */ -+ if (WARN_ON(!list_empty(&opp_table->opp_list))) { -+ ret = -EBUSY; -+ goto err; -+ } -+ -+ /* Already have custom set_opp helper */ -+ if (WARN_ON(opp_table->set_opp)) { -+ ret = -EBUSY; -+ goto err; -+ } -+ -+ opp_table->set_opp = set_opp; -+ -+ mutex_unlock(&opp_table_lock); -+ return 0; -+ -+err: -+ _remove_opp_table(opp_table); -+unlock: -+ mutex_unlock(&opp_table_lock); -+ -+ return ret; -+} -+EXPORT_SYMBOL_GPL(dev_pm_opp_register_set_opp_helper); -+ -+/** -+ * dev_pm_opp_register_put_opp_helper() - Releases resources blocked for -+ * set_opp helper -+ * @dev: Device for which custom set_opp helper has to be cleared. -+ * -+ * Locking: The internal opp_table and opp structures are RCU protected. -+ * Hence this function internally uses RCU updater strategy with mutex locks -+ * to keep the integrity of the internal data structures. Callers should ensure -+ * that this function is *NOT* called under RCU protection or in contexts where -+ * mutex cannot be locked. -+ */ -+void dev_pm_opp_register_put_opp_helper(struct device *dev) -+{ -+ struct opp_table *opp_table; -+ -+ mutex_lock(&opp_table_lock); -+ -+ /* Check for existing table for 'dev' first */ -+ opp_table = _find_opp_table(dev); -+ if (IS_ERR(opp_table)) { -+ dev_err(dev, "Failed to find opp_table: %ld\n", -+ PTR_ERR(opp_table)); -+ goto unlock; -+ } -+ -+ if (!opp_table->set_opp) { -+ dev_err(dev, "%s: Doesn't have custom set_opp helper set\n", -+ __func__); -+ goto unlock; -+ } -+ -+ /* Make sure there are no concurrent readers while updating opp_table */ -+ WARN_ON(!list_empty(&opp_table->opp_list)); -+ -+ opp_table->set_opp = NULL; -+ -+ /* Try freeing opp_table if this was the last blocking resource */ -+ _remove_opp_table(opp_table); -+ -+unlock: -+ mutex_unlock(&opp_table_lock); -+} -+EXPORT_SYMBOL_GPL(dev_pm_opp_register_put_opp_helper); -+ -+/** - * dev_pm_opp_add() - Add an OPP table from a table definitions - * @dev: device for which we do this operation - * @freq: Frequency in Hz for this OPP -diff --git a/drivers/base/power/opp/opp.h b/drivers/base/power/opp/opp.h -index ef70110..d830d4b 100644 ---- a/drivers/base/power/opp/opp.h -+++ b/drivers/base/power/opp/opp.h -@@ -141,6 +141,7 @@ enum opp_table_access { - * @clk: Device's clock handle - * @regulators: Supply regulators - * @regulator_count: Number of power supply regulators -+ * @set_opp: Platform specific set_opp callback - * @set_opp_data: Data to be passed to set_opp callback - * @dentry: debugfs dentry pointer of the real device directory (not links). - * @dentry_name: Name of the real dentry. -@@ -179,6 +180,7 @@ struct opp_table { - struct regulator **regulators; - unsigned int regulator_count; - -+ int (*set_opp)(struct dev_pm_set_opp_data *data); - struct dev_pm_set_opp_data *set_opp_data; - - #ifdef CONFIG_DEBUG_FS -diff --git a/include/linux/pm_opp.h b/include/linux/pm_opp.h -index 4723625..d62bd05 100644 ---- a/include/linux/pm_opp.h -+++ b/include/linux/pm_opp.h -@@ -115,6 +115,8 @@ int dev_pm_opp_set_prop_name(struct device *dev, const char *name); - void dev_pm_opp_put_prop_name(struct device *dev); - int dev_pm_opp_set_regulators(struct device *dev, const char * const names[], unsigned int count); - void dev_pm_opp_put_regulators(struct device *dev); -+int dev_pm_opp_register_set_opp_helper(struct device *dev, int (*set_opp)(struct dev_pm_set_opp_data *data)); -+void dev_pm_opp_register_put_opp_helper(struct device *dev); - int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq); - int dev_pm_opp_set_sharing_cpus(struct device *cpu_dev, const struct cpumask *cpumask); - int dev_pm_opp_get_sharing_cpus(struct device *cpu_dev, struct cpumask *cpumask); -@@ -214,6 +216,14 @@ static inline int dev_pm_opp_set_supported_hw(struct device *dev, - - static inline void dev_pm_opp_put_supported_hw(struct device *dev) {} - -+static inline int dev_pm_opp_register_set_opp_helper(struct device *dev, -+ int (*set_opp)(struct dev_pm_set_opp_data *data)) -+{ -+ return -ENOTSUPP; -+} -+ -+static inline void dev_pm_opp_register_put_opp_helper(struct device *dev) {} -+ - static inline int dev_pm_opp_set_prop_name(struct device *dev, const char *name) - { - return -ENOTSUPP; --- -2.10.2 - diff --git a/patches/drivers/pm_opp/0009-PM-OPP-Don-t-WARN-on-multiple-calls-to-dev_pm_opp_se.patch b/patches/drivers/pm_opp/0009-PM-OPP-Don-t-WARN-on-multiple-calls-to-dev_pm_opp_se.patch deleted file mode 100644 index d2b4a3fdb66385fb87c1f0a81fe9b63869f72504..0000000000000000000000000000000000000000 --- a/patches/drivers/pm_opp/0009-PM-OPP-Don-t-WARN-on-multiple-calls-to-dev_pm_opp_se.patch +++ /dev/null @@ -1,34 +0,0 @@ -From 539f800b470dd6da367b59de7f44dfc481097dcd Mon Sep 17 00:00:00 2001 -From: Viresh Kumar <viresh.kumar@linaro.org> -Date: Tue, 29 Nov 2016 12:06:56 +0530 -Subject: [PATCH 09/10] PM / OPP: Don't WARN on multiple calls to - dev_pm_opp_set_regulators() - -If a platform specific OPP driver has called this routine first and set -the regulators, then the second call from cpufreq-dt driver will hit the -WARN_ON(). Remove the WARN_ON(), but continue to return error in such -cases. - -Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org> -Reviewed-by: Stephen Boyd <sboyd@codeaurora.org> -Tested-by: Dave Gerlach <d-gerlach@ti.com> ---- - drivers/base/power/opp/core.c | 2 +- - 1 file changed, 1 insertion(+), 1 deletion(-) - -diff --git a/drivers/base/power/opp/core.c b/drivers/base/power/opp/core.c -index ddd4915..3c9f223 100644 ---- a/drivers/base/power/opp/core.c -+++ b/drivers/base/power/opp/core.c -@@ -1484,7 +1484,7 @@ int dev_pm_opp_set_regulators(struct device *dev, const char * const names[], - } - - /* Already have regulators set */ -- if (WARN_ON(opp_table->regulators)) { -+ if (opp_table->regulators) { - ret = -EBUSY; - goto err; - } --- -2.10.2 - diff --git a/patches/drivers/pm_opp/0010-PM-OPP-Don-t-assume-platform-doesn-t-have-regulators.patch b/patches/drivers/pm_opp/0010-PM-OPP-Don-t-assume-platform-doesn-t-have-regulators.patch deleted file mode 100644 index b2e4d2b2d71944524057e69272a20226608d9b96..0000000000000000000000000000000000000000 --- a/patches/drivers/pm_opp/0010-PM-OPP-Don-t-assume-platform-doesn-t-have-regulators.patch +++ /dev/null @@ -1,50 +0,0 @@ -From 6ca824bf8f1dd596d9b46e2c7f9c6f795b377525 Mon Sep 17 00:00:00 2001 -From: Viresh Kumar <viresh.kumar@linaro.org> -Date: Tue, 29 Nov 2016 12:06:57 +0530 -Subject: [PATCH 10/10] PM / OPP: Don't assume platform doesn't have regulators - -If the regulators aren't set explicitly by the platform, the OPP core -assumes that the platform doesn't have any regulator and uses the -clk-only callback. - -If the platform failed to register a regulator with the core, then this -can turn out to be a dangerous assumption as the OPP core will try to -change clk without changing regulators. - -Handle that properly by making sure that the DT didn't have any entries -for supply voltages as well. - -Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org> -Reviewed-by: Stephen Boyd <sboyd@codeaurora.org> ---- - drivers/base/power/opp/core.c | 13 +++++++++++++ - 1 file changed, 13 insertions(+) - -diff --git a/drivers/base/power/opp/core.c b/drivers/base/power/opp/core.c -index 3c9f223..f7a5fb4 100644 ---- a/drivers/base/power/opp/core.c -+++ b/drivers/base/power/opp/core.c -@@ -748,7 +748,20 @@ int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq) - - /* Only frequency scaling */ - if (!regulators) { -+ unsigned long u_volt = opp->supplies[0].u_volt; -+ - rcu_read_unlock(); -+ -+ /* -+ * DT contained supply ratings? Consider platform failed to set -+ * regulators. -+ */ -+ if (unlikely(u_volt)) { -+ dev_err(dev, "%s: Regulator not registered with OPP core\n", -+ __func__); -+ return -EINVAL; -+ } -+ - return _generic_set_opp_clk_only(dev, clk, old_freq, freq); - } - --- -2.10.2 - diff --git a/patches/drivers/ti/bbb_overlays/0010-of-overlay-global-sysfs-enable-attribute.patch b/patches/drivers/ti/bbb_overlays/0010-of-overlay-global-sysfs-enable-attribute.patch index 6712119cbfeb2f19b2194a1e26234f1573ce95f4..172756da5ae984bf1576f25c53b15480f7465600 100644 --- a/patches/drivers/ti/bbb_overlays/0010-of-overlay-global-sysfs-enable-attribute.patch +++ b/patches/drivers/ti/bbb_overlays/0010-of-overlay-global-sysfs-enable-attribute.patch @@ -15,7 +15,7 @@ Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> 1 file changed, 49 insertions(+), 1 deletion(-) diff --git a/drivers/of/overlay.c b/drivers/of/overlay.c -index 4a3f63b..053f4b2 100644 +index e6f1ca7..88248a4 100644 --- a/drivers/of/overlay.c +++ b/drivers/of/overlay.c @@ -23,6 +23,7 @@ @@ -44,9 +44,9 @@ index 4a3f63b..053f4b2 100644 struct device_node *target, const struct device_node *overlay); +static int overlay_removal_is_ok(struct of_overlay *ov); - static int of_overlay_apply_single_property(struct of_overlay *ov, - struct device_node *target, struct property *prop) -@@ -340,6 +352,35 @@ void of_overlay_release(struct kobject *kobj) + static BLOCKING_NOTIFIER_HEAD(of_overlay_chain); + +@@ -375,6 +387,35 @@ void of_overlay_release(struct kobject *kobj) kfree(ov); } @@ -82,7 +82,7 @@ index 4a3f63b..053f4b2 100644 static struct kobj_type of_overlay_ktype = { .release = of_overlay_release, }; -@@ -361,6 +402,10 @@ int of_overlay_create(struct device_node *tree) +@@ -396,6 +437,10 @@ int of_overlay_create(struct device_node *tree) struct of_overlay *ov; int err, id; @@ -93,7 +93,7 @@ index 4a3f63b..053f4b2 100644 /* allocate the overlay structure */ ov = kzalloc(sizeof(*ov), GFP_KERNEL); if (ov == NULL) -@@ -586,5 +631,8 @@ int of_overlay_init(void) +@@ -631,5 +676,8 @@ int of_overlay_init(void) if (!ov_kset) return -ENOMEM; @@ -104,5 +104,5 @@ index 4a3f63b..053f4b2 100644 + return rc; } -- -2.9.3 +2.10.2 diff --git a/patches/drivers/ti/bbb_overlays/0012-Documentation-document-of_overlay_disable-parameter.patch b/patches/drivers/ti/bbb_overlays/0012-Documentation-document-of_overlay_disable-parameter.patch index 8fdd38d98ba6eb69ca02c770fc146263928a30e3..ebe23c3423d54cad69e716bbb3ef81abfe63ceb2 100644 --- a/patches/drivers/ti/bbb_overlays/0012-Documentation-document-of_overlay_disable-parameter.patch +++ b/patches/drivers/ti/bbb_overlays/0012-Documentation-document-of_overlay_disable-parameter.patch @@ -8,22 +8,14 @@ Document the of_overlay_disable parameter. Signed-off-by: Pantelis Antoniou <pantelis.antoniou@konsulko.com> Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> --- - Documentation/kernel-parameters.txt | 3 +++ - 1 file changed, 3 insertions(+) + Documentation/admin-guide/kernel-parameters.txt | 2 ++ + 1 file changed, 2 insertions(+) -diff --git a/Documentation/kernel-parameters.txt b/Documentation/kernel-parameters.txt -index fcf05a0..df08a26 100644 ---- a/Documentation/kernel-parameters.txt -+++ b/Documentation/kernel-parameters.txt -@@ -90,6 +90,7 @@ parameter is applicable: - NET Appropriate network support is enabled. - NUMA NUMA support is enabled. - NFS Appropriate NFS support is enabled. -+ OF Open Firmware support (device tree) is enabled. - OSS OSS sound support is enabled. - PV_OPS A paravirtualized kernel is enabled. - PARIDE The ParIDE (parallel port IDE) subsystem is enabled. -@@ -2801,6 +2802,8 @@ bytes respectively. Such letter suffixes can also be entirely omitted. +diff --git a/Documentation/admin-guide/kernel-parameters.txt b/Documentation/admin-guide/kernel-parameters.txt +index 62d68b2..f80fa95 100644 +--- a/Documentation/admin-guide/kernel-parameters.txt ++++ b/Documentation/admin-guide/kernel-parameters.txt +@@ -2659,6 +2659,8 @@ This can be set from sysctl after boot. See Documentation/sysctl/vm.txt for details. @@ -33,5 +25,5 @@ index fcf05a0..df08a26 100644 See Documentation/debugging-via-ohci1394.txt for more info. -- -2.9.3 +2.10.2 diff --git a/patches/drivers/ti/bbb_overlays/0013-of-overlay-add-per-overlay-sysfs-attributes.patch b/patches/drivers/ti/bbb_overlays/0013-of-overlay-add-per-overlay-sysfs-attributes.patch index 1ca0cfa927145abf90a6f351675d5c10b9a11620..b21fb350e8e590f5910bfa339e65d5a16601a1bf 100644 --- a/patches/drivers/ti/bbb_overlays/0013-of-overlay-add-per-overlay-sysfs-attributes.patch +++ b/patches/drivers/ti/bbb_overlays/0013-of-overlay-add-per-overlay-sysfs-attributes.patch @@ -12,11 +12,11 @@ in a group named after the name of the fragment. Signed-off-by: Pantelis Antoniou <pantelis.antoniou@konsulko.com> Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> --- - drivers/of/overlay.c | 103 +++++++++++++++++++++++++++++++++++++++++++++++++-- - 1 file changed, 99 insertions(+), 4 deletions(-) + drivers/of/overlay.c | 101 +++++++++++++++++++++++++++++++++++++++++++++++++-- + 1 file changed, 98 insertions(+), 3 deletions(-) diff --git a/drivers/of/overlay.c b/drivers/of/overlay.c -index 053f4b2..73336d9 100644 +index 88248a4..fb2274d 100644 --- a/drivers/of/overlay.c +++ b/drivers/of/overlay.c @@ -27,8 +27,23 @@ @@ -65,7 +65,7 @@ index 053f4b2..73336d9 100644 struct of_changeset cset; struct kobject kobj; }; -@@ -253,6 +274,8 @@ static int of_fill_overlay_info(struct of_overlay *ov, +@@ -288,6 +309,8 @@ static int of_fill_overlay_info(struct of_overlay *ov, if (ovinfo->target == NULL) goto err_fail; @@ -74,7 +74,7 @@ index 053f4b2..73336d9 100644 return 0; err_fail: -@@ -263,6 +286,17 @@ err_fail: +@@ -298,6 +321,17 @@ static int of_fill_overlay_info(struct of_overlay *ov, return -EINVAL; } @@ -92,7 +92,7 @@ index 053f4b2..73336d9 100644 /** * of_build_overlay_info() - Build an overlay info array * @ov Overlay to build -@@ -280,7 +314,7 @@ static int of_build_overlay_info(struct of_overlay *ov, +@@ -315,7 +349,7 @@ static int of_build_overlay_info(struct of_overlay *ov, { struct device_node *node; struct of_overlay_info *ovinfo; @@ -101,7 +101,7 @@ index 053f4b2..73336d9 100644 /* worst case; every child is a node */ cnt = 0; -@@ -301,14 +335,45 @@ static int of_build_overlay_info(struct of_overlay *ov, +@@ -336,14 +370,45 @@ static int of_build_overlay_info(struct of_overlay *ov, /* if nothing filled, return error */ if (cnt == 0) { @@ -149,7 +149,7 @@ index 053f4b2..73336d9 100644 } /** -@@ -325,12 +390,16 @@ static int of_free_overlay_info(struct of_overlay *ov) +@@ -360,12 +425,16 @@ static int of_free_overlay_info(struct of_overlay *ov) struct of_overlay_info *ovinfo; int i; @@ -166,7 +166,7 @@ index 053f4b2..73336d9 100644 } kfree(ov->ovinfo_tab); -@@ -381,8 +450,25 @@ static const struct attribute *overlay_global_attrs[] = { +@@ -416,8 +485,25 @@ static const struct attribute *overlay_global_attrs[] = { NULL }; @@ -192,9 +192,9 @@ index 053f4b2..73336d9 100644 }; static struct kset *ov_kset; -@@ -455,13 +541,21 @@ int of_overlay_create(struct device_node *tree) - goto err_cancel_overlay; - } +@@ -488,6 +574,12 @@ int of_overlay_create(struct device_node *tree) + if (err) + goto err_revert_overlay; + err = sysfs_create_groups(&ov->kobj, ov->attr_groups); + if (err != 0) { @@ -202,27 +202,26 @@ index 053f4b2..73336d9 100644 + __func__, tree->full_name); + goto err_remove_kobj; + } -+ - /* add to the tail of the overlay list */ - list_add_tail(&ov->node, &ov_list); - mutex_unlock(&of_mutex); + ov->kobj.kset = ov_kset; + err = kobject_add(&ov->kobj, NULL, "%d", id); +@@ -506,6 +598,8 @@ int of_overlay_create(struct device_node *tree) return id; -- + +err_remove_kobj: + kobject_put(&ov->kobj); err_cancel_overlay: of_changeset_revert(&ov->cset); err_revert_overlay: -@@ -578,6 +672,7 @@ int of_overlay_destroy(int id) - +@@ -622,6 +716,7 @@ int of_overlay_destroy(int id) + of_overlay_notify(ov, OF_OVERLAY_PRE_REMOVE); list_del(&ov->node); + sysfs_remove_groups(&ov->kobj, ov->attr_groups); __of_changeset_revert(&ov->cset); + of_overlay_notify(ov, OF_OVERLAY_POST_REMOVE); of_free_overlay_info(ov); - idr_remove(&ov_idr, id); -- -2.9.3 +2.10.2 diff --git a/patches/drivers/ti/bbb_overlays/0026-arm-dts-Enable-beaglebone-cape-manager.patch b/patches/drivers/ti/bbb_overlays/0026-arm-dts-Enable-beaglebone-cape-manager.patch index f431cd9b39694d9667a30dc3e9b26ec9a677b9f0..4453875976b9b35c0411413b04d29e7a93f7feef 100644 --- a/patches/drivers/ti/bbb_overlays/0026-arm-dts-Enable-beaglebone-cape-manager.patch +++ b/patches/drivers/ti/bbb_overlays/0026-arm-dts-Enable-beaglebone-cape-manager.patch @@ -11,12 +11,12 @@ Signed-off-by: Pantelis Antoniou <pantelis.antoniou@konsulko.com> 1 file changed, 25 insertions(+) diff --git a/arch/arm/boot/dts/am335x-bone-common.dtsi b/arch/arm/boot/dts/am335x-bone-common.dtsi -index e247c15..d0e15df 100644 +index dc561d5..e3cb3ec 100644 --- a/arch/arm/boot/dts/am335x-bone-common.dtsi +++ b/arch/arm/boot/dts/am335x-bone-common.dtsi -@@ -393,3 +393,28 @@ - &sham { - status = "okay"; +@@ -415,3 +415,28 @@ + clocks = <&clk_32768_ck>, <&clkdiv32k_ick>; + clock-names = "ext-clk", "int-clk"; }; + +/* the cape manager */ @@ -44,5 +44,5 @@ index e247c15..d0e15df 100644 + }; +}; -- -2.9.3 +2.10.2 diff --git a/patches/drivers/ti/bbb_overlays/0027-of-overlay-Implement-target-index-support.patch b/patches/drivers/ti/bbb_overlays/0027-of-overlay-Implement-target-index-support.patch index f79f46a905106a4596575684786a5ffd71e84663..5f89401340acbf1f3c6a56c4f5f8323cf6122cff 100644 --- a/patches/drivers/ti/bbb_overlays/0027-of-overlay-Implement-target-index-support.patch +++ b/patches/drivers/ti/bbb_overlays/0027-of-overlay-Implement-target-index-support.patch @@ -26,7 +26,7 @@ Signed-off-by: Pantelis Antoniou <pantelis.antoniou@konsulko.com> 2 files changed, 53 insertions(+), 20 deletions(-) diff --git a/drivers/of/overlay.c b/drivers/of/overlay.c -index 73336d9..c6972ea 100644 +index fb2274d..5140f6b 100644 --- a/drivers/of/overlay.c +++ b/drivers/of/overlay.c @@ -77,6 +77,7 @@ struct of_overlay { @@ -37,7 +37,7 @@ index 73336d9..c6972ea 100644 }; /* master enable switch; once set to 0 can't be re-enabled */ -@@ -222,30 +223,29 @@ static int of_overlay_apply(struct of_overlay *ov) +@@ -257,30 +258,29 @@ static int of_overlay_apply(struct of_overlay *ov) /* * Find the target node using a number of different strategies @@ -75,7 +75,7 @@ index 73336d9..c6972ea 100644 return NULL; } -@@ -270,7 +270,7 @@ static int of_fill_overlay_info(struct of_overlay *ov, +@@ -305,7 +305,7 @@ static int of_fill_overlay_info(struct of_overlay *ov, if (ovinfo->overlay == NULL) goto err_fail; @@ -84,7 +84,7 @@ index 73336d9..c6972ea 100644 if (ovinfo->target == NULL) goto err_fail; -@@ -473,17 +473,8 @@ static struct kobj_type of_overlay_ktype = { +@@ -508,17 +508,8 @@ static struct kobj_type of_overlay_ktype = { static struct kset *ov_kset; @@ -104,7 +104,7 @@ index 73336d9..c6972ea 100644 { struct of_overlay *ov; int err, id; -@@ -498,6 +489,8 @@ int of_overlay_create(struct device_node *tree) +@@ -533,6 +524,8 @@ int of_overlay_create(struct device_node *tree) return -ENOMEM; ov->id = -1; @@ -113,7 +113,7 @@ index 73336d9..c6972ea 100644 INIT_LIST_HEAD(&ov->node); of_changeset_init(&ov->cset); -@@ -570,8 +563,40 @@ err_destroy_trans: +@@ -614,8 +607,40 @@ int of_overlay_create(struct device_node *tree) return err; } @@ -155,20 +155,20 @@ index 73336d9..c6972ea 100644 static int overlay_subtree_check(struct device_node *tree, struct device_node *dn) diff --git a/include/linux/of.h b/include/linux/of.h -index 6617d23..5cd40eb 100644 +index c50f088..d9d9537 100644 --- a/include/linux/of.h +++ b/include/linux/of.h -@@ -1490,6 +1490,8 @@ int of_overlay_create(struct device_node *tree); - int of_overlay_destroy(int id); - int of_overlay_destroy_all(void); +@@ -1625,6 +1625,8 @@ int of_overlay_destroy_all(void); + int of_overlay_notifier_register(struct notifier_block *nb); + int of_overlay_notifier_unregister(struct notifier_block *nb); +int of_overlay_create_target_index(struct device_node *tree, int index); + #else static inline int of_overlay_create(struct device_node *tree) -@@ -1507,6 +1509,12 @@ static inline int of_overlay_destroy_all(void) - return -ENOTSUPP; +@@ -1652,6 +1654,12 @@ static inline int of_overlay_notifier_unregister(struct notifier_block *nb) + return 0; } +static inline int of_overlay_create_target_index(struct device_node *tree, @@ -181,5 +181,5 @@ index 6617d23..5cd40eb 100644 #endif /* _LINUX_OF_H */ -- -2.9.3 +2.10.2 diff --git a/patches/drivers/ti/bbb_overlays/0030-of-overlay-Introduce-target-root-capability.patch b/patches/drivers/ti/bbb_overlays/0030-of-overlay-Introduce-target-root-capability.patch index 29730220f7f01209f96e1c575bf7793e7c9a11b8..f50bcfcd5cb51725895b56df9f1aa7749b3cdeff 100644 --- a/patches/drivers/ti/bbb_overlays/0030-of-overlay-Introduce-target-root-capability.patch +++ b/patches/drivers/ti/bbb_overlays/0030-of-overlay-Introduce-target-root-capability.patch @@ -22,7 +22,7 @@ Signed-off-by: Pantelis Antoniou <pantelis.antoniou@konsulko.com> 2 files changed, 102 insertions(+), 7 deletions(-) diff --git a/drivers/of/overlay.c b/drivers/of/overlay.c -index c6972ea..722350b 100644 +index 5140f6b..71a705a 100644 --- a/drivers/of/overlay.c +++ b/drivers/of/overlay.c @@ -78,6 +78,7 @@ struct of_overlay { @@ -33,7 +33,7 @@ index c6972ea..722350b 100644 }; /* master enable switch; once set to 0 can't be re-enabled */ -@@ -231,22 +232,85 @@ static int of_overlay_apply(struct of_overlay *ov) +@@ -266,22 +267,85 @@ static int of_overlay_apply(struct of_overlay *ov) static struct device_node *find_target_node(struct of_overlay *ov, struct device_node *info_node, int index) { @@ -123,7 +123,7 @@ index c6972ea..722350b 100644 } /** -@@ -418,6 +482,7 @@ void of_overlay_release(struct kobject *kobj) +@@ -453,6 +517,7 @@ void of_overlay_release(struct kobject *kobj) { struct of_overlay *ov = kobj_to_overlay(kobj); @@ -131,7 +131,7 @@ index c6972ea..722350b 100644 kfree(ov); } -@@ -474,7 +539,7 @@ static struct kobj_type of_overlay_ktype = { +@@ -509,7 +574,7 @@ static struct kobj_type of_overlay_ktype = { static struct kset *ov_kset; static int __of_overlay_create(struct device_node *tree, @@ -140,7 +140,7 @@ index c6972ea..722350b 100644 { struct of_overlay *ov; int err, id; -@@ -490,6 +555,7 @@ static int __of_overlay_create(struct device_node *tree, +@@ -525,6 +590,7 @@ static int __of_overlay_create(struct device_node *tree, ov->id = -1; ov->target_index = target_index; @@ -148,7 +148,7 @@ index c6972ea..722350b 100644 INIT_LIST_HEAD(&ov->node); -@@ -558,6 +624,7 @@ err_free_idr: +@@ -602,6 +668,7 @@ static int __of_overlay_create(struct device_node *tree, idr_remove(&ov_idr, ov->id); err_destroy_trans: of_changeset_destroy(&ov->cset); @@ -156,7 +156,7 @@ index c6972ea..722350b 100644 kfree(ov); mutex_unlock(&of_mutex); -@@ -576,7 +643,7 @@ err_destroy_trans: +@@ -620,7 +687,7 @@ static int __of_overlay_create(struct device_node *tree, */ int of_overlay_create(struct device_node *tree) { @@ -165,7 +165,7 @@ index c6972ea..722350b 100644 } EXPORT_SYMBOL_GPL(of_overlay_create); -@@ -593,10 +660,30 @@ EXPORT_SYMBOL_GPL(of_overlay_create); +@@ -637,10 +704,30 @@ EXPORT_SYMBOL_GPL(of_overlay_create); */ int of_overlay_create_target_index(struct device_node *tree, int index) { @@ -198,11 +198,11 @@ index c6972ea..722350b 100644 static int overlay_subtree_check(struct device_node *tree, struct device_node *dn) diff --git a/include/linux/of.h b/include/linux/of.h -index 5cd40eb..672539c 100644 +index d9d9537..09693b9 100644 --- a/include/linux/of.h +++ b/include/linux/of.h -@@ -1491,6 +1491,8 @@ int of_overlay_destroy(int id); - int of_overlay_destroy_all(void); +@@ -1626,6 +1626,8 @@ int of_overlay_notifier_register(struct notifier_block *nb); + int of_overlay_notifier_unregister(struct notifier_block *nb); int of_overlay_create_target_index(struct device_node *tree, int index); +int of_overlay_create_target_root(struct device_node *tree, @@ -210,7 +210,7 @@ index 5cd40eb..672539c 100644 #else -@@ -1515,6 +1517,12 @@ static inline int of_overlay_create_target_index(struct device_node *tree, +@@ -1660,6 +1662,12 @@ static inline int of_overlay_create_target_index(struct device_node *tree, return -ENOTSUPP; } @@ -224,5 +224,5 @@ index 5cd40eb..672539c 100644 #endif /* _LINUX_OF_H */ -- -2.9.3 +2.10.2 diff --git a/patches/drivers/ti/iodelay/0002-pinctrl-Introduce-TI-IOdelay-configuration-driver.patch b/patches/drivers/ti/iodelay/0002-pinctrl-Introduce-TI-IOdelay-configuration-driver.patch index 533190c872f3cf0ef1bb0fe4fb59ec3cf531d78e..00909292b882051818879485659479c8c670963d 100644 --- a/patches/drivers/ti/iodelay/0002-pinctrl-Introduce-TI-IOdelay-configuration-driver.patch +++ b/patches/drivers/ti/iodelay/0002-pinctrl-Introduce-TI-IOdelay-configuration-driver.patch @@ -60,10 +60,10 @@ Signed-off-by: Lokesh Vutla <lokeshvutla@ti.com> create mode 100644 drivers/pinctrl/pinctrl-ti-iodelay.c diff --git a/drivers/pinctrl/Kconfig b/drivers/pinctrl/Kconfig -index b3fe1d3..6f9a380 100644 +index 54044a8..b43b6e7 100644 --- a/drivers/pinctrl/Kconfig +++ b/drivers/pinctrl/Kconfig -@@ -179,6 +179,18 @@ config PINCTRL_ST +@@ -203,6 +203,18 @@ config PINCTRL_ST select PINCONF select GPIOLIB_IRQCHIP @@ -83,12 +83,12 @@ index b3fe1d3..6f9a380 100644 bool "Toumaz Xenif TZ1090 pin control driver" depends on SOC_TZ1090 diff --git a/drivers/pinctrl/Makefile b/drivers/pinctrl/Makefile -index 8ebd7b8..499eb1e 100644 +index 25d50a8..25e1ec46 100644 --- a/drivers/pinctrl/Makefile +++ b/drivers/pinctrl/Makefile -@@ -26,6 +26,7 @@ obj-$(CONFIG_PINCTRL_ROCKCHIP) += pinctrl-rockchip.o - obj-$(CONFIG_PINCTRL_SINGLE) += pinctrl-single.o +@@ -28,6 +28,7 @@ obj-$(CONFIG_PINCTRL_SINGLE) += pinctrl-single.o obj-$(CONFIG_PINCTRL_SIRF) += sirf/ + obj-$(CONFIG_PINCTRL_SX150X) += pinctrl-sx150x.o obj-$(CONFIG_ARCH_TEGRA) += tegra/ +obj-$(CONFIG_PINCTRL_TI_IODELAY)+= pinctrl-ti-iodelay.o obj-$(CONFIG_PINCTRL_TZ1090) += pinctrl-tz1090.o @@ -1092,5 +1092,5 @@ index 5c75e80..5a60e3b 100644 #endif -- -2.9.3 +2.10.2 diff --git a/patches/drivers/ti/mcasp/0001-ASoC-add-generic-TDM-codec.patch b/patches/drivers/ti/mcasp/0001-ASoC-add-generic-TDM-codec.patch index 5983777c15b100f3da813dd158fef51bdba00f45..7a26170e75895954f2ed04753a32e4a191d56d1c 100644 --- a/patches/drivers/ti/mcasp/0001-ASoC-add-generic-TDM-codec.patch +++ b/patches/drivers/ti/mcasp/0001-ASoC-add-generic-TDM-codec.patch @@ -1,21 +1,21 @@ -From 91cf06d33c5eb019b1fbecd411bcaaf9f497b788 Mon Sep 17 00:00:00 2001 +From c91761fab292fe91583b9b597d431d088d123336 Mon Sep 17 00:00:00 2001 From: Matthijs van Duin <matthijsvanduin@gmail.com> Date: Mon, 1 Feb 2016 08:21:08 +0100 -Subject: [PATCH] ASoC: add generic TDM codec +Subject: [PATCH 1/2] ASoC: add generic TDM codec Signed-off-by: Matthijs van Duin <matthijsvanduin@gmail.com> --- sound/soc/codecs/Kconfig | 4 ++ sound/soc/codecs/Makefile | 2 + - sound/soc/codecs/tdm.c | 112 ++++++++++++++++++++++++++++++++++++++++++++++ - 3 files changed, 118 insertions(+) + sound/soc/codecs/tdm.c | 110 ++++++++++++++++++++++++++++++++++++++++++++++ + 3 files changed, 116 insertions(+) create mode 100644 sound/soc/codecs/tdm.c diff --git a/sound/soc/codecs/Kconfig b/sound/soc/codecs/Kconfig -index c67667bb970f..0f40b095ddb8 100644 +index cfdafc4..917cc40 100644 --- a/sound/soc/codecs/Kconfig +++ b/sound/soc/codecs/Kconfig -@@ -135,6 +135,7 @@ config SND_SOC_ALL_CODECS +@@ -112,6 +112,7 @@ config SND_SOC_ALL_CODECS select SND_SOC_TAS5086 if I2C select SND_SOC_TAS571X if I2C select SND_SOC_TAS5720 if I2C @@ -23,7 +23,7 @@ index c67667bb970f..0f40b095ddb8 100644 select SND_SOC_TFA9879 if I2C select SND_SOC_TLV320AIC23_I2C if I2C select SND_SOC_TLV320AIC23_SPI if SPI_MASTER -@@ -812,6 +813,9 @@ config SND_SOC_TAS5720 +@@ -656,6 +657,9 @@ config SND_SOC_TAS5720 Enable support for Texas Instruments TAS5720L/M high-efficiency mono Class-D audio power amplifiers. @@ -34,10 +34,10 @@ index c67667bb970f..0f40b095ddb8 100644 tristate "NXP Semiconductors TFA9879 amplifier" depends on I2C diff --git a/sound/soc/codecs/Makefile b/sound/soc/codecs/Makefile -index 958cd4912fbc..ea82c79333ea 100644 +index f632fc4..a47d48d 100644 --- a/sound/soc/codecs/Makefile +++ b/sound/soc/codecs/Makefile -@@ -142,6 +142,7 @@ snd-soc-sti-sas-objs := sti-sas.o +@@ -115,6 +115,7 @@ snd-soc-sti-sas-objs := sti-sas.o snd-soc-tas5086-objs := tas5086.o snd-soc-tas571x-objs := tas571x.o snd-soc-tas5720-objs := tas5720.o @@ -45,7 +45,7 @@ index 958cd4912fbc..ea82c79333ea 100644 snd-soc-tfa9879-objs := tfa9879.o snd-soc-tlv320aic23-objs := tlv320aic23.o snd-soc-tlv320aic23-i2c-objs := tlv320aic23-i2c.o -@@ -363,6 +364,7 @@ obj-$(CONFIG_SND_SOC_TAS2552) += snd-soc-tas2552.o +@@ -307,6 +308,7 @@ obj-$(CONFIG_SND_SOC_TAS2552) += snd-soc-tas2552.o obj-$(CONFIG_SND_SOC_TAS5086) += snd-soc-tas5086.o obj-$(CONFIG_SND_SOC_TAS571X) += snd-soc-tas571x.o obj-$(CONFIG_SND_SOC_TAS5720) += snd-soc-tas5720.o @@ -55,10 +55,10 @@ index 958cd4912fbc..ea82c79333ea 100644 obj-$(CONFIG_SND_SOC_TLV320AIC23_I2C) += snd-soc-tlv320aic23-i2c.o diff --git a/sound/soc/codecs/tdm.c b/sound/soc/codecs/tdm.c new file mode 100644 -index 000000000000..b8fb3b8d0177 +index 0000000..f20d3e2 --- /dev/null +++ b/sound/soc/codecs/tdm.c -@@ -0,0 +1,112 @@ +@@ -0,0 +1,110 @@ +/* + * ALSA SoC generic TDM codec driver + * @@ -110,12 +110,10 @@ index 000000000000..b8fb3b8d0177 +}; + +static struct snd_soc_codec_driver soc_codec_tdm_audio = { -+ .component_driver = { -+ .dapm_widgets = tdm_audio_widgets, -+ .num_dapm_widgets = ARRAY_SIZE(tdm_audio_widgets), -+ .dapm_routes = tdm_audio_routes, -+ .num_dapm_routes = ARRAY_SIZE(tdm_audio_routes), -+ }, ++ .dapm_widgets = tdm_audio_widgets, ++ .num_dapm_widgets = ARRAY_SIZE(tdm_audio_widgets), ++ .dapm_routes = tdm_audio_routes, ++ .num_dapm_routes = ARRAY_SIZE(tdm_audio_routes), +}; + +static struct snd_soc_dai_driver tdm_audio_dai = { @@ -172,5 +170,5 @@ index 000000000000..b8fb3b8d0177 +MODULE_LICENSE("GPL"); +MODULE_ALIAS("platform:" DRV_NAME); -- -2.10.2 +2.6.4 diff --git a/patches/drivers/ti/mmc/0001-mmc-use-of_alias-for-device-numbering.patch b/patches/drivers/ti/mmc/0001-mmc-use-of_alias-for-device-numbering.patch index 2bb8fb9da0a9e44190402c6d3c09468f5dd0bb5f..ab8213ea09e8bfdc7a6c5d384c7d2a10cf4beeba 100644 --- a/patches/drivers/ti/mmc/0001-mmc-use-of_alias-for-device-numbering.patch +++ b/patches/drivers/ti/mmc/0001-mmc-use-of_alias-for-device-numbering.patch @@ -5,14 +5,14 @@ Subject: [PATCH] mmc: use of_alias for device numbering Signed-off-by: Matthijs van Duin <matthijsvanduin@gmail.com> --- - drivers/mmc/card/block.c | 10 +++++++++- + drivers/mmc/core/block.c | 10 +++++++++- drivers/mmc/core/host.c | 13 ++++++++++++- 2 files changed, 21 insertions(+), 2 deletions(-) -diff --git a/drivers/mmc/card/block.c b/drivers/mmc/card/block.c -index c5472e3..f87c8dc 100644 ---- a/drivers/mmc/card/block.c -+++ b/drivers/mmc/card/block.c +diff --git a/drivers/mmc/core/block.c b/drivers/mmc/core/block.c +index bab3f07..92f183f 100644 +--- a/drivers/mmc/core/block.c ++++ b/drivers/mmc/core/block.c @@ -36,6 +36,7 @@ #include <linux/compat.h> #include <linux/pm_runtime.h> @@ -21,7 +21,7 @@ index c5472e3..f87c8dc 100644 #include <linux/mmc/ioctl.h> #include <linux/mmc/card.h> -@@ -2216,13 +2217,20 @@ static struct mmc_blk_data *mmc_blk_alloc_req(struct mmc_card *card, +@@ -1820,13 +1821,20 @@ static struct mmc_blk_data *mmc_blk_alloc_req(struct mmc_card *card, { struct mmc_blk_data *md; int devidx, ret; @@ -44,10 +44,10 @@ index c5472e3..f87c8dc 100644 if (ret == -EAGAIN) diff --git a/drivers/mmc/core/host.c b/drivers/mmc/core/host.c -index 1be42fa..b9e2365 100644 +index 98f25ff..9c211c5 100644 --- a/drivers/mmc/core/host.c +++ b/drivers/mmc/core/host.c -@@ -338,6 +338,8 @@ struct mmc_host *mmc_alloc_host(int extra, struct device *dev) +@@ -346,6 +346,8 @@ struct mmc_host *mmc_alloc_host(int extra, struct device *dev) { int err; struct mmc_host *host; @@ -56,7 +56,7 @@ index 1be42fa..b9e2365 100644 host = kzalloc(sizeof(struct mmc_host) + extra, GFP_KERNEL); if (!host) -@@ -353,7 +355,16 @@ again: +@@ -361,7 +363,16 @@ struct mmc_host *mmc_alloc_host(int extra, struct device *dev) } spin_lock(&mmc_host_lock); @@ -75,5 +75,5 @@ index 1be42fa..b9e2365 100644 if (err == -EAGAIN) { -- -2.8.1 +2.10.2 diff --git a/patches/drivers/ti/omapdrm/0001-drm-omap-tpd12s015-fix-error-handling.patch b/patches/drivers/ti/omapdrm/0001-drm-omap-tpd12s015-fix-error-handling.patch deleted file mode 100644 index 7251e262875754700c96e235e5d00db581c84e3c..0000000000000000000000000000000000000000 --- a/patches/drivers/ti/omapdrm/0001-drm-omap-tpd12s015-fix-error-handling.patch +++ /dev/null @@ -1,56 +0,0 @@ -From 1e59e7b2d21b0423ceaa6d72f43834d3b04ef8d9 Mon Sep 17 00:00:00 2001 -From: Tomi Valkeinen <tomi.valkeinen@ti.com> -Date: Tue, 22 Nov 2016 10:11:07 +0200 -Subject: [PATCH] drm/omap: tpd12s015: fix error handling - -tpd12s015 driver is missing error value handling for gpio -initialization, causing 0 to be returned as an error if gpiod_get_* -fails. This may cause deferred probing to fail. - -Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com> ---- - drivers/gpu/drm/omapdrm/displays/encoder-tpd12s015.c | 13 +++++++++---- - 1 file changed, 9 insertions(+), 4 deletions(-) - -diff --git a/drivers/gpu/drm/omapdrm/displays/encoder-tpd12s015.c b/drivers/gpu/drm/omapdrm/displays/encoder-tpd12s015.c -index 46855c8..d189426 100644 ---- a/drivers/gpu/drm/omapdrm/displays/encoder-tpd12s015.c -+++ b/drivers/gpu/drm/omapdrm/displays/encoder-tpd12s015.c -@@ -234,25 +234,30 @@ static int tpd_probe(struct platform_device *pdev) - if (r) - return r; - -- - gpio = devm_gpiod_get_index_optional(&pdev->dev, NULL, 0, - GPIOD_OUT_LOW); -- if (IS_ERR(gpio)) -+ if (IS_ERR(gpio)) { -+ r = PTR_ERR(gpio); - goto err_gpio; -+ } - - ddata->ct_cp_hpd_gpio = gpio; - - gpio = devm_gpiod_get_index_optional(&pdev->dev, NULL, 1, - GPIOD_OUT_LOW); -- if (IS_ERR(gpio)) -+ if (IS_ERR(gpio)) { -+ r = PTR_ERR(gpio); - goto err_gpio; -+ } - - ddata->ls_oe_gpio = gpio; - - gpio = devm_gpiod_get_index(&pdev->dev, NULL, 2, - GPIOD_IN); -- if (IS_ERR(gpio)) -+ if (IS_ERR(gpio)) { -+ r = PTR_ERR(gpio); - goto err_gpio; -+ } - - ddata->hpd_gpio = gpio; - --- -2.10.2 - diff --git a/patches/drivers/ti/rpmsg/0001-ARM-samples-seccomp-no-m32.patch b/patches/drivers/ti/rpmsg/0001-ARM-samples-seccomp-no-m32.patch index 766a7a3a53fb77760d4524306a74e1a9afd3d050..40ca8362a92b2ef7e4e410fe1e54d350fb4a4235 100644 --- a/patches/drivers/ti/rpmsg/0001-ARM-samples-seccomp-no-m32.patch +++ b/patches/drivers/ti/rpmsg/0001-ARM-samples-seccomp-no-m32.patch @@ -9,7 +9,7 @@ Signed-off-by: Robert Nelson <robertcnelson@gmail.com> 1 file changed, 2 insertions(+) diff --git a/samples/seccomp/Makefile b/samples/seccomp/Makefile -index ae7ff6f..7659beb 100644 +index bf7cc6b..edb3fab 100644 --- a/samples/seccomp/Makefile +++ b/samples/seccomp/Makefile @@ -20,6 +20,7 @@ bpf-direct-objs := bpf-direct.o @@ -21,10 +21,10 @@ index ae7ff6f..7659beb 100644 # s390 has -m31 flag to build 31 bit binaries ifndef CONFIG_S390 @@ -46,3 +47,4 @@ ifndef CONFIG_MIPS - always := $(hostprogs-y) + always := $(hostprogs-m) endif endif +endif -- -2.9.3 +2.10.2 diff --git a/patches/drivers/ti/rtc/0001-ARM-am335x-don-t-reset-or-idle-the-rtc-on-init.patch b/patches/drivers/ti/rtc/0001-ARM-am335x-don-t-reset-or-idle-the-rtc-on-init.patch deleted file mode 100644 index 12e2e4fe73abd3f0f00db8cee3e977e371694229..0000000000000000000000000000000000000000 --- a/patches/drivers/ti/rtc/0001-ARM-am335x-don-t-reset-or-idle-the-rtc-on-init.patch +++ /dev/null @@ -1,30 +0,0 @@ -From 6e7d33d02124e52978748ddd9627fdea21ac7d92 Mon Sep 17 00:00:00 2001 -From: Matthijs van Duin <matthijsvanduin@gmail.com> -Date: Fri, 9 Sep 2016 18:51:21 +0200 -Subject: [PATCH] ARM: am335x: don't reset or idle the rtc on init - -This fixes a bus error in omap_hwmod_read called from -omap_rtc_wait_not_busy. The root cause probably lies elsewhere however -and should be investigated. - -Signed-off-by: Matthijs van Duin <matthijsvanduin@gmail.com> ---- - arch/arm/boot/dts/am33xx.dtsi | 2 ++ - 1 file changed, 2 insertions(+) - -diff --git a/arch/arm/boot/dts/am33xx.dtsi b/arch/arm/boot/dts/am33xx.dtsi -index 2bbfa1fe9e93..5b31a06b2fe8 100644 ---- a/arch/arm/boot/dts/am33xx.dtsi -+++ b/arch/arm/boot/dts/am33xx.dtsi -@@ -583,6 +583,8 @@ - interrupts = <75 - 76>; - ti,hwmods = "rtc"; -+ ti,no-reset-on-init; -+ ti,no-idle-on-init; - }; - - spi0: spi@48030000 { --- -2.9.3 - diff --git a/patches/drivers/ti/sgx/0001-HACK-drm-fb_helper-enable-panning-support.patch b/patches/drivers/ti/sgx/0001-HACK-drm-fb_helper-enable-panning-support.patch deleted file mode 100644 index 5930beba5284aa0d47094df9a50143240a6f42f0..0000000000000000000000000000000000000000 --- a/patches/drivers/ti/sgx/0001-HACK-drm-fb_helper-enable-panning-support.patch +++ /dev/null @@ -1,51 +0,0 @@ -From 2e65df6fb029057b8e2f6981291c3b683c8663c0 Mon Sep 17 00:00:00 2001 -From: Darren Etheridge <detheridge@ti.com> -Date: Thu, 24 Jul 2014 11:49:28 -0500 -Subject: [PATCH 1/6] HACK: drm/fb_helper: enable panning support - -Increase the size of the buffer that is created in the fbdev emulation -helpers. And fill in the var structure with the amount that was allocated. - -Signed-off-by: Darren Etheridge <detheridge@ti.com> ---- - drivers/gpu/drm/drm_fb_cma_helper.c | 10 ++++++++-- - 1 file changed, 8 insertions(+), 2 deletions(-) - -diff --git a/drivers/gpu/drm/drm_fb_cma_helper.c b/drivers/gpu/drm/drm_fb_cma_helper.c -index 1fd6eac..843163e 100644 ---- a/drivers/gpu/drm/drm_fb_cma_helper.c -+++ b/drivers/gpu/drm/drm_fb_cma_helper.c -@@ -28,6 +28,12 @@ - - #define DEFAULT_FBDEFIO_DELAY_MS 50 - -+/* -+ * number of buffers to allocate from CMA pool, often increased for -+ * double/triple buffering -+ */ -+#define DRM_NUM_FBDEV_BUFFERS 3 -+ - struct drm_fb_cma { - struct drm_framebuffer fb; - struct drm_gem_cma_object *obj[4]; -@@ -403,7 +409,7 @@ int drm_fbdev_cma_create_with_funcs(struct drm_fb_helper *helper, - bytes_per_pixel = DIV_ROUND_UP(sizes->surface_bpp, 8); - - mode_cmd.width = sizes->surface_width; -- mode_cmd.height = sizes->surface_height; -+ mode_cmd.height = sizes->surface_height * DRM_NUM_FBDEV_BUFFERS; - mode_cmd.pitches[0] = sizes->surface_width * bytes_per_pixel; - mode_cmd.pixel_format = drm_mode_legacy_fb_format(sizes->surface_bpp, - sizes->surface_depth); -@@ -434,7 +440,7 @@ int drm_fbdev_cma_create_with_funcs(struct drm_fb_helper *helper, - fbi->fbops = &drm_fbdev_cma_ops; - - drm_fb_helper_fill_fix(fbi, fb->pitches[0], fb->depth); -- drm_fb_helper_fill_var(fbi, helper, sizes->fb_width, sizes->fb_height); -+ drm_fb_helper_fill_var(fbi, helper, sizes->fb_width, sizes->surface_height); - - offset = fbi->var.xoffset * bytes_per_pixel; - offset += fbi->var.yoffset * fb->pitches[0]; --- -2.10.2 - diff --git a/patches/drivers/ti/sgx/0002-HACK-drm-tilcdc-add-vsync-callback-for-use-in-omaplf.patch b/patches/drivers/ti/sgx/0002-HACK-drm-tilcdc-add-vsync-callback-for-use-in-omaplf.patch deleted file mode 100644 index 29901ae514e9e02a7c54762badc7f5934f6cc5a5..0000000000000000000000000000000000000000 --- a/patches/drivers/ti/sgx/0002-HACK-drm-tilcdc-add-vsync-callback-for-use-in-omaplf.patch +++ /dev/null @@ -1,95 +0,0 @@ -From 954e7d5791ff176f3b046575a8465c880d4eb536 Mon Sep 17 00:00:00 2001 -From: Darren Etheridge <detheridge@ti.com> -Date: Fri, 11 Jul 2014 09:15:25 -0500 -Subject: [PATCH 2/6] HACK: drm/tilcdc: add vsync callback for use in omaplfb - for gpu - -Add a vsync callback registration API that is identical to what was done -for da8xx-fb.c. - -Need to find if there is a better way using the DRM infrastructure from -kernel space. Either that or change the userspace window manager stuff in -the gpu libraries to make use of the DRM provided syncronization -mechanisms. - -Signed-off-by: Darren Etheridge <detheridge@ti.com> ---- - drivers/gpu/drm/tilcdc/tilcdc_crtc.c | 33 +++++++++++++++++++++++++++++++++ - drivers/gpu/drm/tilcdc/tilcdc_drv.h | 5 +++++ - 2 files changed, 38 insertions(+) - -diff --git a/drivers/gpu/drm/tilcdc/tilcdc_crtc.c b/drivers/gpu/drm/tilcdc/tilcdc_crtc.c -index 52ebe8f..062c4d7 100644 ---- a/drivers/gpu/drm/tilcdc/tilcdc_crtc.c -+++ b/drivers/gpu/drm/tilcdc/tilcdc_crtc.c -@@ -54,6 +54,10 @@ struct tilcdc_crtc { - int sync_lost_count; - bool frame_intact; - }; -+ -+static vsync_callback_t vsync_cb_handler; -+static void *vsync_cb_arg; -+ - #define to_tilcdc_crtc(x) container_of(x, struct tilcdc_crtc, base) - - static void unref_worker(struct drm_flip_work *work, void *val) -@@ -703,6 +707,32 @@ void tilcdc_crtc_update_clk(struct drm_crtc *crtc) - - #define SYNC_LOST_COUNT_LIMIT 50 - -+int register_vsync_cb(vsync_callback_t handler, void *arg, int idx) -+{ -+ if ((vsync_cb_handler == NULL) && (vsync_cb_arg == NULL)) { -+ vsync_cb_arg = arg; -+ vsync_cb_handler = handler; -+ } else { -+ return -EEXIST; -+ } -+ -+ return 0; -+} -+EXPORT_SYMBOL(register_vsync_cb); -+ -+int unregister_vsync_cb(vsync_callback_t handler, void *arg, int idx) -+{ -+ if ((vsync_cb_handler == handler) && (vsync_cb_arg == arg)) { -+ vsync_cb_handler = NULL; -+ vsync_cb_arg = NULL; -+ } else { -+ return -ENXIO; -+ } -+ -+ return 0; -+} -+EXPORT_SYMBOL(unregister_vsync_cb); -+ - irqreturn_t tilcdc_crtc_irq(struct drm_crtc *crtc) - { - struct tilcdc_crtc *tilcdc_crtc = to_tilcdc_crtc(crtc); -@@ -746,6 +776,9 @@ irqreturn_t tilcdc_crtc_irq(struct drm_crtc *crtc) - if (event) - drm_crtc_send_vblank_event(crtc, event); - -+ if (vsync_cb_handler) -+ vsync_cb_handler(vsync_cb_arg); -+ - spin_unlock_irqrestore(&dev->event_lock, flags); - } - -diff --git a/drivers/gpu/drm/tilcdc/tilcdc_drv.h b/drivers/gpu/drm/tilcdc/tilcdc_drv.h -index 9780c37..3c62b3a 100644 ---- a/drivers/gpu/drm/tilcdc/tilcdc_drv.h -+++ b/drivers/gpu/drm/tilcdc/tilcdc_drv.h -@@ -179,4 +179,9 @@ int tilcdc_crtc_update_fb(struct drm_crtc *crtc, - - int tilcdc_plane_init(struct drm_device *dev, struct drm_plane *plane); - -+/* used by SGX OMAPLFB drvier */ -+typedef void (*vsync_callback_t)(void *arg); -+int register_vsync_cb(vsync_callback_t handler, void *arg, int idx); -+int unregister_vsync_cb(vsync_callback_t handler, void *arg, int idx); -+ - #endif /* __TILCDC_DRV_H__ */ --- -2.10.2 - diff --git a/patches/drivers/ti/sgx/0003-ARM-OMAP2-Use-pdata-quirks-for-sgx-deassert_hardrese.patch b/patches/drivers/ti/sgx/0003-ARM-OMAP2-Use-pdata-quirks-for-sgx-deassert_hardrese.patch deleted file mode 100644 index 05ccdfb309300d21d4b91819e82d2bf3ada38135..0000000000000000000000000000000000000000 --- a/patches/drivers/ti/sgx/0003-ARM-OMAP2-Use-pdata-quirks-for-sgx-deassert_hardrese.patch +++ /dev/null @@ -1,86 +0,0 @@ -From 3f25636595e55d60bcbeb379c06b13969a2721dd Mon Sep 17 00:00:00 2001 -From: Darren Etheridge <detheridge@ti.com> -Date: Fri, 25 Jul 2014 16:09:53 -0500 -Subject: [PATCH 3/6] ARM: OMAP2+: Use pdata-quirks for sgx deassert_hardreset - -Use pdata_quirks to provide platform data to the sgx driver. -The data that is provided includes: - -1) Function pointers for the driver to use to reset the h/w block. -2) The reset name that matches with what is used in hwmod. - -Signed-off-by: Darren Etheridge <detheridge@ti.com> ---- - arch/arm/mach-omap2/pdata-quirks.c | 12 ++++++++++++ - include/linux/platform_data/sgx-omap.h | 22 ++++++++++++++++++++++ - 2 files changed, 34 insertions(+) - create mode 100644 include/linux/platform_data/sgx-omap.h - -diff --git a/arch/arm/mach-omap2/pdata-quirks.c b/arch/arm/mach-omap2/pdata-quirks.c -index 05e20aa..964598f6 100644 ---- a/arch/arm/mach-omap2/pdata-quirks.c -+++ b/arch/arm/mach-omap2/pdata-quirks.c -@@ -25,6 +25,7 @@ - #include <linux/platform_data/iommu-omap.h> - #include <linux/platform_data/wkup_m3.h> - #include <linux/platform_data/pwm_omap_dmtimer.h> -+#include <linux/platform_data/sgx-omap.h> - #include <linux/platform_data/media/ir-rx51.h> - #include <linux/platform_data/asoc-ti-mcbsp.h> - #include <plat/dmtimer.h> -@@ -49,6 +50,13 @@ struct pdata_init { - static struct of_dev_auxdata omap_auxdata_lookup[]; - static struct twl4030_gpio_platform_data twl_gpio_auxdata; - -+#if defined(CONFIG_SOC_AM33XX) || defined(CONFIG_SOC_AM43XX) -+static struct gfx_sgx_platform_data gfx_pdata = { -+ .reset_name = "gfx", -+ .deassert_reset = omap_device_deassert_hardreset, -+}; -+#endif -+ - #ifdef CONFIG_MACH_NOKIA_N8X0 - static void __init omap2420_n8x0_legacy_init(void) - { -@@ -553,6 +561,10 @@ static struct of_dev_auxdata omap_auxdata_lookup[] __initdata = { - OF_DEV_AUXDATA("ti,am4372-wkup-m3", 0x44d00000, "44d00000.wkup_m3", - &wkup_m3_data), - #endif -+#if defined(CONFIG_SOC_AM33XX) || defined(CONFIG_SOC_AM43XX) -+ OF_DEV_AUXDATA("ti,sgx", 0x56000000, "56000000.sgx", -+ &gfx_pdata), -+#endif - #if IS_ENABLED(CONFIG_OMAP_DM_TIMER) - OF_DEV_AUXDATA("ti,omap-dmtimer-pwm", 0, NULL, &pwm_dmtimer_pdata), - #endif -diff --git a/include/linux/platform_data/sgx-omap.h b/include/linux/platform_data/sgx-omap.h -new file mode 100644 -index 0000000..aa59b2c ---- /dev/null -+++ b/include/linux/platform_data/sgx-omap.h -@@ -0,0 +1,22 @@ -+/* -+ * SGX Graphics Driver Platform Data -+ * -+ * Copyright (C) 2014 Texas Instruments Incorporated - http://www.ti.com/ -+ * Darren Etheridge <detheridge@ti.com> -+ * -+ * 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. -+ * -+ * This program is distributed "as is" WITHOUT ANY WARRANTY of any -+ * kind, whether express or implied; without even the implied warranty -+ * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -+ * GNU General Public License for more details. -+ */ -+#include <linux/platform_device.h> -+ -+struct gfx_sgx_platform_data { -+ const char *reset_name; -+ -+ int (*deassert_reset)(struct platform_device *pdev, const char *name); -+}; --- -2.10.2 - diff --git a/patches/drivers/ti/sgx/0004-ARM-dts-am33xx-add-DT-node-for-gpu.patch b/patches/drivers/ti/sgx/0004-ARM-dts-am33xx-add-DT-node-for-gpu.patch deleted file mode 100644 index 8b0b469b44c4dbc3dec88b38cb3ed513895d9131..0000000000000000000000000000000000000000 --- a/patches/drivers/ti/sgx/0004-ARM-dts-am33xx-add-DT-node-for-gpu.patch +++ /dev/null @@ -1,34 +0,0 @@ -From 20171b32feee4ebc11339e95cc9664fd43123d95 Mon Sep 17 00:00:00 2001 -From: Darren Etheridge <detheridge@ti.com> -Date: Fri, 18 Jul 2014 16:19:54 -0500 -Subject: [PATCH 4/6] ARM: dts: am33xx: add DT node for gpu - -Add the node into the am33xx.dtsi file for the SGX GPU -that is found in some variants of the SoC. - -Signed-off-by: Darren Etheridge <detheridge@ti.com> ---- - arch/arm/boot/dts/am33xx.dtsi | 7 +++++++ - 1 file changed, 7 insertions(+) - -diff --git a/arch/arm/boot/dts/am33xx.dtsi b/arch/arm/boot/dts/am33xx.dtsi -index 3f609c8..0117413 100644 ---- a/arch/arm/boot/dts/am33xx.dtsi -+++ b/arch/arm/boot/dts/am33xx.dtsi -@@ -1048,6 +1048,13 @@ - reg = <0x48310000 0x2000>; - interrupts = <111>; - }; -+ -+ sgx@0x56000000 { -+ compatible = "ti,sgx"; -+ ti,hwmods = "gfx"; -+ reg = <0x56000000 0x1000000>; -+ interrupts = <37>; -+ }; - }; - }; - --- -2.10.2 - diff --git a/patches/drivers/ti/sgx/0005-Revert-ARM-reduce-visibility-of-dmac_-functions.patch b/patches/drivers/ti/sgx/0005-Revert-ARM-reduce-visibility-of-dmac_-functions.patch deleted file mode 100644 index 08e04307df29c2f412f906fa6bf8312faa0adf38..0000000000000000000000000000000000000000 --- a/patches/drivers/ti/sgx/0005-Revert-ARM-reduce-visibility-of-dmac_-functions.patch +++ /dev/null @@ -1,104 +0,0 @@ -From df2d6cb53948d9f0641c72ae643eba19f13066b8 Mon Sep 17 00:00:00 2001 -From: Robert Nelson <robertcnelson@gmail.com> -Date: Mon, 4 Jan 2016 11:00:59 -0600 -Subject: [PATCH 5/6] Revert "ARM: reduce visibility of dmac_* functions" - -This reverts commit 1234e3fda9aa24b2d650bbcd9ef09d5f6a12dc86. - -Signed-off-by: Robert Nelson <robertcnelson@gmail.com> ---- - arch/arm/include/asm/cacheflush.h | 4 ++++ - arch/arm/include/asm/glue-cache.h | 2 ++ - arch/arm/mm/dma-mapping.c | 1 - - arch/arm/mm/dma.h | 32 -------------------------------- - 4 files changed, 6 insertions(+), 33 deletions(-) - delete mode 100644 arch/arm/mm/dma.h - -diff --git a/arch/arm/include/asm/cacheflush.h b/arch/arm/include/asm/cacheflush.h -index bdd283b..b8039a6 100644 ---- a/arch/arm/include/asm/cacheflush.h -+++ b/arch/arm/include/asm/cacheflush.h -@@ -140,6 +140,8 @@ extern struct cpu_cache_fns cpu_cache; - * is visible to DMA, or data written by DMA to system memory is - * visible to the CPU. - */ -+#define dmac_map_area cpu_cache.dma_map_area -+#define dmac_unmap_area cpu_cache.dma_unmap_area - #define dmac_flush_range cpu_cache.dma_flush_range - - #else -@@ -159,6 +161,8 @@ extern void __cpuc_flush_dcache_area(void *, size_t); - * is visible to DMA, or data written by DMA to system memory is - * visible to the CPU. - */ -+extern void dmac_map_area(const void *, size_t, int); -+extern void dmac_unmap_area(const void *, size_t, int); - extern void dmac_flush_range(const void *, const void *); - - #endif -diff --git a/arch/arm/include/asm/glue-cache.h b/arch/arm/include/asm/glue-cache.h -index 01c3d92..9f94cba 100644 ---- a/arch/arm/include/asm/glue-cache.h -+++ b/arch/arm/include/asm/glue-cache.h -@@ -154,6 +154,8 @@ static inline void nop_dma_unmap_area(const void *s, size_t l, int f) { } - #define __cpuc_coherent_user_range __glue(_CACHE,_coherent_user_range) - #define __cpuc_flush_dcache_area __glue(_CACHE,_flush_kern_dcache_area) - -+#define dmac_map_area __glue(_CACHE,_dma_map_area) -+#define dmac_unmap_area __glue(_CACHE,_dma_unmap_area) - #define dmac_flush_range __glue(_CACHE,_dma_flush_range) - #endif - -diff --git a/arch/arm/mm/dma-mapping.c b/arch/arm/mm/dma-mapping.c -index ab77100..12ddd32 100644 ---- a/arch/arm/mm/dma-mapping.c -+++ b/arch/arm/mm/dma-mapping.c -@@ -39,7 +39,6 @@ - #include <asm/system_info.h> - #include <asm/dma-contiguous.h> - --#include "dma.h" - #include "mm.h" - - struct arm_dma_alloc_args { -diff --git a/arch/arm/mm/dma.h b/arch/arm/mm/dma.h -deleted file mode 100644 -index 70ea6852..0000000 ---- a/arch/arm/mm/dma.h -+++ /dev/null -@@ -1,32 +0,0 @@ --#ifndef DMA_H --#define DMA_H -- --#include <asm/glue-cache.h> -- --#ifndef MULTI_CACHE --#define dmac_map_area __glue(_CACHE,_dma_map_area) --#define dmac_unmap_area __glue(_CACHE,_dma_unmap_area) -- --/* -- * These are private to the dma-mapping API. Do not use directly. -- * Their sole purpose is to ensure that data held in the cache -- * is visible to DMA, or data written by DMA to system memory is -- * visible to the CPU. -- */ --extern void dmac_map_area(const void *, size_t, int); --extern void dmac_unmap_area(const void *, size_t, int); -- --#else -- --/* -- * These are private to the dma-mapping API. Do not use directly. -- * Their sole purpose is to ensure that data held in the cache -- * is visible to DMA, or data written by DMA to system memory is -- * visible to the CPU. -- */ --#define dmac_map_area cpu_cache.dma_map_area --#define dmac_unmap_area cpu_cache.dma_unmap_area -- --#endif -- --#endif --- -2.10.2 - diff --git a/patches/drivers/ti/sgx/0006-arm-Export-cache-flush-management-symbols-when-MULTI.patch b/patches/drivers/ti/sgx/0006-arm-Export-cache-flush-management-symbols-when-MULTI.patch deleted file mode 100644 index 7f6b30b25b67a53114d81031d689adfc6343151a..0000000000000000000000000000000000000000 --- a/patches/drivers/ti/sgx/0006-arm-Export-cache-flush-management-symbols-when-MULTI.patch +++ /dev/null @@ -1,34 +0,0 @@ -From 1f6c6f6ef1c0d687de7e376cb92fb1de6c1ca7de Mon Sep 17 00:00:00 2001 -From: Pantelis Antoniou <panto@antoniou-consulting.com> -Date: Fri, 4 Jan 2013 00:32:33 +0200 -Subject: [PATCH 6/6] arm: Export cache flush management symbols when - !MULTI_CACHE - -When compiling a kernel without CONFIG_MULTI_CACHE enabled the -dma access functions end up not being exported. Fix it. - -Signed-off-by: Pantelis Antoniou <panto@antoniou-consulting.com> ---- - arch/arm/kernel/setup.c | 9 +++++++++ - 1 file changed, 9 insertions(+) - -diff --git a/arch/arm/kernel/setup.c b/arch/arm/kernel/setup.c -index 34e3f3c..3325965 100644 ---- a/arch/arm/kernel/setup.c -+++ b/arch/arm/kernel/setup.c -@@ -1292,3 +1292,12 @@ const struct seq_operations cpuinfo_op = { - .stop = c_stop, - .show = c_show - }; -+ -+/* export the cache management functions */ -+#ifndef MULTI_CACHE -+ -+EXPORT_SYMBOL(__glue(_CACHE,_dma_map_area)); -+EXPORT_SYMBOL(__glue(_CACHE,_dma_unmap_area)); -+EXPORT_SYMBOL(__glue(_CACHE,_dma_flush_range)); -+ -+#endif --- -2.10.2 - diff --git a/patches/drivers/ti/uio/0001-Making-the-uio-pruss-driver-work.patch b/patches/drivers/ti/uio/0001-Making-the-uio-pruss-driver-work.patch index 5f9f69cef4d3273ca7ec0e67284c1060fd651bf8..3e18ed9b263473f4253e661dd2242a98bd6462d0 100644 --- a/patches/drivers/ti/uio/0001-Making-the-uio-pruss-driver-work.patch +++ b/patches/drivers/ti/uio/0001-Making-the-uio-pruss-driver-work.patch @@ -12,7 +12,7 @@ Subject: [PATCH] Making the uio pruss driver work 5 files changed, 139 insertions(+), 8 deletions(-) diff --git a/Documentation/devicetree/bindings/arm/omap/omap.txt b/Documentation/devicetree/bindings/arm/omap/omap.txt -index 94b57f2..413aeed 100644 +index f53e2ee..29bc4fe 100644 --- a/Documentation/devicetree/bindings/arm/omap/omap.txt +++ b/Documentation/devicetree/bindings/arm/omap/omap.txt @@ -24,6 +24,8 @@ Optional properties: @@ -25,10 +25,10 @@ index 94b57f2..413aeed 100644 Example: diff --git a/arch/arm/boot/dts/am33xx.dtsi b/arch/arm/boot/dts/am33xx.dtsi -index 98748c6..386d044 100644 +index 4efb3f5..ee36d6f 100644 --- a/arch/arm/boot/dts/am33xx.dtsi +++ b/arch/arm/boot/dts/am33xx.dtsi -@@ -561,6 +561,17 @@ +@@ -566,6 +566,17 @@ ti,timer-pwm; }; @@ -47,7 +47,7 @@ index 98748c6..386d044 100644 compatible = "ti,am3352-rtc", "ti,da830-rtc"; reg = <0x44e3e000 0x1000>; diff --git a/arch/arm/mach-omap2/omap_device.c b/arch/arm/mach-omap2/omap_device.c -index e920dd8..2ea553d 100644 +index 3133fe8..f5eff35 100644 --- a/arch/arm/mach-omap2/omap_device.c +++ b/arch/arm/mach-omap2/omap_device.c @@ -138,8 +138,8 @@ static int omap_device_build_from_dt(struct platform_device *pdev) @@ -89,7 +89,7 @@ index e920dd8..2ea553d 100644 odbfd_exit1: kfree(hwmods); diff --git a/drivers/uio/Kconfig b/drivers/uio/Kconfig -index 52c98ce..05400bc0 100644 +index 7e8dc78..e0c68ac 100644 --- a/drivers/uio/Kconfig +++ b/drivers/uio/Kconfig @@ -129,7 +129,7 @@ config UIO_PRUSS @@ -102,7 +102,7 @@ index 52c98ce..05400bc0 100644 driver is available from below SVN repo - you may use anonymous login diff --git a/drivers/uio/uio_pruss.c b/drivers/uio/uio_pruss.c -index ca9e2fa..6559752 100644 +index 31d5b1d..dbe8ec8 100644 --- a/drivers/uio/uio_pruss.c +++ b/drivers/uio/uio_pruss.c @@ -19,6 +19,7 @@ @@ -136,9 +136,9 @@ index ca9e2fa..6559752 100644 sram_pool_sz); +#endif kfree(gdev->info); + clk_disable(gdev->pruss_clk); clk_put(gdev->pruss_clk); - kfree(gdev); -@@ -120,9 +128,15 @@ static int pruss_probe(struct platform_device *pdev) +@@ -121,9 +129,15 @@ static int pruss_probe(struct platform_device *pdev) struct uio_info *p; struct uio_pruss_dev *gdev; struct resource *regs_prussio; @@ -154,7 +154,7 @@ index ca9e2fa..6559752 100644 gdev = kzalloc(sizeof(struct uio_pruss_dev), GFP_KERNEL); if (!gdev) -@@ -133,7 +147,7 @@ static int pruss_probe(struct platform_device *pdev) +@@ -134,7 +148,7 @@ static int pruss_probe(struct platform_device *pdev) kfree(gdev); return -ENOMEM; } @@ -163,9 +163,9 @@ index ca9e2fa..6559752 100644 /* Power on PRU in case its not done as part of boot-loader */ gdev->pruss_clk = clk_get(dev, "pruss"); if (IS_ERR(gdev->pruss_clk)) { -@@ -145,8 +159,25 @@ static int pruss_probe(struct platform_device *pdev) - } else { - clk_enable(gdev->pruss_clk); +@@ -153,8 +167,25 @@ static int pruss_probe(struct platform_device *pdev) + return ret; + } } +#endif + @@ -190,7 +190,7 @@ index ca9e2fa..6559752 100644 if (!regs_prussio) { dev_err(dev, "No PRUSS I/O resource specified\n"); goto out_free; -@@ -157,7 +188,50 @@ static int pruss_probe(struct platform_device *pdev) +@@ -165,7 +196,50 @@ static int pruss_probe(struct platform_device *pdev) goto out_free; } @@ -242,7 +242,7 @@ index ca9e2fa..6559752 100644 gdev->sram_pool = pdata->sram_pool; gdev->sram_vaddr = (unsigned long)gen_pool_dma_alloc(gdev->sram_pool, -@@ -182,7 +256,17 @@ static int pruss_probe(struct platform_device *pdev) +@@ -190,7 +264,17 @@ static int pruss_probe(struct platform_device *pdev) goto out_free; } @@ -261,7 +261,7 @@ index ca9e2fa..6559752 100644 gdev->hostirq_start = platform_get_irq(pdev, 0); for (cnt = 0, p = gdev->info; cnt < MAX_PRUSS_EVT; cnt++, p++) { -@@ -190,6 +274,7 @@ static int pruss_probe(struct platform_device *pdev) +@@ -198,6 +282,7 @@ static int pruss_probe(struct platform_device *pdev) p->mem[0].size = resource_size(regs_prussio); p->mem[0].memtype = UIO_MEM_PHYS; @@ -269,7 +269,7 @@ index ca9e2fa..6559752 100644 p->mem[1].addr = gdev->sram_paddr; p->mem[1].size = sram_pool_sz; p->mem[1].memtype = UIO_MEM_PHYS; -@@ -197,7 +282,11 @@ static int pruss_probe(struct platform_device *pdev) +@@ -205,7 +290,11 @@ static int pruss_probe(struct platform_device *pdev) p->mem[2].addr = gdev->ddr_paddr; p->mem[2].size = extram_pool_sz; p->mem[2].memtype = UIO_MEM_PHYS; @@ -282,7 +282,7 @@ index ca9e2fa..6559752 100644 p->name = kasprintf(GFP_KERNEL, "pruss_evt%d", cnt); p->version = DRV_VERSION; -@@ -227,11 +316,20 @@ static int pruss_remove(struct platform_device *dev) +@@ -235,11 +324,20 @@ static int pruss_remove(struct platform_device *dev) return 0; } @@ -304,5 +304,5 @@ index ca9e2fa..6559752 100644 }; -- -2.9.3 +2.10.2 diff --git a/patches/drivers/tinydrm/0001-merge-tinydrm.patch b/patches/drivers/tinydrm/0001-merge-tinydrm.patch index f1ac064c9f1fde3016ca545336867921c001d2d3..9b0486af8381fdd48e95c8d900ecef785aff4730 100644 --- a/patches/drivers/tinydrm/0001-merge-tinydrm.patch +++ b/patches/drivers/tinydrm/0001-merge-tinydrm.patch @@ -1,6 +1,6 @@ -From a60588bf5e7bd0173661947aaa5f951765042745 Mon Sep 17 00:00:00 2001 +From c30ce6e1ecf1c9026940ae0ec8667d0de8efdf47 Mon Sep 17 00:00:00 2001 From: Robert Nelson <robertcnelson@gmail.com> -Date: Tue, 20 Dec 2016 13:56:28 -0600 +Date: Tue, 13 Dec 2016 14:10:42 -0600 Subject: [PATCH] merge: tinydrm Signed-off-by: Robert Nelson <robertcnelson@gmail.com> @@ -52,26 +52,26 @@ Signed-off-by: Robert Nelson <robertcnelson@gmail.com> create mode 100644 include/uapi/drm/utinydrm.h diff --git a/drivers/gpu/drm/Kconfig b/drivers/gpu/drm/Kconfig -index 483059a22b1b..c882d09d8279 100644 +index ebfe840..0b1d655 100644 --- a/drivers/gpu/drm/Kconfig +++ b/drivers/gpu/drm/Kconfig -@@ -300,3 +300,4 @@ config DRM_SAVAGE +@@ -321,3 +321,4 @@ config DRM_SAVAGE chipset. If M is selected the module will be called savage. endif # DRM_LEGACY +source "drivers/gpu/drm/tinydrm/Kconfig" diff --git a/drivers/gpu/drm/Makefile b/drivers/gpu/drm/Makefile -index 25c720454017..11c4b8e7ecd8 100644 +index b9ae428..da26c96 100644 --- a/drivers/gpu/drm/Makefile +++ b/drivers/gpu/drm/Makefile -@@ -86,3 +86,4 @@ obj-$(CONFIG_DRM_FSL_DCU) += fsl-dcu/ - obj-$(CONFIG_DRM_ETNAVIV) += etnaviv/ - obj-$(CONFIG_DRM_ARCPGU)+= arc/ +@@ -91,3 +91,4 @@ obj-$(CONFIG_DRM_ARCPGU)+= arc/ obj-y += hisilicon/ + obj-$(CONFIG_DRM_ZTE) += zte/ + obj-$(CONFIG_DRM_MXSFB) += mxsfb/ +obj-$(CONFIG_DRM_TINYDRM)+= tinydrm/ diff --git a/drivers/gpu/drm/tinydrm/Kconfig b/drivers/gpu/drm/tinydrm/Kconfig new file mode 100644 -index 000000000000..38a073e9a498 +index 0000000..38a073e --- /dev/null +++ b/drivers/gpu/drm/tinydrm/Kconfig @@ -0,0 +1,38 @@ @@ -115,7 +115,7 @@ index 000000000000..38a073e9a498 + choose 'm' here: the module will be called utinydrm. diff --git a/drivers/gpu/drm/tinydrm/Makefile b/drivers/gpu/drm/tinydrm/Makefile new file mode 100644 -index 000000000000..7417a5eff617 +index 0000000..7417a5e --- /dev/null +++ b/drivers/gpu/drm/tinydrm/Makefile @@ -0,0 +1,11 @@ @@ -132,7 +132,7 @@ index 000000000000..7417a5eff617 +obj-$(CONFIG_TINYDRM_USER) += utinydrm.o diff --git a/drivers/gpu/drm/tinydrm/adafruit-tft.c b/drivers/gpu/drm/tinydrm/adafruit-tft.c new file mode 100644 -index 000000000000..ef89c1b6b0e6 +index 0000000..ef89c1b --- /dev/null +++ b/drivers/gpu/drm/tinydrm/adafruit-tft.c @@ -0,0 +1,394 @@ @@ -532,7 +532,7 @@ index 000000000000..ef89c1b6b0e6 +MODULE_LICENSE("GPL"); diff --git a/drivers/gpu/drm/tinydrm/core/Makefile b/drivers/gpu/drm/tinydrm/core/Makefile new file mode 100644 -index 000000000000..c672d89dce9b +index 0000000..c672d89 --- /dev/null +++ b/drivers/gpu/drm/tinydrm/core/Makefile @@ -0,0 +1,7 @@ @@ -545,7 +545,7 @@ index 000000000000..c672d89dce9b +obj-$(CONFIG_DRM_TINYDRM) += tinydrm.o diff --git a/drivers/gpu/drm/tinydrm/core/tinydrm-core.c b/drivers/gpu/drm/tinydrm/core/tinydrm-core.c new file mode 100644 -index 000000000000..da55c2c5dc59 +index 0000000..da55c2c --- /dev/null +++ b/drivers/gpu/drm/tinydrm/core/tinydrm-core.c @@ -0,0 +1,411 @@ @@ -962,7 +962,7 @@ index 000000000000..da55c2c5dc59 +MODULE_LICENSE("GPL"); diff --git a/drivers/gpu/drm/tinydrm/core/tinydrm-debugfs.c b/drivers/gpu/drm/tinydrm/core/tinydrm-debugfs.c new file mode 100644 -index 000000000000..0c701464ef83 +index 0000000..0c70146 --- /dev/null +++ b/drivers/gpu/drm/tinydrm/core/tinydrm-debugfs.c @@ -0,0 +1,439 @@ @@ -1407,7 +1407,7 @@ index 000000000000..0c701464ef83 +EXPORT_SYMBOL(tinydrm_debugfs_cleanup); diff --git a/drivers/gpu/drm/tinydrm/core/tinydrm-fb.c b/drivers/gpu/drm/tinydrm/core/tinydrm-fb.c new file mode 100644 -index 000000000000..3150754695d3 +index 0000000..3150754 --- /dev/null +++ b/drivers/gpu/drm/tinydrm/core/tinydrm-fb.c @@ -0,0 +1,182 @@ @@ -1595,7 +1595,7 @@ index 000000000000..3150754695d3 +EXPORT_SYMBOL(tinydrm_fbdev_fini); diff --git a/drivers/gpu/drm/tinydrm/core/tinydrm-helpers.c b/drivers/gpu/drm/tinydrm/core/tinydrm-helpers.c new file mode 100644 -index 000000000000..27683e90e8da +index 0000000..27683e9 --- /dev/null +++ b/drivers/gpu/drm/tinydrm/core/tinydrm-helpers.c @@ -0,0 +1,222 @@ @@ -1823,7 +1823,7 @@ index 000000000000..27683e90e8da +EXPORT_SYMBOL(tinydrm_spi_shutdown); diff --git a/drivers/gpu/drm/tinydrm/core/tinydrm-pipe.c b/drivers/gpu/drm/tinydrm/core/tinydrm-pipe.c new file mode 100644 -index 000000000000..0751208e4f78 +index 0000000..0751208 --- /dev/null +++ b/drivers/gpu/drm/tinydrm/core/tinydrm-pipe.c @@ -0,0 +1,247 @@ @@ -2076,7 +2076,7 @@ index 000000000000..0751208e4f78 +EXPORT_SYMBOL(tinydrm_display_pipe_init); diff --git a/drivers/gpu/drm/tinydrm/core/tinydrm-regmap.c b/drivers/gpu/drm/tinydrm/core/tinydrm-regmap.c new file mode 100644 -index 000000000000..15a879c6d6b0 +index 0000000..15a879c --- /dev/null +++ b/drivers/gpu/drm/tinydrm/core/tinydrm-regmap.c @@ -0,0 +1,326 @@ @@ -2408,7 +2408,7 @@ index 000000000000..15a879c6d6b0 +#endif /* CONFIG_SPI */ diff --git a/drivers/gpu/drm/tinydrm/mi0283qt.c b/drivers/gpu/drm/tinydrm/mi0283qt.c new file mode 100644 -index 000000000000..aca2a0483687 +index 0000000..aca2a04 --- /dev/null +++ b/drivers/gpu/drm/tinydrm/mi0283qt.c @@ -0,0 +1,310 @@ @@ -2724,7 +2724,7 @@ index 000000000000..aca2a0483687 +MODULE_LICENSE("GPL"); diff --git a/drivers/gpu/drm/tinydrm/mipi-dbi.c b/drivers/gpu/drm/tinydrm/mipi-dbi.c new file mode 100644 -index 000000000000..0a074a20c605 +index 0000000..0a074a2 --- /dev/null +++ b/drivers/gpu/drm/tinydrm/mipi-dbi.c @@ -0,0 +1,1087 @@ @@ -3817,7 +3817,7 @@ index 000000000000..0a074a20c605 +MODULE_LICENSE("GPL"); diff --git a/drivers/gpu/drm/tinydrm/utinydrm.c b/drivers/gpu/drm/tinydrm/utinydrm.c new file mode 100644 -index 000000000000..14ac47ce64b4 +index 0000000..14ac47c --- /dev/null +++ b/drivers/gpu/drm/tinydrm/utinydrm.c @@ -0,0 +1,652 @@ @@ -4475,7 +4475,7 @@ index 000000000000..14ac47ce64b4 +MODULE_LICENSE("GPL"); diff --git a/include/drm/tinydrm/hx8340.h b/include/drm/tinydrm/hx8340.h new file mode 100644 -index 000000000000..4fc975f698a3 +index 0000000..4fc975f --- /dev/null +++ b/include/drm/tinydrm/hx8340.h @@ -0,0 +1,46 @@ @@ -4527,7 +4527,7 @@ index 000000000000..4fc975f698a3 +#endif /* __LINUX_HX8340_H */ diff --git a/include/drm/tinydrm/ili9341.h b/include/drm/tinydrm/ili9341.h new file mode 100644 -index 000000000000..807a09f43cad +index 0000000..807a09f --- /dev/null +++ b/include/drm/tinydrm/ili9341.h @@ -0,0 +1,54 @@ @@ -4587,7 +4587,7 @@ index 000000000000..807a09f43cad +#endif /* __LINUX_ILI9341_H */ diff --git a/include/drm/tinydrm/mipi-dbi.h b/include/drm/tinydrm/mipi-dbi.h new file mode 100644 -index 000000000000..e3de909391d5 +index 0000000..e3de909 --- /dev/null +++ b/include/drm/tinydrm/mipi-dbi.h @@ -0,0 +1,82 @@ @@ -4675,7 +4675,7 @@ index 000000000000..e3de909391d5 +#endif /* __LINUX_MIPI_DBI_H */ diff --git a/include/drm/tinydrm/st7735r.h b/include/drm/tinydrm/st7735r.h new file mode 100644 -index 000000000000..f2ba5352b634 +index 0000000..f2ba535 --- /dev/null +++ b/include/drm/tinydrm/st7735r.h @@ -0,0 +1,44 @@ @@ -4725,7 +4725,7 @@ index 000000000000..f2ba5352b634 +#endif /* __LINUX_ST7735R_H */ diff --git a/include/drm/tinydrm/tinydrm-helpers.h b/include/drm/tinydrm/tinydrm-helpers.h new file mode 100644 -index 000000000000..2cf416afd64b +index 0000000..2cf416a --- /dev/null +++ b/include/drm/tinydrm/tinydrm-helpers.h @@ -0,0 +1,50 @@ @@ -4781,7 +4781,7 @@ index 000000000000..2cf416afd64b +#endif /* __LINUX_TINYDRM_HELPERS_H */ diff --git a/include/drm/tinydrm/tinydrm-regmap.h b/include/drm/tinydrm/tinydrm-regmap.h new file mode 100644 -index 000000000000..70a67ed684a5 +index 0000000..70a67ed --- /dev/null +++ b/include/drm/tinydrm/tinydrm-regmap.h @@ -0,0 +1,99 @@ @@ -4886,7 +4886,7 @@ index 000000000000..70a67ed684a5 +#endif /* __LINUX_TINYDRM_REGMAP_H */ diff --git a/include/drm/tinydrm/tinydrm.h b/include/drm/tinydrm/tinydrm.h new file mode 100644 -index 000000000000..15557420b678 +index 0000000..1555742 --- /dev/null +++ b/include/drm/tinydrm/tinydrm.h @@ -0,0 +1,177 @@ @@ -5069,7 +5069,7 @@ index 000000000000..15557420b678 +#endif /* __LINUX_TINYDRM_H */ diff --git a/include/uapi/drm/utinydrm.h b/include/uapi/drm/utinydrm.h new file mode 100644 -index 000000000000..7d578861fcd3 +index 0000000..7d57886 --- /dev/null +++ b/include/uapi/drm/utinydrm.h @@ -0,0 +1,73 @@ @@ -5147,5 +5147,5 @@ index 000000000000..7d578861fcd3 + +#endif /* _UAPI__UTINYDRM_H_ */ -- -2.11.0 +2.10.2 diff --git a/patches/drivers/tps65217/0001-ARM-dts-tps65217-Specify-the-interrupt-controller.patch b/patches/drivers/tps65217/0001-ARM-dts-tps65217-Specify-the-interrupt-controller.patch deleted file mode 100644 index 4802606b81f73e0b96f5679557b1afef7695b667..0000000000000000000000000000000000000000 --- a/patches/drivers/tps65217/0001-ARM-dts-tps65217-Specify-the-interrupt-controller.patch +++ /dev/null @@ -1,33 +0,0 @@ -From c8935c1531ef0a7007ee63e9ece54a0626b0b1c2 Mon Sep 17 00:00:00 2001 -From: Milo Kim <woogyom.kim@gmail.com> -Date: Fri, 28 Oct 2016 21:36:55 +0900 -Subject: [PATCH 1/9] ARM: dts: tps65217: Specify the interrupt controller - -TPS65217 MFD driver supports the IRQ domain to handle the charger input -interrupts and push button status event. The interrupt controller enables -corresponding IRQ handling in the charger[*] and power button driver[**]. - -[*] drivers/power/supply/tps65217_charger.c -[**] drivers/input/misc/tps65218-pwrbutton.c - -Signed-off-by: Milo Kim <woogyom.kim@gmail.com> ---- - arch/arm/boot/dts/tps65217.dtsi | 2 ++ - 1 file changed, 2 insertions(+) - -diff --git a/arch/arm/boot/dts/tps65217.dtsi b/arch/arm/boot/dts/tps65217.dtsi -index a632724..27935f8 100644 ---- a/arch/arm/boot/dts/tps65217.dtsi -+++ b/arch/arm/boot/dts/tps65217.dtsi -@@ -13,6 +13,8 @@ - - &tps { - compatible = "ti,tps65217"; -+ interrupt-controller; -+ #interrupt-cells = <1>; - - regulators { - #address-cells = <1>; --- -2.10.2 - diff --git a/patches/drivers/tps65217/0009-HACK-tps65217_pwr_but.patch b/patches/drivers/tps65217/0001-HACK-tps65217_pwr_but.patch similarity index 100% rename from patches/drivers/tps65217/0009-HACK-tps65217_pwr_but.patch rename to patches/drivers/tps65217/0001-HACK-tps65217_pwr_but.patch diff --git a/patches/drivers/tps65217/0002-ARM-dts-tps65217-Add-the-charger-device.patch b/patches/drivers/tps65217/0002-ARM-dts-tps65217-Add-the-charger-device.patch deleted file mode 100644 index 6d1b5774db1d52042142a3143233e5dfe46e5aa7..0000000000000000000000000000000000000000 --- a/patches/drivers/tps65217/0002-ARM-dts-tps65217-Add-the-charger-device.patch +++ /dev/null @@ -1,31 +0,0 @@ -From 7e18b51eb2f74d1ea33ced94435e5be7083111c7 Mon Sep 17 00:00:00 2001 -From: Milo Kim <woogyom.kim@gmail.com> -Date: Fri, 28 Oct 2016 21:36:56 +0900 -Subject: [PATCH 2/9] ARM: dts: tps65217: Add the charger device - -Support the charger driver and disable it by default. - -Signed-off-by: Milo Kim <woogyom.kim@gmail.com> ---- - arch/arm/boot/dts/tps65217.dtsi | 5 +++++ - 1 file changed, 5 insertions(+) - -diff --git a/arch/arm/boot/dts/tps65217.dtsi b/arch/arm/boot/dts/tps65217.dtsi -index 27935f8..8f77d0d 100644 ---- a/arch/arm/boot/dts/tps65217.dtsi -+++ b/arch/arm/boot/dts/tps65217.dtsi -@@ -16,6 +16,11 @@ - interrupt-controller; - #interrupt-cells = <1>; - -+ charger { -+ compatible = "ti,tps65217-charger"; -+ status = "disabled"; -+ }; -+ - regulators { - #address-cells = <1>; - #size-cells = <0>; --- -2.10.2 - diff --git a/patches/drivers/tps65217/0003-ARM-dts-tps65217-Add-the-power-button-device.patch b/patches/drivers/tps65217/0003-ARM-dts-tps65217-Add-the-power-button-device.patch deleted file mode 100644 index ee265e525cfe28a82e41d8b03c3dc9c96b9226dc..0000000000000000000000000000000000000000 --- a/patches/drivers/tps65217/0003-ARM-dts-tps65217-Add-the-power-button-device.patch +++ /dev/null @@ -1,31 +0,0 @@ -From 4ce14d862b7cec2d6b964c623ec99fcbe38b5083 Mon Sep 17 00:00:00 2001 -From: Milo Kim <woogyom.kim@gmail.com> -Date: Fri, 28 Oct 2016 21:36:57 +0900 -Subject: [PATCH 3/9] ARM: dts: tps65217: Add the power button device - -Support the power button driver and disable it by default. - -Signed-off-by: Milo Kim <woogyom.kim@gmail.com> ---- - arch/arm/boot/dts/tps65217.dtsi | 5 +++++ - 1 file changed, 5 insertions(+) - -diff --git a/arch/arm/boot/dts/tps65217.dtsi b/arch/arm/boot/dts/tps65217.dtsi -index 8f77d0d..02de56b 100644 ---- a/arch/arm/boot/dts/tps65217.dtsi -+++ b/arch/arm/boot/dts/tps65217.dtsi -@@ -21,6 +21,11 @@ - status = "disabled"; - }; - -+ pwrbutton { -+ compatible = "ti,tps65217-pwrbutton"; -+ status = "disabled"; -+ }; -+ - regulators { - #address-cells = <1>; - #size-cells = <0>; --- -2.10.2 - diff --git a/patches/drivers/tps65217/0004-ARM-dts-am335x-Support-the-PMIC-interrupt.patch b/patches/drivers/tps65217/0004-ARM-dts-am335x-Support-the-PMIC-interrupt.patch deleted file mode 100644 index eacaf51c1d2387dc134f84f554c7b20d4708982a..0000000000000000000000000000000000000000 --- a/patches/drivers/tps65217/0004-ARM-dts-am335x-Support-the-PMIC-interrupt.patch +++ /dev/null @@ -1,32 +0,0 @@ -From 341f8a44fb57e2bd461c1c21d2331943b53ce1c6 Mon Sep 17 00:00:00 2001 -From: Milo Kim <woogyom.kim@gmail.com> -Date: Fri, 28 Oct 2016 21:36:58 +0900 -Subject: [PATCH 4/9] ARM: dts: am335x: Support the PMIC interrupt - -AM335x bone based boards have the PMIC interrupt named NMI which is -connected to TPS65217 device. AM335x main interrupt controller provides it -and the number is 7. - -Signed-off-by: Milo Kim <woogyom.kim@gmail.com> ---- - arch/arm/boot/dts/am335x-bone-common.dtsi | 4 ++++ - 1 file changed, 4 insertions(+) - -diff --git a/arch/arm/boot/dts/am335x-bone-common.dtsi b/arch/arm/boot/dts/am335x-bone-common.dtsi -index 007b5e5..25303d9 100644 ---- a/arch/arm/boot/dts/am335x-bone-common.dtsi -+++ b/arch/arm/boot/dts/am335x-bone-common.dtsi -@@ -310,6 +310,10 @@ - * by the hardware problems. (Tip: double-check by performing a current - * measurement after shutdown: it should be less than 1 mA.) - */ -+ -+ interrupts = <7>; /* NMI */ -+ interrupt-parent = <&intc>; -+ - ti,pmic-shutdown-controller; - - regulators { --- -2.10.2 - diff --git a/patches/drivers/tps65217/0005-dt-bindings-mfd-Provide-human-readable-defines-for-T.patch b/patches/drivers/tps65217/0005-dt-bindings-mfd-Provide-human-readable-defines-for-T.patch deleted file mode 100644 index 4b367135c51f7820ca21379c414fcef58344a624..0000000000000000000000000000000000000000 --- a/patches/drivers/tps65217/0005-dt-bindings-mfd-Provide-human-readable-defines-for-T.patch +++ /dev/null @@ -1,51 +0,0 @@ -From bc8f1ded76566e75703380399d77d67922ab18bc Mon Sep 17 00:00:00 2001 -From: Milo Kim <woogyom.kim@gmail.com> -Date: Fri, 28 Oct 2016 21:36:59 +0900 -Subject: [PATCH 5/9] dt-bindings: mfd: Provide human readable defines for - TPS65217 interrupts - -TPS65217 supports three interrupt sources. This patch enables assigning -each IRQ number in the charger and power button node. Then corresponding -IRQ will be requested by each driver. - -Signed-off-by: Milo Kim <woogyom.kim@gmail.com> ---- - include/dt-bindings/mfd/tps65217.h | 26 ++++++++++++++++++++++++++ - 1 file changed, 26 insertions(+) - create mode 100644 include/dt-bindings/mfd/tps65217.h - -diff --git a/include/dt-bindings/mfd/tps65217.h b/include/dt-bindings/mfd/tps65217.h -new file mode 100644 -index 0000000..cafb9e6 ---- /dev/null -+++ b/include/dt-bindings/mfd/tps65217.h -@@ -0,0 +1,26 @@ -+/* -+ * This header provides macros for TI TPS65217 DT bindings. -+ * -+ * Copyright (C) 2016 Texas Instruments -+ * -+ * 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. -+ * -+ * 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, see <http://www.gnu.org/licenses/>. -+ */ -+ -+#ifndef __DT_BINDINGS_TPS65217_H__ -+#define __DT_BINDINGS_TPS65217_H__ -+ -+#define TPS65217_IRQ_USB 0 -+#define TPS65217_IRQ_AC 1 -+#define TPS65217_IRQ_PB 2 -+ -+#endif --- -2.10.2 - diff --git a/patches/drivers/tps65217/0006-ARM-dts-am335x-Add-the-charger-interrupt.patch b/patches/drivers/tps65217/0006-ARM-dts-am335x-Add-the-charger-interrupt.patch deleted file mode 100644 index 189b02eddb4126f03e513450186a67530cdeb22b..0000000000000000000000000000000000000000 --- a/patches/drivers/tps65217/0006-ARM-dts-am335x-Add-the-charger-interrupt.patch +++ /dev/null @@ -1,42 +0,0 @@ -From e55374ce9374dae0066eef8e4193c288c6536eab Mon Sep 17 00:00:00 2001 -From: Milo Kim <woogyom.kim@gmail.com> -Date: Fri, 28 Oct 2016 21:37:00 +0900 -Subject: [PATCH 6/9] ARM: dts: am335x: Add the charger interrupt - -This enables the charger driver gets corresponding IRQ number by using -platform_get_irq_byname() helper. - -Signed-off-by: Milo Kim <woogyom.kim@gmail.com> ---- - arch/arm/boot/dts/am335x-bone-common.dtsi | 8 ++++++++ - 1 file changed, 8 insertions(+) - -diff --git a/arch/arm/boot/dts/am335x-bone-common.dtsi b/arch/arm/boot/dts/am335x-bone-common.dtsi -index 25303d9..cec9d91 100644 ---- a/arch/arm/boot/dts/am335x-bone-common.dtsi -+++ b/arch/arm/boot/dts/am335x-bone-common.dtsi -@@ -6,6 +6,8 @@ - * published by the Free Software Foundation. - */ - -+#include <dt-bindings/mfd/tps65217.h> -+ - / { - cpus { - cpu@0 { -@@ -316,6 +318,12 @@ - - ti,pmic-shutdown-controller; - -+ charger { -+ interrupts = <TPS65217_IRQ_AC>, <TPS65217_IRQ_USB>; -+ interrupts-names = "AC", "USB"; -+ status = "okay"; -+ }; -+ - regulators { - dcdc1_reg: regulator@0 { - regulator-name = "vdds_dpr"; --- -2.10.2 - diff --git a/patches/drivers/tps65217/0007-ARM-dts-am335x-Add-the-power-button-interrupt.patch b/patches/drivers/tps65217/0007-ARM-dts-am335x-Add-the-power-button-interrupt.patch deleted file mode 100644 index 13b534def56e268beee637420e87a433285c5a36..0000000000000000000000000000000000000000 --- a/patches/drivers/tps65217/0007-ARM-dts-am335x-Add-the-power-button-interrupt.patch +++ /dev/null @@ -1,32 +0,0 @@ -From 27cfe40d02ff47105650935a7de900dce2cc6608 Mon Sep 17 00:00:00 2001 -From: Milo Kim <woogyom.kim@gmail.com> -Date: Fri, 28 Oct 2016 21:37:01 +0900 -Subject: [PATCH 7/9] ARM: dts: am335x: Add the power button interrupt - -This enables the power button driver gets corresponding IRQ number by -using platform_get_irq(). - -Signed-off-by: Milo Kim <woogyom.kim@gmail.com> ---- - arch/arm/boot/dts/am335x-bone-common.dtsi | 5 +++++ - 1 file changed, 5 insertions(+) - -diff --git a/arch/arm/boot/dts/am335x-bone-common.dtsi b/arch/arm/boot/dts/am335x-bone-common.dtsi -index cec9d91..0c0a90c 100644 ---- a/arch/arm/boot/dts/am335x-bone-common.dtsi -+++ b/arch/arm/boot/dts/am335x-bone-common.dtsi -@@ -324,6 +324,11 @@ - status = "okay"; - }; - -+ pwrbutton { -+ interrupts = <TPS65217_IRQ_PB>; -+ status = "okay"; -+ }; -+ - regulators { - dcdc1_reg: regulator@0 { - regulator-name = "vdds_dpr"; --- -2.10.2 - diff --git a/patches/drivers/tps65217/0008-mfd-tps65217-Fix-mismatched-interrupt-number.patch b/patches/drivers/tps65217/0008-mfd-tps65217-Fix-mismatched-interrupt-number.patch deleted file mode 100644 index 790fe450aba19fa6ed9e5ed0144f1cad3a219a0f..0000000000000000000000000000000000000000 --- a/patches/drivers/tps65217/0008-mfd-tps65217-Fix-mismatched-interrupt-number.patch +++ /dev/null @@ -1,49 +0,0 @@ -From 7302a9421fc213a17f2796b1ac12d9874011aa5b Mon Sep 17 00:00:00 2001 -From: Milo Kim <woogyom.kim@gmail.com> -Date: Fri, 28 Oct 2016 21:37:02 +0900 -Subject: [PATCH 8/9] mfd: tps65217: Fix mismatched interrupt number - -Enum value of 'tps65217_irq_type' is not matched with DT parsed hwirq -number[*]. - -The MFD driver gets the IRQ data by referencing hwirq, but the value is -different. So, irq_to_tps65217_irq() returns mismatched IRQ data. -Eventually, the power button driver enables not PB but USB interrupt -when it is probed. - -According to the TPS65217 register map[**], USB interrupt is the LSB. -This patch defines synchronized IRQ value. - -[*] include/dt-bindings/mfd/tps65217.h -[**] http://www.ti.com/lit/ds/symlink/tps65217.pdf - -Signed-off-by: Milo Kim <woogyom.kim@gmail.com> ---- - include/linux/mfd/tps65217.h | 11 +++++------ - 1 file changed, 5 insertions(+), 6 deletions(-) - -diff --git a/include/linux/mfd/tps65217.h b/include/linux/mfd/tps65217.h -index 4ccda89..3cbec4b 100644 ---- a/include/linux/mfd/tps65217.h -+++ b/include/linux/mfd/tps65217.h -@@ -234,12 +234,11 @@ struct tps65217_bl_pdata { - int dft_brightness; - }; - --enum tps65217_irq_type { -- TPS65217_IRQ_PB, -- TPS65217_IRQ_AC, -- TPS65217_IRQ_USB, -- TPS65217_NUM_IRQ --}; -+/* Interrupt numbers */ -+#define TPS65217_IRQ_USB 0 -+#define TPS65217_IRQ_AC 1 -+#define TPS65217_IRQ_PB 2 -+#define TPS65217_NUM_IRQ 3 - - /** - * struct tps65217_board - packages regulator init data --- -2.10.2 - diff --git a/patches/ref_omap2plus_defconfig b/patches/ref_omap2plus_defconfig index 666086cdb48d0d7aa6e970f5e7413286e84a36e1..4eaba57a35a258e2d97deb9a346928b0d1dbde4e 100644 --- a/patches/ref_omap2plus_defconfig +++ b/patches/ref_omap2plus_defconfig @@ -1,6 +1,6 @@ # # Automatically generated file; DO NOT EDIT. -# Linux/arm 4.9.0 Kernel Configuration +# Linux/arm 4.10.0-rc1 Kernel Configuration # CONFIG_ARM=y CONFIG_ARM_HAS_SG_CHAIN=y @@ -157,6 +157,7 @@ CONFIG_RD_LZMA=y CONFIG_RD_XZ=y CONFIG_RD_LZO=y CONFIG_RD_LZ4=y +CONFIG_INITRAMFS_COMPRESSION=".gz" CONFIG_CC_OPTIMIZE_FOR_PERFORMANCE=y # CONFIG_CC_OPTIMIZE_FOR_SIZE is not set CONFIG_SYSCTL=y @@ -169,6 +170,7 @@ CONFIG_MULTIUSER=y # CONFIG_SGETMASK_SYSCALL is not set CONFIG_SYSFS_SYSCALL=y # CONFIG_SYSCTL_SYSCALL is not set +CONFIG_POSIX_TIMERS=y CONFIG_KALLSYMS=y CONFIG_KALLSYMS_ALL=y # CONFIG_KALLSYMS_ABSOLUTE_PERCPU is not set @@ -286,8 +288,10 @@ CONFIG_LBDAF=y # CONFIG_BLK_DEV_BSG is not set # CONFIG_BLK_DEV_BSGLIB is not set # CONFIG_BLK_DEV_INTEGRITY is not set +# CONFIG_BLK_DEV_ZONED is not set # CONFIG_BLK_DEV_THROTTLING is not set # CONFIG_BLK_CMDLINE_PARSER is not set +# CONFIG_BLK_WBT is not set # # Partition Types @@ -326,6 +330,7 @@ CONFIG_DEFAULT_CFQ=y CONFIG_DEFAULT_IOSCHED="cfq" CONFIG_UNINLINE_SPIN_UNLOCK=y CONFIG_ARCH_SUPPORTS_ATOMIC_RMW=y +CONFIG_MUTEX_SPIN_ON_OWNER=y CONFIG_RWSEM_SPIN_ON_OWNER=y CONFIG_LOCK_SPIN_ON_OWNER=y CONFIG_FREEZER=y @@ -395,9 +400,6 @@ CONFIG_ARCH_OMAP=y CONFIG_POWER_AVS_OMAP=y CONFIG_POWER_AVS_OMAP_CLASS3=y CONFIG_OMAP_RESET_CLOCKS=y -CONFIG_OMAP_MUX=y -CONFIG_OMAP_MUX_DEBUG=y -CONFIG_OMAP_MUX_WARNINGS=y CONFIG_OMAP_32K_TIMER=y # CONFIG_OMAP3_L2_AUX_SECURE_SAVE_RESTORE is not set CONFIG_OMAP_DM_TIMER=y @@ -446,6 +448,7 @@ CONFIG_MACH_NOKIA_N8X0=y # CONFIG_OMAP5_ERRATA_801819 is not set # CONFIG_ARCH_PICOXCELL is not set # CONFIG_ARCH_MMP is not set +# CONFIG_ARCH_OXNAS is not set # CONFIG_ARCH_QCOM is not set # CONFIG_ARCH_REALVIEW is not set # CONFIG_ARCH_ROCKCHIP is not set @@ -682,7 +685,6 @@ CONFIG_CPUFREQ_DT_PLATDEV=y # CONFIG_ARM_BIG_LITTLE_CPUFREQ is not set # CONFIG_ARM_KIRKWOOD_CPUFREQ is not set # CONFIG_ARM_OMAP2PLUS_CPUFREQ is not set -# CONFIG_ARM_TI_CPUFREQ is not set # CONFIG_QORIQ_CPUFREQ is not set # @@ -791,6 +793,7 @@ CONFIG_INET_XFRM_MODE_BEET=y CONFIG_INET_DIAG=y CONFIG_INET_TCP_DIAG=y # CONFIG_INET_UDP_DIAG is not set +# CONFIG_INET_RAW_DIAG is not set # CONFIG_INET_DIAG_DESTROY is not set # CONFIG_TCP_CONG_ADVANCED is not set CONFIG_TCP_CONG_CUBIC=y @@ -819,6 +822,8 @@ CONFIG_IPV6_NDISC_NODETYPE=y # CONFIG_IPV6_FOU_TUNNEL is not set # CONFIG_IPV6_MULTIPLE_TABLES is not set # CONFIG_IPV6_MROUTE is not set +# CONFIG_IPV6_SEG6_LWTUNNEL is not set +# CONFIG_IPV6_SEG6_HMAC is not set # CONFIG_NETLABEL is not set # CONFIG_NETWORK_SECMARK is not set CONFIG_NET_PTP_CLASSIFY=y @@ -835,6 +840,7 @@ CONFIG_NETFILTER_INGRESS=y # CONFIG_NETFILTER_NETLINK_QUEUE is not set # CONFIG_NETFILTER_NETLINK_LOG is not set # CONFIG_NF_CONNTRACK is not set +# CONFIG_NF_LOG_NETDEV is not set # CONFIG_NF_TABLES is not set # CONFIG_NETFILTER_XTABLES is not set # CONFIG_IP_SET is not set @@ -844,6 +850,7 @@ CONFIG_NETFILTER_INGRESS=y # IP: Netfilter Configuration # # CONFIG_NF_DEFRAG_IPV4 is not set +# CONFIG_NF_SOCKET_IPV4 is not set # CONFIG_NF_DUP_IPV4 is not set # CONFIG_NF_LOG_ARP is not set # CONFIG_NF_LOG_IPV4 is not set @@ -855,6 +862,7 @@ CONFIG_NETFILTER_INGRESS=y # IPv6: Netfilter Configuration # # CONFIG_NF_DEFRAG_IPV6 is not set +# CONFIG_NF_SOCKET_IPV6 is not set # CONFIG_NF_DUP_IPV6 is not set # CONFIG_NF_REJECT_IPV6 is not set # CONFIG_NF_LOG_IPV6 is not set @@ -1063,6 +1071,7 @@ CONFIG_DEV_COREDUMP=y # CONFIG_DEBUG_DRIVER is not set # CONFIG_DEBUG_DEVRES is not set # CONFIG_DEBUG_TEST_DRIVER_REMOVE is not set +# CONFIG_TEST_ASYNC_DRIVER_PROBE is not set # CONFIG_SYS_HYPERVISOR is not set # CONFIG_GENERIC_CPU_DEVICES is not set CONFIG_SOC_BUS=y @@ -1072,7 +1081,7 @@ CONFIG_REGMAP_SPI=y CONFIG_REGMAP_MMIO=y CONFIG_REGMAP_IRQ=y CONFIG_DMA_SHARED_BUFFER=y -# CONFIG_FENCE_TRACE is not set +# CONFIG_DMA_FENCE_TRACE is not set CONFIG_DMA_CMA=y # @@ -1187,6 +1196,7 @@ CONFIG_MTD_NAND_IDS=y # CONFIG_MTD_NAND_NANDSIM is not set # CONFIG_MTD_NAND_BRCMNAND is not set # CONFIG_MTD_NAND_PLATFORM is not set +# CONFIG_MTD_NAND_OXNAS is not set # CONFIG_MTD_NAND_HISI504 is not set # CONFIG_MTD_NAND_MTK is not set CONFIG_MTD_ONENAND=y @@ -1239,6 +1249,7 @@ CONFIG_BLK_DEV_RAM_SIZE=16384 # CONFIG_ATA_OVER_ETH is not set # CONFIG_MG_DISK is not set # CONFIG_BLK_DEV_RBD is not set +# CONFIG_NVME_FC is not set # CONFIG_NVME_TARGET is not set # @@ -1432,6 +1443,7 @@ CONFIG_NET_CORE=y # Distributed Switch Architecture drivers # CONFIG_ETHERNET=y +CONFIG_NET_VENDOR_ALACRITECH=y # CONFIG_ALTERA_TSE is not set CONFIG_NET_VENDOR_AMAZON=y # CONFIG_NET_VENDOR_ARC is not set @@ -1461,6 +1473,7 @@ CONFIG_NET_VENDOR_RENESAS=y CONFIG_NET_VENDOR_ROCKER=y # CONFIG_NET_VENDOR_SAMSUNG is not set # CONFIG_NET_VENDOR_SEEQ is not set +CONFIG_NET_VENDOR_SOLARFLARE=y CONFIG_NET_VENDOR_SMSC=y CONFIG_SMC91X=y # CONFIG_SMC911X is not set @@ -1481,6 +1494,7 @@ CONFIG_TI_CPTS=y # CONFIG_NET_VENDOR_WIZNET is not set CONFIG_PHYLIB=y CONFIG_SWPHY=y +# CONFIG_LED_TRIGGER_PHY is not set # # MDIO bus device drivers @@ -1510,6 +1524,7 @@ CONFIG_FIXED_PHY=y # CONFIG_LSI_ET1011C_PHY is not set # CONFIG_LXT_PHY is not set # CONFIG_MARVELL_PHY is not set +# CONFIG_MESON_GXL_PHY is not set # CONFIG_MICREL_PHY is not set # CONFIG_MICROCHIP_PHY is not set # CONFIG_MICROSEMI_PHY is not set @@ -1572,6 +1587,7 @@ CONFIG_USB_CDC_PHONET=m # CONFIG_USB_VL600 is not set # CONFIG_USB_NET_CH9200 is not set CONFIG_WLAN=y +# CONFIG_WIRELESS_WDS is not set CONFIG_WLAN_VENDOR_ADMTEK=y CONFIG_WLAN_VENDOR_ATH=y # CONFIG_ATH_DEBUG is not set @@ -1740,7 +1756,7 @@ CONFIG_TOUCHSCREEN_PIXCIR=m # CONFIG_TOUCHSCREEN_TOUCHIT213 is not set # CONFIG_TOUCHSCREEN_TSC_SERIO is not set CONFIG_TOUCHSCREEN_TSC200X_CORE=m -# CONFIG_TOUCHSCREEN_TSC2004 is not set +CONFIG_TOUCHSCREEN_TSC2004=m CONFIG_TOUCHSCREEN_TSC2005=m CONFIG_TOUCHSCREEN_TSC2007=m # CONFIG_TOUCHSCREEN_RM_TS is not set @@ -1818,7 +1834,7 @@ CONFIG_UNIX98_PTYS=y # CONFIG_N_GSM is not set # CONFIG_TRACE_SINK is not set CONFIG_DEVMEM=y -CONFIG_DEVKMEM=y +# CONFIG_DEVKMEM is not set # # Serial drivers @@ -1865,7 +1881,6 @@ CONFIG_SERIAL_OMAP_CONSOLE=y # CONFIG_SERIAL_FSL_LPUART is not set # CONFIG_SERIAL_CONEXANT_DIGICOLOR is not set # CONFIG_SERIAL_ST_ASC is not set -# CONFIG_SERIAL_STM32 is not set # CONFIG_TTY_PRINTK is not set # CONFIG_HVC_DCC is not set # CONFIG_IPMI_HANDLER is not set @@ -2006,6 +2021,7 @@ CONFIG_GENERIC_PINCONF=y # CONFIG_DEBUG_PINCTRL is not set # CONFIG_PINCTRL_AMD is not set CONFIG_PINCTRL_SINGLE=y +# CONFIG_PINCTRL_SX150X is not set # CONFIG_PINCTRL_TI_IODELAY is not set # CONFIG_PINCTRL_PALMAS is not set CONFIG_ARCH_HAVE_CUSTOM_GPIO_H=y @@ -2022,7 +2038,6 @@ CONFIG_GPIO_SYSFS=y # CONFIG_GPIO_74XX_MMIO is not set # CONFIG_GPIO_ALTERA is not set # CONFIG_GPIO_DWAPB is not set -# CONFIG_GPIO_EM is not set # CONFIG_GPIO_GENERIC_PLATFORM is not set # CONFIG_GPIO_GRGPIO is not set # CONFIG_GPIO_MOCKUP is not set @@ -2031,7 +2046,6 @@ CONFIG_GPIO_OMAP=y # CONFIG_GPIO_SYSCON is not set # CONFIG_GPIO_XILINX is not set # CONFIG_GPIO_ZEVIO is not set -# CONFIG_GPIO_ZX is not set # # I2C GPIO expanders @@ -2044,12 +2058,12 @@ CONFIG_GPIO_PCA953X=m CONFIG_GPIO_PCF857X=y # CONFIG_GPIO_SX150X is not set # CONFIG_GPIO_TPIC2810 is not set -# CONFIG_GPIO_TS4900 is not set # # MFD GPIO expanders # # CONFIG_HTC_EGPIO is not set +# CONFIG_GPIO_LP873X is not set CONFIG_GPIO_PALMAS=y # CONFIG_GPIO_TPS65218 is not set # CONFIG_GPIO_TPS65910 is not set @@ -2201,6 +2215,7 @@ CONFIG_SENSORS_GPIO_FAN=m # CONFIG_SENSORS_MAX6697 is not set # CONFIG_SENSORS_MAX31790 is not set # CONFIG_SENSORS_MCP3021 is not set +# CONFIG_SENSORS_TC654 is not set # CONFIG_SENSORS_ADCXX is not set # CONFIG_SENSORS_LM63 is not set # CONFIG_SENSORS_LM70 is not set @@ -2255,6 +2270,7 @@ CONFIG_SENSORS_LM75=m # CONFIG_SENSORS_THMC50 is not set CONFIG_SENSORS_TMP102=m # CONFIG_SENSORS_TMP103 is not set +# CONFIG_SENSORS_TMP108 is not set # CONFIG_SENSORS_TMP401 is not set # CONFIG_SENSORS_TMP421 is not set # CONFIG_SENSORS_VT1211 is not set @@ -2363,7 +2379,6 @@ CONFIG_MFD_CORE=y # CONFIG_MFD_DA9063 is not set # CONFIG_MFD_DA9150 is not set # CONFIG_MFD_DLN2 is not set -# CONFIG_MFD_EXYNOS_LPASS is not set # CONFIG_MFD_MC13XXX_SPI is not set # CONFIG_MFD_MC13XXX_I2C is not set # CONFIG_MFD_HI6421_PMIC is not set @@ -2389,7 +2404,7 @@ CONFIG_MFD_CORE=y # CONFIG_MFD_VIPERBOARD is not set # CONFIG_MFD_RETU is not set # CONFIG_MFD_PCF50633 is not set -# CONFIG_MFD_PM8921_CORE is not set +# CONFIG_MFD_PM8XXX is not set # CONFIG_MFD_RT5033 is not set # CONFIG_MFD_RTSX_USB is not set # CONFIG_MFD_RC5T583 is not set @@ -2414,7 +2429,7 @@ CONFIG_MFD_PALMAS=y # CONFIG_MFD_TPS65086 is not set # CONFIG_MFD_TPS65090 is not set CONFIG_MFD_TPS65217=y -# CONFIG_MFD_TI_LP873X is not set +CONFIG_MFD_TI_LP873X=y CONFIG_MFD_TPS65218=y # CONFIG_MFD_TPS6586X is not set CONFIG_MFD_TPS65910=y @@ -2451,12 +2466,13 @@ CONFIG_REGULATOR_FIXED_VOLTAGE=y # CONFIG_REGULATOR_DA9210 is not set # CONFIG_REGULATOR_DA9211 is not set # CONFIG_REGULATOR_FAN53555 is not set -# CONFIG_REGULATOR_GPIO is not set +CONFIG_REGULATOR_GPIO=y # CONFIG_REGULATOR_ISL9305 is not set # CONFIG_REGULATOR_ISL6271A is not set # CONFIG_REGULATOR_LP3971 is not set # CONFIG_REGULATOR_LP3972 is not set CONFIG_REGULATOR_LP872X=y +CONFIG_REGULATOR_LP873X=y # CONFIG_REGULATOR_LP8755 is not set # CONFIG_REGULATOR_LTC3589 is not set # CONFIG_REGULATOR_LTC3676 is not set @@ -2494,8 +2510,8 @@ CONFIG_MEDIA_CAMERA_SUPPORT=y # CONFIG_MEDIA_RADIO_SUPPORT is not set # CONFIG_MEDIA_SDR_SUPPORT is not set CONFIG_MEDIA_RC_SUPPORT=y +# CONFIG_MEDIA_CEC_SUPPORT is not set CONFIG_MEDIA_CONTROLLER=y -# CONFIG_MEDIA_CONTROLLER_DVB is not set CONFIG_VIDEO_DEV=m CONFIG_VIDEO_V4L2_SUBDEV_API=y CONFIG_VIDEO_V4L2=m @@ -2536,6 +2552,7 @@ CONFIG_RC_DEVICES=y CONFIG_IR_RX51=m # CONFIG_RC_LOOPBACK is not set # CONFIG_IR_GPIO_CIR is not set +# CONFIG_IR_SERIAL is not set # CONFIG_MEDIA_USB_SUPPORT is not set CONFIG_V4L_PLATFORM_DRIVERS=y # CONFIG_VIDEO_OMAP2_VOUT is not set @@ -2692,19 +2709,15 @@ CONFIG_VIDEO_TVP5150=m # # Customise DVB Frontends # -CONFIG_DVB_AU8522=m -CONFIG_DVB_AU8522_V4L=m -CONFIG_DVB_TUNER_DIB0070=m -CONFIG_DVB_TUNER_DIB0090=m # # Tools to develop new frontends # -# CONFIG_DVB_DUMMY_FE is not set # # Graphics support # +# CONFIG_IMX_IPUV3_CORE is not set # CONFIG_DRM is not set # @@ -2914,7 +2927,6 @@ CONFIG_SND_OMAP_SOC_DMIC=m CONFIG_SND_OMAP_SOC_MCBSP=m CONFIG_SND_OMAP_SOC_MCPDM=m # CONFIG_SND_OMAP_SOC_HDMI_AUDIO is not set -# CONFIG_SND_OMAP_SOC_N810 is not set # CONFIG_SND_OMAP_SOC_RX51 is not set # CONFIG_SND_OMAP_SOC_AM3517EVM is not set CONFIG_SND_OMAP_SOC_OMAP_TWL4030=m @@ -2939,6 +2951,8 @@ CONFIG_SND_SOC_I2C_AND_SPI=m # CONFIG_SND_SOC_BT_SCO is not set # CONFIG_SND_SOC_CS35L32 is not set # CONFIG_SND_SOC_CS35L33 is not set +# CONFIG_SND_SOC_CS35L34 is not set +# CONFIG_SND_SOC_CS42L42 is not set # CONFIG_SND_SOC_CS42L51_I2C is not set # CONFIG_SND_SOC_CS42L52 is not set # CONFIG_SND_SOC_CS42L56 is not set @@ -2956,6 +2970,7 @@ CONFIG_SND_SOC_DMIC=m # CONFIG_SND_SOC_INNO_RK3036 is not set # CONFIG_SND_SOC_MAX98504 is not set # CONFIG_SND_SOC_MAX9860 is not set +# CONFIG_SND_SOC_MSM8916_WCD_DIGITAL is not set # CONFIG_SND_SOC_PCM1681 is not set # CONFIG_SND_SOC_PCM179X_I2C is not set # CONFIG_SND_SOC_PCM179X_SPI is not set @@ -3063,6 +3078,7 @@ CONFIG_HID_GENERIC=m # CONFIG_HID_LENOVO is not set # CONFIG_HID_LOGITECH is not set # CONFIG_HID_MAGICMOUSE is not set +# CONFIG_HID_MAYFLASH is not set # CONFIG_HID_MICROSOFT is not set # CONFIG_HID_MONTEREY is not set # CONFIG_HID_MULTITOUCH is not set @@ -3088,6 +3104,7 @@ CONFIG_HID_GENERIC=m # CONFIG_HID_TOPSEED is not set # CONFIG_HID_THINGM is not set # CONFIG_HID_THRUSTMASTER is not set +# CONFIG_HID_UDRAW_PS3 is not set # CONFIG_HID_WACOM is not set # CONFIG_HID_WIIMOTE is not set # CONFIG_HID_XINMO is not set @@ -3250,6 +3267,7 @@ CONFIG_USB_SERIAL_FTDI_SIO=m # CONFIG_USB_SERIAL_EDGEPORT is not set # CONFIG_USB_SERIAL_EDGEPORT_TI is not set # CONFIG_USB_SERIAL_F81232 is not set +# CONFIG_USB_SERIAL_F8153X is not set # CONFIG_USB_SERIAL_GARMIN is not set # CONFIG_USB_SERIAL_IPW is not set # CONFIG_USB_SERIAL_IUU is not set @@ -3408,10 +3426,6 @@ CONFIG_MMC=y # CONFIG_MMC_DEBUG is not set CONFIG_PWRSEQ_EMMC=y CONFIG_PWRSEQ_SIMPLE=y - -# -# MMC/SD/SDIO Card Drivers -# CONFIG_MMC_BLOCK=y CONFIG_MMC_BLOCK_MINORS=8 CONFIG_MMC_BLOCK_BOUNCE=y @@ -3466,6 +3480,7 @@ CONFIG_LEDS_PWM=m # LED driver for blink(1) USB RGB LED is under Special HID drivers (HID_THINGM) # # CONFIG_LEDS_BLINKM is not set +# CONFIG_LEDS_USER is not set # # LED Triggers @@ -3594,6 +3609,7 @@ CONFIG_RTC_I2C_AND_SPI=y # CONFIG_RTC_DRV_OMAP=m # CONFIG_RTC_DRV_SNVS is not set +# CONFIG_RTC_DRV_R7301 is not set # # HID Sensor RTC drivers @@ -3665,6 +3681,13 @@ CONFIG_COMMON_CLK_PALMAS=m # CONFIG_COMMON_CLK_PWM is not set # CONFIG_COMMON_CLK_PXA is not set # CONFIG_COMMON_CLK_PIC32 is not set +# CONFIG_COMMON_CLK_MT2701 is not set +# CONFIG_COMMON_CLK_MT2701_MMSYS is not set +# CONFIG_COMMON_CLK_MT2701_IMGSYS is not set +# CONFIG_COMMON_CLK_MT2701_VDECSYS is not set +# CONFIG_COMMON_CLK_MT2701_HIFSYS is not set +# CONFIG_COMMON_CLK_MT2701_ETHSYS is not set +# CONFIG_COMMON_CLK_MT2701_BDPSYS is not set CONFIG_COMMON_CLK_TI_ADPLL=y # @@ -3704,9 +3727,7 @@ CONFIG_OMAP_IOMMU=y # # Remoteproc drivers # -# CONFIG_OMAP_REMOTEPROC is not set -# CONFIG_STE_MODEM_RPROC is not set -# CONFIG_WKUP_M3_RPROC is not set +# CONFIG_REMOTEPROC is not set # # Rpmsg drivers @@ -3755,8 +3776,11 @@ CONFIG_IIO_KFIFO_BUF=m # CONFIG_BMA180 is not set # CONFIG_BMA220 is not set # CONFIG_BMC150_ACCEL is not set +# CONFIG_DA280 is not set +# CONFIG_DA311 is not set # CONFIG_DMARD06 is not set # CONFIG_DMARD09 is not set +# CONFIG_DMARD10 is not set # CONFIG_IIO_ST_ACCEL_3AXIS is not set # CONFIG_KXSD9 is not set # CONFIG_KXCJK1013 is not set @@ -3769,6 +3793,7 @@ CONFIG_IIO_KFIFO_BUF=m # CONFIG_MMA9553 is not set # CONFIG_MXC4005 is not set # CONFIG_MXC6255 is not set +# CONFIG_SCA3000 is not set # CONFIG_STK8312 is not set # CONFIG_STK8BA50 is not set @@ -3779,12 +3804,14 @@ CONFIG_IIO_KFIFO_BUF=m # CONFIG_AD7291 is not set # CONFIG_AD7298 is not set # CONFIG_AD7476 is not set +# CONFIG_AD7766 is not set # CONFIG_AD7791 is not set # CONFIG_AD7793 is not set # CONFIG_AD7887 is not set # CONFIG_AD7923 is not set # CONFIG_AD799X is not set # CONFIG_CC10001_ADC is not set +# CONFIG_ENVELOPE_DETECTOR is not set # CONFIG_HI8435 is not set # CONFIG_INA2XX_ADC is not set # CONFIG_LTC2485 is not set @@ -3827,6 +3854,10 @@ CONFIG_TI_AM335X_ADC=m # # CONFIG_IIO_SSP_SENSORHUB is not set +# +# Counters +# + # # Digital to analog converters # @@ -3847,6 +3878,7 @@ CONFIG_TI_AM335X_ADC=m # CONFIG_AD5791 is not set # CONFIG_AD7303 is not set # CONFIG_AD8801 is not set +# CONFIG_DPOT_DAC is not set # CONFIG_M62332 is not set # CONFIG_MAX517 is not set # CONFIG_MAX5821 is not set @@ -3881,6 +3913,7 @@ CONFIG_TI_AM335X_ADC=m # CONFIG_ADIS16260 is not set # CONFIG_ADXRS450 is not set # CONFIG_BMG160 is not set +# CONFIG_MPU3050_I2C is not set # CONFIG_IIO_ST_GYRO_3AXIS is not set # CONFIG_ITG3200 is not set @@ -3901,6 +3934,7 @@ CONFIG_TI_AM335X_ADC=m # CONFIG_AM2315 is not set # CONFIG_DHT11 is not set # CONFIG_HDC100X is not set +# CONFIG_HTS221 is not set # CONFIG_HTU21 is not set # CONFIG_SI7005 is not set # CONFIG_SI7020 is not set @@ -3929,6 +3963,7 @@ CONFIG_TI_AM335X_ADC=m # CONFIG_CM3323 is not set # CONFIG_CM36651 is not set # CONFIG_GP2AP020A00F is not set +# CONFIG_SENSORS_ISL29018 is not set # CONFIG_ISL29125 is not set # CONFIG_JSA1212 is not set # CONFIG_RPR0521 is not set @@ -3941,6 +3976,7 @@ CONFIG_TI_AM335X_ADC=m # CONFIG_TCS3414 is not set # CONFIG_TCS3472 is not set # CONFIG_SENSORS_TSL2563 is not set +# CONFIG_TSL2583 is not set # CONFIG_TSL4531 is not set # CONFIG_US5182D is not set # CONFIG_VCNL4000 is not set @@ -3973,9 +4009,15 @@ CONFIG_TI_AM335X_ADC=m # CONFIG_MCP4531 is not set # CONFIG_TPL0102 is not set +# +# Digital potentiostats +# +# CONFIG_LMP91000 is not set + # # Pressure sensors # +# CONFIG_ABP060MG is not set CONFIG_BMP280=m CONFIG_BMP280_I2C=m CONFIG_BMP280_SPI=m @@ -4069,6 +4111,10 @@ CONFIG_NVMEM=m # CONFIG_FW_CFG_SYSFS is not set CONFIG_HAVE_ARM_SMCCC=y +# +# Tegra firmware driver +# + # # File systems # @@ -4185,7 +4231,7 @@ CONFIG_UBIFS_FS=y CONFIG_UBIFS_FS_LZO=y CONFIG_UBIFS_FS_ZLIB=y # CONFIG_UBIFS_ATIME_SUPPORT is not set -# CONFIG_LOGFS is not set +# CONFIG_UBIFS_FS_ENCRYPTION is not set CONFIG_CRAMFS=y # CONFIG_SQUASHFS is not set # CONFIG_VXFS_FS is not set @@ -4198,7 +4244,6 @@ CONFIG_CRAMFS=y # CONFIG_PSTORE is not set # CONFIG_SYSV_FS is not set # CONFIG_UFS_FS is not set -# CONFIG_AUFS_FS is not set CONFIG_NETWORK_FILESYSTEMS=y CONFIG_NFS_FS=y CONFIG_NFS_V2=y @@ -4285,6 +4330,7 @@ CONFIG_NLS_ISO8859_1=y # printk and dmesg options # CONFIG_PRINTK_TIME=y +CONFIG_CONSOLE_LOGLEVEL_DEFAULT=7 CONFIG_MESSAGE_LOGLEVEL_DEFAULT=4 # CONFIG_BOOT_PRINTK_DELAY is not set # CONFIG_DYNAMIC_DEBUG is not set @@ -4453,6 +4499,7 @@ CONFIG_TRACING_EVENTS_GPIO=y # CONFIG_TEST_UDELAY is not set # CONFIG_MEMTEST is not set # CONFIG_TEST_STATIC_KEYS is not set +# CONFIG_BUG_ON_DATA_CORRUPTION is not set # CONFIG_SAMPLES is not set CONFIG_HAVE_ARCH_KGDB=y # CONFIG_KGDB is not set @@ -4517,6 +4564,7 @@ CONFIG_CRYPTO_RNG2=y CONFIG_CRYPTO_RNG_DEFAULT=m CONFIG_CRYPTO_AKCIPHER2=y CONFIG_CRYPTO_KPP2=y +CONFIG_CRYPTO_ACOMP2=y # CONFIG_CRYPTO_RSA is not set # CONFIG_CRYPTO_DH is not set # CONFIG_CRYPTO_ECDH is not set @@ -4629,6 +4677,7 @@ CONFIG_CRYPTO_JITTERENTROPY=m # CONFIG_CRYPTO_USER_API_RNG is not set # CONFIG_CRYPTO_USER_API_AEAD is not set CONFIG_CRYPTO_HW=y +# CONFIG_CRYPTO_DEV_FSL_CAAM_CRYPTO_API_DESC is not set # CONFIG_CRYPTO_DEV_OMAP_SHAM is not set # CONFIG_CRYPTO_DEV_OMAP_AES is not set # CONFIG_CRYPTO_DEV_OMAP_DES is not set diff --git a/patches/soc/imx/0002-mcimx6ul-bb-and-ism43362-b81-evb.patch b/patches/soc/imx/0002-mcimx6ul-bb-and-ism43362-b81-evb.patch index f8cd49fd94867d6b9750192bcd0d366708daa484..0d7367b06dfb299b0e064b5eba26c3ea7927aafd 100644 --- a/patches/soc/imx/0002-mcimx6ul-bb-and-ism43362-b81-evb.patch +++ b/patches/soc/imx/0002-mcimx6ul-bb-and-ism43362-b81-evb.patch @@ -1,33 +1,33 @@ -From 1fa392187efc7d98f8afa8ebe08df0fb063c6e78 Mon Sep 17 00:00:00 2001 +From c7375ef8c4515b74632d676b4ab39203c825ac3b Mon Sep 17 00:00:00 2001 From: Robert Nelson <robertcnelson@gmail.com> -Date: Sat, 8 Oct 2016 11:19:36 -0500 +Date: Fri, 16 Dec 2016 10:13:25 -0600 Subject: [PATCH 2/2] mcimx6ul-bb and ism43362-b81-evb Signed-off-by: Robert Nelson <robertcnelson@gmail.com> --- arch/arm/boot/dts/Makefile | 1 + - .../boot/dts/imx6ul-14x14-evk-ism43362-b81-evb.dts | 516 +++++++++++++++++++++ - 2 files changed, 517 insertions(+) + .../boot/dts/imx6ul-14x14-evk-ism43362-b81-evb.dts | 524 +++++++++++++++++++++ + 2 files changed, 525 insertions(+) create mode 100644 arch/arm/boot/dts/imx6ul-14x14-evk-ism43362-b81-evb.dts diff --git a/arch/arm/boot/dts/Makefile b/arch/arm/boot/dts/Makefile -index ae7f203..2d2be97 100644 +index 1ad4b16..9aa85b0 100644 --- a/arch/arm/boot/dts/Makefile +++ b/arch/arm/boot/dts/Makefile -@@ -427,6 +427,7 @@ dtb-$(CONFIG_SOC_IMX6SX) += \ - imx6sx-sdb.dtb +@@ -441,6 +441,7 @@ dtb-$(CONFIG_SOC_IMX6SX) += \ + imx6sx-udoo-neo-full.dtb dtb-$(CONFIG_SOC_IMX6UL) += \ imx6ul-14x14-evk.dtb \ + imx6ul-14x14-evk-ism43362-b81-evb.dtb \ imx6ul-geam-kit.dtb \ + imx6ul-liteboard.dtb \ imx6ul-pico-hobbit.dtb \ - imx6ul-tx6ul-0010.dtb \ diff --git a/arch/arm/boot/dts/imx6ul-14x14-evk-ism43362-b81-evb.dts b/arch/arm/boot/dts/imx6ul-14x14-evk-ism43362-b81-evb.dts new file mode 100644 -index 0000000..9ba86b8 +index 0000000..75ddec4 --- /dev/null +++ b/arch/arm/boot/dts/imx6ul-14x14-evk-ism43362-b81-evb.dts -@@ -0,0 +1,516 @@ +@@ -0,0 +1,524 @@ +/* + * Copyright (C) 2015 Freescale Semiconductor, Inc. + * @@ -265,7 +265,7 @@ index 0000000..9ba86b8 +}; + +&usbotg1 { -+ dr_mode = "peripheral"; ++ dr_mode = "otg"; + status = "okay"; +}; + @@ -275,6 +275,14 @@ index 0000000..9ba86b8 + status = "okay"; +}; + ++&usbphy1 { ++ fsl,tx-d-cal = <106>; ++}; ++ ++&usbphy2 { ++ fsl,tx-d-cal = <106>; ++}; ++ +®_sd1_vmmc { + regulator-always-on; +}; @@ -545,5 +553,5 @@ index 0000000..9ba86b8 + }; +}; -- -2.9.3 +2.10.2 diff --git a/patches/soc/imx/udoo/0004-usb-core-add-power-sequence-handling-for-USB-devices.patch b/patches/soc/imx/udoo/0004-usb-core-add-power-sequence-handling-for-USB-devices.patch index 7d827b76a87e2983c6c9cc79c4c8ee6c458cdb82..a975c68139d9ce6a2f8dc97e15093d140de71419 100644 --- a/patches/soc/imx/udoo/0004-usb-core-add-power-sequence-handling-for-USB-devices.patch +++ b/patches/soc/imx/udoo/0004-usb-core-add-power-sequence-handling-for-USB-devices.patch @@ -25,18 +25,18 @@ Reviewed-by: Vaibhav Hiremath <hvaibhav.linux@gmail.com> 2 files changed, 39 insertions(+), 3 deletions(-) diff --git a/drivers/usb/core/hub.c b/drivers/usb/core/hub.c -index cbb1467..acbbf0a 100644 +index 1fa5c0f29c64..08b5d66e5d16 100644 --- a/drivers/usb/core/hub.c +++ b/drivers/usb/core/hub.c -@@ -26,6 +26,7 @@ +@@ -28,6 +28,7 @@ #include <linux/mutex.h> #include <linux/random.h> #include <linux/pm_qos.h> +#include <linux/power/pwrseq.h> - #include <asm/uaccess.h> + #include <linux/uaccess.h> #include <asm/byteorder.h> -@@ -1695,6 +1696,7 @@ static void hub_disconnect(struct usb_interface *intf) +@@ -1645,6 +1646,7 @@ static void hub_disconnect(struct usb_interface *intf) hub->error = 0; hub_quiesce(hub, HUB_DISCONNECT); @@ -44,7 +44,7 @@ index cbb1467..acbbf0a 100644 mutex_lock(&usb_port_peer_mutex); /* Avoid races with recursively_mark_NOTATTACHED() */ -@@ -1722,12 +1724,41 @@ static void hub_disconnect(struct usb_interface *intf) +@@ -1672,12 +1674,41 @@ static void hub_disconnect(struct usb_interface *intf) kref_put(&hub->kref, hub_release); } @@ -86,7 +86,7 @@ index cbb1467..acbbf0a 100644 desc = intf->cur_altsetting; hdev = interface_to_usbdev(intf); -@@ -1832,6 +1863,7 @@ static int hub_probe(struct usb_interface *intf, const struct usb_device_id *id) +@@ -1782,6 +1813,7 @@ static int hub_probe(struct usb_interface *intf, const struct usb_device_id *id) INIT_DELAYED_WORK(&hub->leds, led_work); INIT_DELAYED_WORK(&hub->init_work, NULL); INIT_WORK(&hub->events, hub_event); @@ -94,7 +94,7 @@ index cbb1467..acbbf0a 100644 usb_get_intf(intf); usb_get_dev(hdev); -@@ -1845,11 +1877,14 @@ static int hub_probe(struct usb_interface *intf, const struct usb_device_id *id) +@@ -1795,11 +1827,14 @@ static int hub_probe(struct usb_interface *intf, const struct usb_device_id *id) if (id->driver_info & HUB_QUIRK_CHECK_PORT_AUTOSUSPEND) hub->quirk_check_port_auto_suspend = 1; @@ -113,7 +113,7 @@ index cbb1467..acbbf0a 100644 static int diff --git a/drivers/usb/core/hub.h b/drivers/usb/core/hub.h -index 34c1a7e..cd86f91 100644 +index 34c1a7e22aae..cd86f91e0342 100644 --- a/drivers/usb/core/hub.h +++ b/drivers/usb/core/hub.h @@ -78,6 +78,7 @@ struct usb_hub { @@ -125,5 +125,5 @@ index 34c1a7e..cd86f91 100644 /** -- -2.10.2 +2.11.0 diff --git a/patches/soc/ti/0001-sync-with-ti-4.4.patch b/patches/soc/ti/0001-sync-with-ti-4.4.patch index 822f32ea3db7151b1c7ebc47619d86592c662daf..aa4735d91024d474a71aefa3d39a6c73044d7dbd 100644 --- a/patches/soc/ti/0001-sync-with-ti-4.4.patch +++ b/patches/soc/ti/0001-sync-with-ti-4.4.patch @@ -1,28 +1,25 @@ -From 115c3233807a34c1f09bae95c307ec5cf2bc9e25 Mon Sep 17 00:00:00 2001 +From 44e0ab099272d20473abcf9815b1c459fde304f1 Mon Sep 17 00:00:00 2001 From: Robert Nelson <robertcnelson@gmail.com> -Date: Mon, 4 Apr 2016 11:06:52 -0500 +Date: Fri, 16 Dec 2016 10:15:02 -0600 Subject: [PATCH 1/8] sync: with ti-4.4 Signed-off-by: Robert Nelson <robertcnelson@gmail.com> --- - arch/arm/boot/dts/am335x-bone-common.dtsi | 4 ++++ - 1 file changed, 4 insertions(+) + arch/arm/boot/dts/am335x-bone-common.dtsi | 1 + + 1 file changed, 1 insertion(+) diff --git a/arch/arm/boot/dts/am335x-bone-common.dtsi b/arch/arm/boot/dts/am335x-bone-common.dtsi -index c078139..8eb69de 100644 +index e3cb3ec..3253763 100644 --- a/arch/arm/boot/dts/am335x-bone-common.dtsi +++ b/arch/arm/boot/dts/am335x-bone-common.dtsi -@@ -411,6 +411,10 @@ - status = "okay"; +@@ -414,6 +414,7 @@ + &rtc { + clocks = <&clk_32768_ck>, <&clkdiv32k_ick>; + clock-names = "ext-clk", "int-clk"; ++ system-power-controller; }; -+&rtc { -+ system-power-controller; -+}; -+ /* the cape manager */ - / { - bone_capemgr { -- 2.10.2 diff --git a/patches/soc/ti/0008-clk-ti-omap36xx-Work-around-sprz319-advisory-2.1.patch b/patches/soc/ti/0008-clk-ti-omap36xx-Work-around-sprz319-advisory-2.1.patch deleted file mode 100644 index 06af562c481b94f94503176890bddec48bfaac20..0000000000000000000000000000000000000000 --- a/patches/soc/ti/0008-clk-ti-omap36xx-Work-around-sprz319-advisory-2.1.patch +++ /dev/null @@ -1,217 +0,0 @@ -From 5f01e5787ade74056d811fce43c7d35f5f73b81b Mon Sep 17 00:00:00 2001 -From: Richard Watts <rrw@kynesim.co.uk> -Date: Fri, 2 Dec 2016 23:14:38 +0200 -Subject: [PATCH 8/8] clk: ti: omap36xx: Work around sprz319 advisory 2.1 - -The OMAP36xx DPLL5, driving EHCI USB, can be subject to a long-term -frequency drift. The frequency drift magnitude depends on the VCO update -rate, which is inversely proportional to the PLL divider. The kernel -DPLL configuration code results in a high value for the divider, leading -to a long term drift high enough to cause USB transmission errors. In -the worst case the USB PHY's ULPI interface can stop responding, -breaking USB operation completely. This manifests itself on the -Beagleboard xM by the LAN9514 reporting 'Cannot enable port 2. Maybe the -cable is bad?' in the kernel log. - -Errata sprz319 advisory 2.1 documents PLL values that minimize the -drift. Use them automatically when DPLL5 is used for USB operation, -which we detect based on the requested clock rate. The clock framework -will still compute the PLL parameters and resulting rate as usual, but -the PLL M and N values will then be overridden. This can result in the -effective clock rate being slightly different than the rate cached by -the clock framework, but won't cause any adverse effect to USB -operation. - -Signed-off-by: Richard Watts <rrw@kynesim.co.uk> -[Upported from v3.2 to v4.9] -Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> ---- - drivers/clk/ti/clk-3xxx.c | 20 +++++++------- - drivers/clk/ti/clock.h | 9 +++++++ - drivers/clk/ti/dpll.c | 19 +++++++++++++- - drivers/clk/ti/dpll3xxx.c | 67 +++++++++++++++++++++++++++++++++++++++++++++++ - 4 files changed, 104 insertions(+), 11 deletions(-) - -diff --git a/drivers/clk/ti/clk-3xxx.c b/drivers/clk/ti/clk-3xxx.c -index 8831e1a..11d8aa3 100644 ---- a/drivers/clk/ti/clk-3xxx.c -+++ b/drivers/clk/ti/clk-3xxx.c -@@ -22,13 +22,6 @@ - - #include "clock.h" - --/* -- * DPLL5_FREQ_FOR_USBHOST: USBHOST and USBTLL are the only clocks -- * that are sourced by DPLL5, and both of these require this clock -- * to be at 120 MHz for proper operation. -- */ --#define DPLL5_FREQ_FOR_USBHOST 120000000 -- - #define OMAP3430ES2_ST_DSS_IDLE_SHIFT 1 - #define OMAP3430ES2_ST_HSOTGUSB_IDLE_SHIFT 5 - #define OMAP3430ES2_ST_SSI_IDLE_SHIFT 8 -@@ -546,14 +539,21 @@ void __init omap3_clk_lock_dpll5(void) - struct clk *dpll5_clk; - struct clk *dpll5_m2_clk; - -+ /* -+ * Errata sprz319f advisory 2.1 documents a USB host clock drift issue -+ * that can be worked around using specially crafted dpll5 settings -+ * with a dpll5_m2 divider set to 8. Set the dpll5 rate to 8x the USB -+ * host clock rate, its .set_rate handler() will detect that frequency -+ * and use the errata settings. -+ */ - dpll5_clk = clk_get(NULL, "dpll5_ck"); -- clk_set_rate(dpll5_clk, DPLL5_FREQ_FOR_USBHOST); -+ clk_set_rate(dpll5_clk, OMAP3_DPLL5_FREQ_FOR_USBHOST * 8); - clk_prepare_enable(dpll5_clk); - -- /* Program dpll5_m2_clk divider for no division */ -+ /* Program dpll5_m2_clk divider */ - dpll5_m2_clk = clk_get(NULL, "dpll5_m2_ck"); - clk_prepare_enable(dpll5_m2_clk); -- clk_set_rate(dpll5_m2_clk, DPLL5_FREQ_FOR_USBHOST); -+ clk_set_rate(dpll5_m2_clk, OMAP3_DPLL5_FREQ_FOR_USBHOST); - - clk_disable_unprepare(dpll5_m2_clk); - clk_disable_unprepare(dpll5_clk); -diff --git a/drivers/clk/ti/clock.h b/drivers/clk/ti/clock.h -index 90f3f47..13c37f4 100644 ---- a/drivers/clk/ti/clock.h -+++ b/drivers/clk/ti/clock.h -@@ -257,11 +257,20 @@ long omap2_dpll_round_rate(struct clk_hw *hw, unsigned long target_rate, - unsigned long omap3_clkoutx2_recalc(struct clk_hw *hw, - unsigned long parent_rate); - -+/* -+ * OMAP3_DPLL5_FREQ_FOR_USBHOST: USBHOST and USBTLL are the only clocks -+ * that are sourced by DPLL5, and both of these require this clock -+ * to be at 120 MHz for proper operation. -+ */ -+#define OMAP3_DPLL5_FREQ_FOR_USBHOST 120000000 -+ - unsigned long omap3_dpll_recalc(struct clk_hw *hw, unsigned long parent_rate); - int omap3_dpll4_set_rate(struct clk_hw *clk, unsigned long rate, - unsigned long parent_rate); - int omap3_dpll4_set_rate_and_parent(struct clk_hw *hw, unsigned long rate, - unsigned long parent_rate, u8 index); -+int omap3_dpll5_set_rate(struct clk_hw *hw, unsigned long rate, -+ unsigned long parent_rate); - void omap3_clk_lock_dpll5(void); - - unsigned long omap4_dpll_regm4xen_recalc(struct clk_hw *hw, -diff --git a/drivers/clk/ti/dpll.c b/drivers/clk/ti/dpll.c -index 9fc8754..4b9a419 100644 ---- a/drivers/clk/ti/dpll.c -+++ b/drivers/clk/ti/dpll.c -@@ -114,6 +114,18 @@ static const struct clk_ops omap3_dpll_ck_ops = { - .round_rate = &omap2_dpll_round_rate, - }; - -+static const struct clk_ops omap3_dpll5_ck_ops = { -+ .enable = &omap3_noncore_dpll_enable, -+ .disable = &omap3_noncore_dpll_disable, -+ .get_parent = &omap2_init_dpll_parent, -+ .recalc_rate = &omap3_dpll_recalc, -+ .set_rate = &omap3_dpll5_set_rate, -+ .set_parent = &omap3_noncore_dpll_set_parent, -+ .set_rate_and_parent = &omap3_noncore_dpll_set_rate_and_parent, -+ .determine_rate = &omap3_noncore_dpll_determine_rate, -+ .round_rate = &omap2_dpll_round_rate, -+}; -+ - static const struct clk_ops omap3_dpll_per_ck_ops = { - .enable = &omap3_noncore_dpll_enable, - .disable = &omap3_noncore_dpll_disable, -@@ -474,7 +486,12 @@ static void __init of_ti_omap3_dpll_setup(struct device_node *node) - .modes = (1 << DPLL_LOW_POWER_BYPASS) | (1 << DPLL_LOCKED), - }; - -- of_ti_dpll_setup(node, &omap3_dpll_ck_ops, &dd); -+ if ((of_machine_is_compatible("ti,omap3630") || -+ of_machine_is_compatible("ti,omap36xx")) && -+ !strcmp(node->name, "dpll5_ck")) -+ of_ti_dpll_setup(node, &omap3_dpll5_ck_ops, &dd); -+ else -+ of_ti_dpll_setup(node, &omap3_dpll_ck_ops, &dd); - } - CLK_OF_DECLARE(ti_omap3_dpll_clock, "ti,omap3-dpll-clock", - of_ti_omap3_dpll_setup); -diff --git a/drivers/clk/ti/dpll3xxx.c b/drivers/clk/ti/dpll3xxx.c -index 88f2ce8..4cdd28a 100644 ---- a/drivers/clk/ti/dpll3xxx.c -+++ b/drivers/clk/ti/dpll3xxx.c -@@ -838,3 +838,70 @@ int omap3_dpll4_set_rate_and_parent(struct clk_hw *hw, unsigned long rate, - return omap3_noncore_dpll_set_rate_and_parent(hw, rate, parent_rate, - index); - } -+ -+/* Apply DM3730 errata sprz319 advisory 2.1. */ -+static bool omap3_dpll5_apply_errata(struct clk_hw *hw, -+ unsigned long parent_rate) -+{ -+ struct omap3_dpll5_settings { -+ unsigned int rate, m, n; -+ }; -+ -+ static const struct omap3_dpll5_settings precomputed[] = { -+ /* -+ * From DM3730 errata advisory 2.1, table 35 and 36. -+ * The N value is increased by 1 compared to the tables as the -+ * errata lists register values while last_rounded_field is the -+ * real divider value. -+ */ -+ { 12000000, 80, 0 + 1 }, -+ { 13000000, 443, 5 + 1 }, -+ { 19200000, 50, 0 + 1 }, -+ { 26000000, 443, 11 + 1 }, -+ { 38400000, 25, 0 + 1 } -+ }; -+ -+ const struct omap3_dpll5_settings *d; -+ struct clk_hw_omap *clk = to_clk_hw_omap(hw); -+ struct dpll_data *dd; -+ unsigned int i; -+ -+ for (i = 0; i < ARRAY_SIZE(precomputed); ++i) { -+ if (parent_rate == precomputed[i].rate) -+ break; -+ } -+ -+ if (i == ARRAY_SIZE(precomputed)) -+ return false; -+ -+ d = &precomputed[i]; -+ -+ /* Update the M, N and rounded rate values and program the DPLL. */ -+ dd = clk->dpll_data; -+ dd->last_rounded_m = d->m; -+ dd->last_rounded_n = d->n; -+ dd->last_rounded_rate = div_u64((u64)parent_rate * d->m, d->n); -+ omap3_noncore_dpll_program(clk, 0); -+ -+ return true; -+} -+ -+/** -+ * omap3_dpll5_set_rate - set rate for omap3 dpll5 -+ * @hw: clock to change -+ * @rate: target rate for clock -+ * @parent_rate: rate of the parent clock -+ * -+ * Set rate for the DPLL5 clock. Apply the sprz319 advisory 2.1 on OMAP36xx if -+ * the DPLL is used for USB host (detected through the requested rate). -+ */ -+int omap3_dpll5_set_rate(struct clk_hw *hw, unsigned long rate, -+ unsigned long parent_rate) -+{ -+ if (rate == OMAP3_DPLL5_FREQ_FOR_USBHOST * 8) { -+ if (omap3_dpll5_apply_errata(hw, parent_rate)) -+ return 0; -+ } -+ -+ return omap3_noncore_dpll_set_rate(hw, rate, parent_rate); -+} --- -2.10.2 - diff --git a/patches/soc/ti/blue/0001-ARM-dts-add-am335x-boneblue.dtb.patch b/patches/soc/ti/blue/0001-ARM-dts-add-am335x-boneblue.dtb.patch index 636eb7b7607103035b407f3ab6ee72e6e9306e55..ed87a87203303ecb924d0aab8e03c35857df1e37 100644 --- a/patches/soc/ti/blue/0001-ARM-dts-add-am335x-boneblue.dtb.patch +++ b/patches/soc/ti/blue/0001-ARM-dts-add-am335x-boneblue.dtb.patch @@ -1018,16 +1018,16 @@ index 0000000..16e9376 + status = "okay"; +}; + -+&cpu0_opp_table { -+ /* -+ * All PG 2.0 silicon may not support 1GHz but some of the early -+ * BeagleBone Blacks have PG 2.0 silicon which is guaranteed -+ * to support 1GHz OPP so enable it for PG 2.0 on this board. -+ */ -+ oppnitro@1000000000 { -+ opp-supported-hw = <0x06 0x0100>; -+ }; -+}; ++//&cpu0_opp_table { ++// /* ++// * All PG 2.0 silicon may not support 1GHz but some of the early ++// * BeagleBone Blacks have PG 2.0 silicon which is guaranteed ++// * to support 1GHz OPP so enable it for PG 2.0 on this board. ++// */ ++// oppnitro@1000000000 { ++// opp-supported-hw = <0x06 0x0100>; ++// }; ++//}; diff --git a/arch/arm/boot/dts/am335x-boneblack-wireless-roboticscape.dts b/arch/arm/boot/dts/am335x-boneblack-wireless-roboticscape.dts new file mode 100644 index 0000000..4a72d56 diff --git a/patches/ti_4.9.x/pm_opp/0002-Documentation-dt-add-bindings-for-ti-cpufreq.patch b/patches/ti_4.9.x/pm_opp/0001-Documentation-dt-add-bindings-for-ti-cpufreq.patch similarity index 97% rename from patches/ti_4.9.x/pm_opp/0002-Documentation-dt-add-bindings-for-ti-cpufreq.patch rename to patches/ti_4.9.x/pm_opp/0001-Documentation-dt-add-bindings-for-ti-cpufreq.patch index 250978ba1aea1e60f616c2680274dcead3b53a94..d3af0674c05eae8ecbfe7c8671c03e2867f99083 100644 --- a/patches/ti_4.9.x/pm_opp/0002-Documentation-dt-add-bindings-for-ti-cpufreq.patch +++ b/patches/ti_4.9.x/pm_opp/0001-Documentation-dt-add-bindings-for-ti-cpufreq.patch @@ -1,7 +1,7 @@ -From 14f6b0371f49d044f7b7f4384f528cf64e0b2977 Mon Sep 17 00:00:00 2001 +From f00aa33e1accefa17bf33cbd0be4a16b48006c4b Mon Sep 17 00:00:00 2001 From: Dave Gerlach <d-gerlach@ti.com> Date: Tue, 29 Nov 2016 18:02:16 -0600 -Subject: [PATCH] Documentation: dt: add bindings for ti-cpufreq +Subject: [PATCH 1/7] Documentation: dt: add bindings for ti-cpufreq Add the device tree bindings document for the TI CPUFreq/OPP driver on AM33xx and AM43xx SoCs. The operating-points-v2 binding allows us diff --git a/patches/ti_4.9.x/pm_opp/0003-cpufreq-ti-Add-cpufreq-driver-to-determine-available.patch b/patches/ti_4.9.x/pm_opp/0002-cpufreq-ti-Add-cpufreq-driver-to-determine-available.patch similarity index 97% rename from patches/ti_4.9.x/pm_opp/0003-cpufreq-ti-Add-cpufreq-driver-to-determine-available.patch rename to patches/ti_4.9.x/pm_opp/0002-cpufreq-ti-Add-cpufreq-driver-to-determine-available.patch index 50498d9b096ab1418a6356fec46d76b8c698d400..dd6ee763d446d4778b1d6d461327e8d0ceeac062 100644 --- a/patches/ti_4.9.x/pm_opp/0003-cpufreq-ti-Add-cpufreq-driver-to-determine-available.patch +++ b/patches/ti_4.9.x/pm_opp/0002-cpufreq-ti-Add-cpufreq-driver-to-determine-available.patch @@ -1,8 +1,8 @@ -From 78ff54d5f5f159532ba8dd2db4018f5f401796bd Mon Sep 17 00:00:00 2001 +From 787af24a89ac3ac7d7fdcd8049f26d5e8bc7af93 Mon Sep 17 00:00:00 2001 From: Dave Gerlach <d-gerlach@ti.com> Date: Tue, 29 Nov 2016 18:02:17 -0600 -Subject: [PATCH] cpufreq: ti: Add cpufreq driver to determine available OPPs - at runtime +Subject: [PATCH 2/7] cpufreq: ti: Add cpufreq driver to determine available + OPPs at runtime Some TI SoCs, like those in the AM335x, AM437x, DRA7x, and AM57x families, have different OPPs available for the MPU depending on which specific @@ -30,10 +30,10 @@ Signed-off-by: Dave Gerlach <d-gerlach@ti.com> create mode 100644 drivers/cpufreq/ti-cpufreq.c diff --git a/drivers/cpufreq/Kconfig.arm b/drivers/cpufreq/Kconfig.arm -index d89b8af..665f11d 100644 +index 920c469..6d87742 100644 --- a/drivers/cpufreq/Kconfig.arm +++ b/drivers/cpufreq/Kconfig.arm -@@ -234,6 +234,17 @@ config ARM_TEGRA124_CPUFREQ +@@ -247,6 +247,17 @@ config ARM_TEGRA124_CPUFREQ help This adds the CPUFreq driver support for Tegra124 SOCs. @@ -52,7 +52,7 @@ index d89b8af..665f11d 100644 tristate "Intel PXA2xx CPUfreq driver" depends on PXA27x || PXA25x diff --git a/drivers/cpufreq/Makefile b/drivers/cpufreq/Makefile -index 0a9b6a09..5b1b6ec 100644 +index 1e46c39..2078a0f 100644 --- a/drivers/cpufreq/Makefile +++ b/drivers/cpufreq/Makefile @@ -77,6 +77,7 @@ obj-$(CONFIG_ARM_SPEAR_CPUFREQ) += spear-cpufreq.o diff --git a/patches/ti_4.9.x/pm_opp/0004-cpufreq-dt-Don-t-use-generic-platdev-driver-for-ti-c.patch b/patches/ti_4.9.x/pm_opp/0003-cpufreq-dt-Don-t-use-generic-platdev-driver-for-ti-c.patch similarity index 73% rename from patches/ti_4.9.x/pm_opp/0004-cpufreq-dt-Don-t-use-generic-platdev-driver-for-ti-c.patch rename to patches/ti_4.9.x/pm_opp/0003-cpufreq-dt-Don-t-use-generic-platdev-driver-for-ti-c.patch index 9f446bdf93a6db7f5079342eed456714bbe5baec..1ccba523d8f88adb5b500ee66917914125a2679e 100644 --- a/patches/ti_4.9.x/pm_opp/0004-cpufreq-dt-Don-t-use-generic-platdev-driver-for-ti-c.patch +++ b/patches/ti_4.9.x/pm_opp/0003-cpufreq-dt-Don-t-use-generic-platdev-driver-for-ti-c.patch @@ -1,8 +1,8 @@ -From d4bca0c2d8c315c0aa4f7c15207a26d12974f929 Mon Sep 17 00:00:00 2001 +From 7ea8914366c31120ef5b4328a8a00f279f02084b Mon Sep 17 00:00:00 2001 From: Dave Gerlach <d-gerlach@ti.com> Date: Tue, 29 Nov 2016 18:02:18 -0600 -Subject: [PATCH] cpufreq: dt: Don't use generic platdev driver for ti-cpufreq - platforms +Subject: [PATCH 3/7] cpufreq: dt: Don't use generic platdev driver for + ti-cpufreq platforms Some TI platforms, specifically those in the am33xx, am43xx, dra7xx, and am57xx families of SoCs can make use of the ti-cpufreq driver to @@ -17,12 +17,12 @@ Signed-off-by: Dave Gerlach <d-gerlach@ti.com> 1 file changed, 2 deletions(-) diff --git a/drivers/cpufreq/cpufreq-dt-platdev.c b/drivers/cpufreq/cpufreq-dt-platdev.c -index 7126762..d2637e1 100644 +index bc97b6a..d22326f 100644 --- a/drivers/cpufreq/cpufreq-dt-platdev.c +++ b/drivers/cpufreq/cpufreq-dt-platdev.c -@@ -72,8 +72,6 @@ static const struct of_device_id machines[] __initconst = { - - { .compatible = "sigma,tango4" }, +@@ -85,8 +85,6 @@ static const struct of_device_id machines[] __initconst = { + { .compatible = "socionext,uniphier-ld11", }, + { .compatible = "socionext,uniphier-ld20", }, - { .compatible = "ti,am33xx", }, - { .compatible = "ti,dra7", }, diff --git a/patches/ti_4.9.x/pm_opp/0005-ARM-dts-am33xx-Add-updated-operating-points-v2-table.patch b/patches/ti_4.9.x/pm_opp/0004-ARM-dts-am33xx-Add-updated-operating-points-v2-table.patch similarity index 94% rename from patches/ti_4.9.x/pm_opp/0005-ARM-dts-am33xx-Add-updated-operating-points-v2-table.patch rename to patches/ti_4.9.x/pm_opp/0004-ARM-dts-am33xx-Add-updated-operating-points-v2-table.patch index cf27fbef82c472ee105edbe5bd2a0946f14e2e18..2ea4166ec11a56eaa4a8f264d407758fe5770069 100644 --- a/patches/ti_4.9.x/pm_opp/0005-ARM-dts-am33xx-Add-updated-operating-points-v2-table.patch +++ b/patches/ti_4.9.x/pm_opp/0004-ARM-dts-am33xx-Add-updated-operating-points-v2-table.patch @@ -1,8 +1,8 @@ -From c5d004835f2d162a04be591419d17864b477a789 Mon Sep 17 00:00:00 2001 +From c8fbce7db84ce92b28d0c690afb2d58681d1d2fd Mon Sep 17 00:00:00 2001 From: Dave Gerlach <d-gerlach@ti.com> Date: Tue, 29 Nov 2016 18:02:19 -0600 -Subject: [PATCH] ARM: dts: am33xx: Add updated operating-points-v2 table for - cpu +Subject: [PATCH 4/7] ARM: dts: am33xx: Add updated operating-points-v2 table + for cpu After the ti-cpufreq driver has been added, we can now drop the operating-points table present in am33xx.dtsi for the cpu and add an @@ -20,7 +20,7 @@ Signed-off-by: Dave Gerlach <d-gerlach@ti.com> 1 file changed, 75 insertions(+), 13 deletions(-) diff --git a/arch/arm/boot/dts/am33xx.dtsi b/arch/arm/boot/dts/am33xx.dtsi -index d52fa1c..c3aafe6 100644 +index 194d884..b379c24 100644 --- a/arch/arm/boot/dts/am33xx.dtsi +++ b/arch/arm/boot/dts/am33xx.dtsi @@ -45,19 +45,7 @@ diff --git a/patches/ti_4.9.x/pm_opp/0006-ARM-dts-am335x-boneblack-Enable-1GHz-OPP-for-cpu.patch b/patches/ti_4.9.x/pm_opp/0005-ARM-dts-am335x-boneblack-Enable-1GHz-OPP-for-cpu.patch similarity index 89% rename from patches/ti_4.9.x/pm_opp/0006-ARM-dts-am335x-boneblack-Enable-1GHz-OPP-for-cpu.patch rename to patches/ti_4.9.x/pm_opp/0005-ARM-dts-am335x-boneblack-Enable-1GHz-OPP-for-cpu.patch index 753446643aad034ea79b9adb666e63c6d6917ddc..997c32b1325061304ed4b17366b7590d98aa88a8 100644 --- a/patches/ti_4.9.x/pm_opp/0006-ARM-dts-am335x-boneblack-Enable-1GHz-OPP-for-cpu.patch +++ b/patches/ti_4.9.x/pm_opp/0005-ARM-dts-am335x-boneblack-Enable-1GHz-OPP-for-cpu.patch @@ -1,7 +1,7 @@ -From 85fd3abebe7191cfcf70f4fbf9b1c7e31369129b Mon Sep 17 00:00:00 2001 +From 5e5e80fe44b83d79d9540ce6f5f28acd9612d256 Mon Sep 17 00:00:00 2001 From: Dave Gerlach <d-gerlach@ti.com> Date: Tue, 29 Nov 2016 18:02:20 -0600 -Subject: [PATCH] ARM: dts: am335x-boneblack: Enable 1GHz OPP for cpu +Subject: [PATCH 5/7] ARM: dts: am335x-boneblack: Enable 1GHz OPP for cpu Although all PG2.0 silicon may not support 1GHz OPP for the MPU, older Beaglebone Blacks may have PG2.0 silicon populated and these particular diff --git a/patches/ti_4.9.x/pm_opp/0007-ARM-dts-am4372-Update-operating-points-v2-table-for-.patch b/patches/ti_4.9.x/pm_opp/0006-ARM-dts-am4372-Update-operating-points-v2-table-for-.patch similarity index 88% rename from patches/ti_4.9.x/pm_opp/0007-ARM-dts-am4372-Update-operating-points-v2-table-for-.patch rename to patches/ti_4.9.x/pm_opp/0006-ARM-dts-am4372-Update-operating-points-v2-table-for-.patch index cab94edaf6a660139f4f48cdfdaa6d164ab2682b..738a96b5d4ae8a23536d148841b01f9ed70f4a7f 100644 --- a/patches/ti_4.9.x/pm_opp/0007-ARM-dts-am4372-Update-operating-points-v2-table-for-.patch +++ b/patches/ti_4.9.x/pm_opp/0006-ARM-dts-am4372-Update-operating-points-v2-table-for-.patch @@ -1,7 +1,8 @@ -From d99c96b19e5d2821689c4c3ba97479289dbe9f79 Mon Sep 17 00:00:00 2001 +From 760aa1effb63f92c4b045422ca74cc7b120f2b48 Mon Sep 17 00:00:00 2001 From: Dave Gerlach <d-gerlach@ti.com> Date: Tue, 29 Nov 2016 18:02:21 -0600 -Subject: [PATCH] ARM: dts: am4372: Update operating-points-v2 table for cpu +Subject: [PATCH 6/7] ARM: dts: am4372: Update operating-points-v2 table for + cpu The new ti-cpufreq driver expects the platform specific properties to be part of the operating-points-v2 table rather than the cpu node so let's diff --git a/patches/ti_4.9.x/pm_opp/0008-ARM-dts-dra7-Add-updated-operating-points-v2-table-f.patch b/patches/ti_4.9.x/pm_opp/0007-ARM-dts-dra7-Add-updated-operating-points-v2-table-f.patch similarity index 94% rename from patches/ti_4.9.x/pm_opp/0008-ARM-dts-dra7-Add-updated-operating-points-v2-table-f.patch rename to patches/ti_4.9.x/pm_opp/0007-ARM-dts-dra7-Add-updated-operating-points-v2-table-f.patch index acfe0d7d75ead5d4b9f9ddca131906d449cc3d3a..aad4ed7d86c9dfe9b4e15462697380b03351710c 100644 --- a/patches/ti_4.9.x/pm_opp/0008-ARM-dts-dra7-Add-updated-operating-points-v2-table-f.patch +++ b/patches/ti_4.9.x/pm_opp/0007-ARM-dts-dra7-Add-updated-operating-points-v2-table-f.patch @@ -1,7 +1,8 @@ -From 3bf60fbfab08b34cead5549b414fb2ed47e512b9 Mon Sep 17 00:00:00 2001 +From c7c95a29bc80c4d04eb4a4b4daa8b519df60b6ac Mon Sep 17 00:00:00 2001 From: Dave Gerlach <d-gerlach@ti.com> Date: Tue, 29 Nov 2016 18:02:22 -0600 -Subject: [PATCH] ARM: dts: dra7: Add updated operating-points-v2 table for cpu +Subject: [PATCH 7/7] ARM: dts: dra7: Add updated operating-points-v2 table for + cpu After the ti-cpufreq driver has been added, we can now drop the operating-points table present in dra7.dtsi for the cpu and add an diff --git a/patches/ti_4.9.x/pm_opp/0001-PM-OPP-Expose-_of_get_opp_desc_node-as-dev_pm_opp-AP.patch b/patches/ti_4.9.x/pm_opp/0008-PM-OPP-Expose-_of_get_opp_desc_node-as-dev_pm_opp-AP.patch similarity index 50% rename from patches/ti_4.9.x/pm_opp/0001-PM-OPP-Expose-_of_get_opp_desc_node-as-dev_pm_opp-AP.patch rename to patches/ti_4.9.x/pm_opp/0008-PM-OPP-Expose-_of_get_opp_desc_node-as-dev_pm_opp-AP.patch index 551cef86f6fe91db542908c810da6a6ea9a347cd..de75330bbffacf1d6c5ad051532276de3e086305 100644 --- a/patches/ti_4.9.x/pm_opp/0001-PM-OPP-Expose-_of_get_opp_desc_node-as-dev_pm_opp-AP.patch +++ b/patches/ti_4.9.x/pm_opp/0008-PM-OPP-Expose-_of_get_opp_desc_node-as-dev_pm_opp-AP.patch @@ -1,7 +1,7 @@ -From b3ba20b199ddd8bbb77c03bef1ad854da9cffec2 Mon Sep 17 00:00:00 2001 +From adca00fe4f9eefcc5239971b3f459172d2c332b4 Mon Sep 17 00:00:00 2001 From: Dave Gerlach <d-gerlach@ti.com> Date: Tue, 29 Nov 2016 18:02:15 -0600 -Subject: [PATCH] PM / OPP: Expose _of_get_opp_desc_node as dev_pm_opp API +Subject: [PATCH 8/8] PM / OPP: Expose _of_get_opp_desc_node as dev_pm_opp API Move _of_get_opp_desc_node into include/linux/pm_opp.h and rename it dev_pm_opp_of_get_opp_desc_node to allow other drivers, such as platform @@ -9,25 +9,15 @@ OPP and cpufreq drivers, to make use of it. Signed-off-by: Dave Gerlach <d-gerlach@ti.com> --- - drivers/base/power/opp/of.c | 9 +++++---- - drivers/base/power/opp/opp.h | 1 - - include/linux/pm_opp.h | 6 ++++++ - 3 files changed, 11 insertions(+), 5 deletions(-) + drivers/base/power/opp/of.c | 7 ++++--- + include/linux/pm_opp.h | 6 ++++++ + 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/drivers/base/power/opp/of.c b/drivers/base/power/opp/of.c -index 5552211..9c8cfb6 100644 +index 3f7d259..618f018 100644 --- a/drivers/base/power/opp/of.c +++ b/drivers/base/power/opp/of.c -@@ -198,7 +198,7 @@ void dev_pm_opp_of_remove_table(struct device *dev) - EXPORT_SYMBOL_GPL(dev_pm_opp_of_remove_table); - - /* Returns opp descriptor node for a device, caller must do of_node_put() */ --struct device_node *_of_get_opp_desc_node(struct device *dev) -+struct device_node *dev_pm_opp_of_get_opp_desc_node(struct device *dev) - { - /* - * TODO: Support for multiple OPP tables. -@@ -209,6 +209,7 @@ struct device_node *_of_get_opp_desc_node(struct device *dev) +@@ -254,6 +254,7 @@ static struct device_node *_of_get_opp_desc_node(struct device *dev) return of_parse_phandle(dev->of_node, "operating-points-v2", 0); } @@ -35,7 +25,7 @@ index 5552211..9c8cfb6 100644 /** * _opp_add_static_v2() - Allocate static OPPs (As per 'v2' DT bindings) -@@ -450,7 +451,7 @@ int dev_pm_opp_of_add_table(struct device *dev) +@@ -495,7 +496,7 @@ int dev_pm_opp_of_add_table(struct device *dev) * OPPs have two version of bindings now. The older one is deprecated, * try for the new binding first. */ @@ -44,41 +34,29 @@ index 5552211..9c8cfb6 100644 if (!opp_np) { /* * Try old-deprecated bindings for backward compatibility with -@@ -560,7 +561,7 @@ int dev_pm_opp_of_get_sharing_cpus(struct device *cpu_dev, +@@ -605,7 +606,7 @@ int dev_pm_opp_of_get_sharing_cpus(struct device *cpu_dev, int cpu, ret = 0; /* Get OPP descriptor node */ - np = _of_get_opp_desc_node(cpu_dev); + np = dev_pm_opp_of_get_opp_desc_node(cpu_dev); if (!np) { - dev_dbg(cpu_dev, "%s: Couldn't find cpu_dev node.\n", __func__); + dev_dbg(cpu_dev, "%s: Couldn't find opp node.\n", __func__); return -ENOENT; -@@ -585,7 +586,7 @@ int dev_pm_opp_of_get_sharing_cpus(struct device *cpu_dev, +@@ -630,7 +631,7 @@ int dev_pm_opp_of_get_sharing_cpus(struct device *cpu_dev, } /* Get OPP descriptor node */ - tmp_np = _of_get_opp_desc_node(tcpu_dev); + tmp_np = dev_pm_opp_of_get_opp_desc_node(tcpu_dev); if (!tmp_np) { - dev_err(tcpu_dev, "%s: Couldn't find tcpu_dev node.\n", + dev_err(tcpu_dev, "%s: Couldn't find opp node.\n", __func__); -diff --git a/drivers/base/power/opp/opp.h b/drivers/base/power/opp/opp.h -index fabd5ca..96cd30a 100644 ---- a/drivers/base/power/opp/opp.h -+++ b/drivers/base/power/opp/opp.h -@@ -190,7 +190,6 @@ struct opp_table { - /* Routines internal to opp core */ - struct opp_table *_find_opp_table(struct device *dev); - struct opp_device *_add_opp_dev(const struct device *dev, struct opp_table *opp_table); --struct device_node *_of_get_opp_desc_node(struct device *dev); - void _dev_pm_opp_remove_table(struct device *dev, bool remove_all); - struct dev_pm_opp *_allocate_opp(struct device *dev, struct opp_table **opp_table); - int _opp_add(struct device *dev, struct dev_pm_opp *new_opp, struct opp_table *opp_table); diff --git a/include/linux/pm_opp.h b/include/linux/pm_opp.h -index bca2615..9e8c138 100644 +index 0edd88f..a5b1aae 100644 --- a/include/linux/pm_opp.h +++ b/include/linux/pm_opp.h -@@ -208,6 +208,7 @@ void dev_pm_opp_of_remove_table(struct device *dev); +@@ -270,6 +270,7 @@ void dev_pm_opp_of_remove_table(struct device *dev); int dev_pm_opp_of_cpumask_add_table(const struct cpumask *cpumask); void dev_pm_opp_of_cpumask_remove_table(const struct cpumask *cpumask); int dev_pm_opp_of_get_sharing_cpus(struct device *cpu_dev, struct cpumask *cpumask); @@ -86,7 +64,7 @@ index bca2615..9e8c138 100644 #else static inline int dev_pm_opp_of_add_table(struct device *dev) { -@@ -231,6 +232,11 @@ static inline int dev_pm_opp_of_get_sharing_cpus(struct device *cpu_dev, struct +@@ -293,6 +294,11 @@ static inline int dev_pm_opp_of_get_sharing_cpus(struct device *cpu_dev, struct { return -ENOTSUPP; } diff --git a/version.sh b/version.sh index b4fac9d7b2ca19b385ed7b83c998ff1097664d6e..2efbe4f334a6265ddeaf2fb7613caebed5cd00d0 100644 --- a/version.sh +++ b/version.sh @@ -26,9 +26,9 @@ toolchain="gcc_linaro_gnueabihf_6" #toolchain="gcc_linaro_aarch64_gnu_6" #Kernel/Build -KERNEL_REL=4.9 -KERNEL_TAG=${KERNEL_REL} -BUILD=${build_prefix}4 +KERNEL_REL=4.10 +KERNEL_TAG=${KERNEL_REL}-rc1 +BUILD=${build_prefix}0 kernel_rt=".X-rtY" #v4.X-rcX + upto SHA