linux-google-veyron: separate from linux-postmarketos-rockchip and upgrade to 6.0 (MR 3524)
Also, add patches for better HDMI support
This commit is contained in:
parent
325cc8e483
commit
bc70ccdcf4
7 changed files with 9061 additions and 0 deletions
77
device/testing/linux-google-veyron/APKBUILD
Normal file
77
device/testing/linux-google-veyron/APKBUILD
Normal file
|
@ -0,0 +1,77 @@
|
||||||
|
# Maintainer: Jenneron <jenneron@protonmail.com>
|
||||||
|
pkgname=linux-google-veyron
|
||||||
|
pkgver=6.0
|
||||||
|
pkgrel=0
|
||||||
|
pkgdesc="Mainline kernel for Google Veyron devices"
|
||||||
|
arch="armv7"
|
||||||
|
_carch="arm"
|
||||||
|
_flavor="${pkgname#linux-}"
|
||||||
|
url="https://kernel.org"
|
||||||
|
license="GPL-2.0-only"
|
||||||
|
options="!strip !check !tracedeps
|
||||||
|
pmb:cross-native
|
||||||
|
pmb:kconfigcheck-community
|
||||||
|
"
|
||||||
|
makedepends="
|
||||||
|
bash
|
||||||
|
bison
|
||||||
|
devicepkg-dev
|
||||||
|
findutils
|
||||||
|
flex
|
||||||
|
installkernel
|
||||||
|
openssl-dev
|
||||||
|
perl
|
||||||
|
rsync
|
||||||
|
gzip
|
||||||
|
xz
|
||||||
|
gmp-dev
|
||||||
|
mpc1-dev
|
||||||
|
mpfr-dev
|
||||||
|
"
|
||||||
|
_config="config-$_flavor.$arch"
|
||||||
|
case $pkgver in
|
||||||
|
*.*.*) _kernver=${pkgver%.0};;
|
||||||
|
*.*) _kernver=$pkgver;;
|
||||||
|
esac
|
||||||
|
source="
|
||||||
|
https://cdn.kernel.org/pub/linux/kernel/v6.x/linux-${pkgver//_/-}.tar.xz
|
||||||
|
$_config
|
||||||
|
veyron.better_clock_selection_logic_and_dts_rate_list.patch
|
||||||
|
veyron.dts_allow_dedicating_npll_to_vop.patch
|
||||||
|
veyron.dts_do_dedicate_npll_to_vop.patch
|
||||||
|
veyron.ignore-gpt-ignoreme.patch
|
||||||
|
veyron.support_dedicating_npll_to_vop.patch
|
||||||
|
"
|
||||||
|
builddir="$srcdir/linux-$_kernver"
|
||||||
|
replaces="linux-postmarketos-rockchip"
|
||||||
|
|
||||||
|
prepare() {
|
||||||
|
default_prepare
|
||||||
|
cp "$srcdir/config-$_flavor.$CARCH" .config
|
||||||
|
}
|
||||||
|
|
||||||
|
build() {
|
||||||
|
unset LDFLAGS
|
||||||
|
make ARCH="$_carch" \
|
||||||
|
KBUILD_BUILD_VERSION="$((pkgrel + 1 ))-$_flavor"
|
||||||
|
}
|
||||||
|
|
||||||
|
package() {
|
||||||
|
downstreamkernel_package "$builddir" "$pkgdir" "$_carch" "$_flavor"
|
||||||
|
|
||||||
|
make -j1 modules_install dtbs_install \
|
||||||
|
ARCH="$_carch" \
|
||||||
|
INSTALL_MOD_STRIP=1 \
|
||||||
|
INSTALL_MOD_PATH="$pkgdir" \
|
||||||
|
INSTALL_DTBS_PATH="$pkgdir/boot/dtbs"
|
||||||
|
}
|
||||||
|
|
||||||
|
sha512sums="
|
||||||
|
bac41a7aeb6e809616cee2f13dcd1c45e829dfd1ccf60aee1dc4c46b1e28532f4485c7d819a32940de84fdfbf89db80a4e919bce8a74b2948c5a01551771b714 linux-6.0.tar.xz
|
||||||
|
f57790174d117cc6b58cbab5cfc26144d02b28c53fe346824cb5714551f723609eb551bdaa336deec6b996ab7022518ca3a9d4349b2d22e9fb5240475a405f5d config-google-veyron.armv7
|
||||||
|
2912c675c1e07f7e91e2edcaa82738643907ed46614e4b871565930ff4ffece468d47db7905c2c081f936c020ea78db4a9d9f33b76c110125a0e68a1bd57f9fd veyron.better_clock_selection_logic_and_dts_rate_list.patch
|
||||||
|
b16da0e0b1da9f074a773300e954aa5e0da6c2113e20c0b594a7a4875e9addb10efcf5be694467fb00cd8d7c2e3cc83e6d7aac618047775dc0bb354245cf7c35 veyron.dts_allow_dedicating_npll_to_vop.patch
|
||||||
|
b7bda162526abdb61c0223f1aac31893526d3d1d21d79ebd3e707be8d9b5dc464f6b4fa20b74444c44fda987352728433913f6f50b9b860c2621d11ae2306e1b veyron.dts_do_dedicate_npll_to_vop.patch
|
||||||
|
67f49d49457eed7ae2de4582d53602743dc9c785720527d713e9b14a027a4716c755cf56e5188641cb69b35c5a561f298fa4cf2b37751696768e76e534139f40 veyron.ignore-gpt-ignoreme.patch
|
||||||
|
30e78435b3ef7a1e2ca304297f3bb446e12acd416158707b98b4e38aa31871acac24a6671317bae752a25732534e3f273cd9ab5bf909d920b4b277a69aa11da2 veyron.support_dedicating_npll_to_vop.patch
|
||||||
|
"
|
8109
device/testing/linux-google-veyron/config-google-veyron.armv7
Normal file
8109
device/testing/linux-google-veyron/config-google-veyron.armv7
Normal file
File diff suppressed because it is too large
Load diff
|
@ -0,0 +1,439 @@
|
||||||
|
From invalid-sha-id-22080c28e92f466d396bfe2be Mon Sep 17 00:00:00 2001
|
||||||
|
From: Urja Rannikko <urjaman@gmail.com>
|
||||||
|
Date: Wed, 22 Aug 2018 18:36:40 +0000
|
||||||
|
Subject: [PATCH] drm: dw_hdmi-rockchip: better clock selection logic and
|
||||||
|
dts-based rate list
|
||||||
|
|
||||||
|
This contains traces of the following commits from the ChromeOS 3.14
|
||||||
|
tree, which improve RF/EMI performance and detach the clock selection
|
||||||
|
logic from the HDMI PHY configurations, plus support for configuring
|
||||||
|
the allowed clock rates via device tree as they are dependent on
|
||||||
|
PLL configuration and maybe even the PCB layout and other hardware things,
|
||||||
|
eg. interference to wifi or such (EMI).
|
||||||
|
|
||||||
|
Rates that were allowed previous to this patch are added as the fallback
|
||||||
|
list if no dts configuration exists.
|
||||||
|
|
||||||
|
CHROMIUM: drm: rockchip/dw_hdmi-rockchip: Adjust rockchip_mpll_cfg for 146.25
|
||||||
|
CHROMIUM: drm: rockchip/dw_hdmi-rockchip: expand the informal mpll config
|
||||||
|
CHROMIUM: drm: rockchip/dw_hdmi-rockchip: add slop to more tables
|
||||||
|
CHROMIUM: drm: rockchip/dw_hdmi-rockchip: redo rockchip hdmi to allow slop
|
||||||
|
CHROMIUM: drm: rockchip/dw_hdmi-rockchip: Use auto-generated tables
|
||||||
|
CHROMIUM: drm: rockchip/dw_hdmi-rockchip: Fixup the clock to be what we expect
|
||||||
|
CHROMIUM: drm/rockchip: hdmi: adjust cklvl & txlvl for RF/EMI
|
||||||
|
CHROMIUM: drm: rockchip/dw_hdmi-rockchip: Set cur_ctr to 0 always
|
||||||
|
CHROMIUM: drm: rockchip/dw_hdmi-rockchip: Decrease slop
|
||||||
|
|
||||||
|
Signed-off-by: Urja Rannikko <urjaman@gmail.com>
|
||||||
|
Signed-off-by: Maya Matuszczyk <maccraft123mc@gmail.com>
|
||||||
|
|
||||||
|
---
|
||||||
|
drivers/gpu/drm/rockchip/dw_hdmi-rockchip.c | 271 +++++++++++++-------
|
||||||
|
1 file changed, 174 insertions(+), 97 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/drivers/gpu/drm/rockchip/dw_hdmi-rockchip.c b/drivers/gpu/drm/rockchip/dw_hdmi-rockchip.c
|
||||||
|
index c14f88893868..cb7a302497a5 100644
|
||||||
|
--- a/drivers/gpu/drm/rockchip/dw_hdmi-rockchip.c
|
||||||
|
+++ b/drivers/gpu/drm/rockchip/dw_hdmi-rockchip.c
|
||||||
|
@@ -80,8 +80,13 @@ struct rockchip_hdmi {
|
||||||
|
struct regulator *avdd_0v9;
|
||||||
|
struct regulator *avdd_1v8;
|
||||||
|
struct phy *phy;
|
||||||
|
+ u32* rates;
|
||||||
|
+ u32 rates_cnt;
|
||||||
|
};
|
||||||
|
|
||||||
|
+#define CLK_SLOP(clk) ((clk) / 1000)
|
||||||
|
+#define CLK_PLUS_SLOP(clk) ((clk) + CLK_SLOP(clk))
|
||||||
|
+
|
||||||
|
static struct rockchip_hdmi *to_rockchip_hdmi(struct drm_encoder *encoder)
|
||||||
|
{
|
||||||
|
struct rockchip_encoder *rkencoder = to_rockchip_encoder(encoder);
|
||||||
|
@@ -89,118 +94,132 @@ static struct rockchip_hdmi *to_rockchip_hdmi(struct drm_encoder *encoder)
|
||||||
|
return container_of(rkencoder, struct rockchip_hdmi, encoder);
|
||||||
|
}
|
||||||
|
|
||||||
|
+/* These were the rates allowed by the driver before rates list in device tree,
|
||||||
|
+ * so keep them around as a fallback */
|
||||||
|
+static const u32 dw_hdmi_fallback_rates[] = {
|
||||||
|
+ 27000000,
|
||||||
|
+ 36000000,
|
||||||
|
+ 40000000,
|
||||||
|
+ 54000000,
|
||||||
|
+ 65000000,
|
||||||
|
+ 66000000,
|
||||||
|
+ 74250000,
|
||||||
|
+ 83500000,
|
||||||
|
+ 106500000,
|
||||||
|
+ 108000000,
|
||||||
|
+ 146250000,
|
||||||
|
+ 148500000
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
static const struct dw_hdmi_mpll_config rockchip_mpll_cfg[] = {
|
||||||
|
{
|
||||||
|
- 27000000, {
|
||||||
|
- { 0x00b3, 0x0000},
|
||||||
|
- { 0x2153, 0x0000},
|
||||||
|
- { 0x40f3, 0x0000}
|
||||||
|
+ 30666000, {
|
||||||
|
+ { 0x00b3, 0x0000 },
|
||||||
|
+ { 0x2153, 0x0000 },
|
||||||
|
+ { 0x40f3, 0x0000 },
|
||||||
|
},
|
||||||
|
- }, {
|
||||||
|
- 36000000, {
|
||||||
|
- { 0x00b3, 0x0000},
|
||||||
|
- { 0x2153, 0x0000},
|
||||||
|
- { 0x40f3, 0x0000}
|
||||||
|
+ }, {
|
||||||
|
+ 36800000, {
|
||||||
|
+ { 0x00b3, 0x0000 },
|
||||||
|
+ { 0x2153, 0x0000 },
|
||||||
|
+ { 0x40a2, 0x0001 },
|
||||||
|
},
|
||||||
|
- }, {
|
||||||
|
- 40000000, {
|
||||||
|
- { 0x00b3, 0x0000},
|
||||||
|
- { 0x2153, 0x0000},
|
||||||
|
- { 0x40f3, 0x0000}
|
||||||
|
+ }, {
|
||||||
|
+ 46000000, {
|
||||||
|
+ { 0x00b3, 0x0000 },
|
||||||
|
+ { 0x2142, 0x0001 },
|
||||||
|
+ { 0x40a2, 0x0001 },
|
||||||
|
},
|
||||||
|
- }, {
|
||||||
|
- 54000000, {
|
||||||
|
- { 0x0072, 0x0001},
|
||||||
|
- { 0x2142, 0x0001},
|
||||||
|
- { 0x40a2, 0x0001},
|
||||||
|
+ }, {
|
||||||
|
+ 61333000, {
|
||||||
|
+ { 0x0072, 0x0001 },
|
||||||
|
+ { 0x2142, 0x0001 },
|
||||||
|
+ { 0x40a2, 0x0001 },
|
||||||
|
},
|
||||||
|
- }, {
|
||||||
|
- 65000000, {
|
||||||
|
- { 0x0072, 0x0001},
|
||||||
|
- { 0x2142, 0x0001},
|
||||||
|
- { 0x40a2, 0x0001},
|
||||||
|
+ }, {
|
||||||
|
+ 73600000, {
|
||||||
|
+ { 0x0072, 0x0001 },
|
||||||
|
+ { 0x2142, 0x0001 },
|
||||||
|
+ { 0x4061, 0x0002 },
|
||||||
|
},
|
||||||
|
- }, {
|
||||||
|
- 66000000, {
|
||||||
|
- { 0x013e, 0x0003},
|
||||||
|
- { 0x217e, 0x0002},
|
||||||
|
- { 0x4061, 0x0002}
|
||||||
|
+ }, {
|
||||||
|
+ 92000000, {
|
||||||
|
+ { 0x0072, 0x0001 },
|
||||||
|
+ { 0x2145, 0x0002 },
|
||||||
|
+ { 0x4061, 0x0002 },
|
||||||
|
},
|
||||||
|
- }, {
|
||||||
|
- 74250000, {
|
||||||
|
- { 0x0072, 0x0001},
|
||||||
|
- { 0x2145, 0x0002},
|
||||||
|
- { 0x4061, 0x0002}
|
||||||
|
+ }, {
|
||||||
|
+ 122666000, {
|
||||||
|
+ { 0x0051, 0x0002 },
|
||||||
|
+ { 0x2145, 0x0002 },
|
||||||
|
+ { 0x4061, 0x0002 },
|
||||||
|
},
|
||||||
|
- }, {
|
||||||
|
- 83500000, {
|
||||||
|
- { 0x0072, 0x0001},
|
||||||
|
+ }, {
|
||||||
|
+ 147200000, {
|
||||||
|
+ { 0x0051, 0x0002 },
|
||||||
|
+ { 0x2145, 0x0002 },
|
||||||
|
+ { 0x4064, 0x0003 },
|
||||||
|
},
|
||||||
|
- }, {
|
||||||
|
- 108000000, {
|
||||||
|
- { 0x0051, 0x0002},
|
||||||
|
- { 0x2145, 0x0002},
|
||||||
|
- { 0x4061, 0x0002}
|
||||||
|
+ }, {
|
||||||
|
+ 184000000, {
|
||||||
|
+ { 0x0051, 0x0002 },
|
||||||
|
+ { 0x214c, 0x0003 },
|
||||||
|
+ { 0x4064, 0x0003 },
|
||||||
|
},
|
||||||
|
- }, {
|
||||||
|
- 106500000, {
|
||||||
|
- { 0x0051, 0x0002},
|
||||||
|
- { 0x2145, 0x0002},
|
||||||
|
- { 0x4061, 0x0002}
|
||||||
|
+ }, {
|
||||||
|
+ 226666000, {
|
||||||
|
+ { 0x0040, 0x0003 },
|
||||||
|
+ { 0x214c, 0x0003 },
|
||||||
|
+ { 0x4064, 0x0003 },
|
||||||
|
},
|
||||||
|
- }, {
|
||||||
|
- 146250000, {
|
||||||
|
- { 0x0051, 0x0002},
|
||||||
|
- { 0x2145, 0x0002},
|
||||||
|
- { 0x4061, 0x0002}
|
||||||
|
+ }, {
|
||||||
|
+ 272000000, {
|
||||||
|
+ { 0x0040, 0x0003 },
|
||||||
|
+ { 0x214c, 0x0003 },
|
||||||
|
+ { 0x5a64, 0x0003 },
|
||||||
|
},
|
||||||
|
- }, {
|
||||||
|
- 148500000, {
|
||||||
|
- { 0x0051, 0x0003},
|
||||||
|
- { 0x214c, 0x0003},
|
||||||
|
- { 0x4064, 0x0003}
|
||||||
|
+ }, {
|
||||||
|
+ 340000000, {
|
||||||
|
+ { 0x0040, 0x0003 },
|
||||||
|
+ { 0x3b4c, 0x0003 },
|
||||||
|
+ { 0x5a64, 0x0003 },
|
||||||
|
},
|
||||||
|
- }, {
|
||||||
|
+ }, {
|
||||||
|
+ 600000000, {
|
||||||
|
+ { 0x1a40, 0x0003 },
|
||||||
|
+ { 0x3b4c, 0x0003 },
|
||||||
|
+ { 0x5a64, 0x0003 },
|
||||||
|
+ },
|
||||||
|
+ }, {
|
||||||
|
~0UL, {
|
||||||
|
- { 0x00a0, 0x000a },
|
||||||
|
- { 0x2001, 0x000f },
|
||||||
|
- { 0x4002, 0x000f },
|
||||||
|
+ { 0x0000, 0x0000 },
|
||||||
|
+ { 0x0000, 0x0000 },
|
||||||
|
+ { 0x0000, 0x0000 },
|
||||||
|
},
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct dw_hdmi_curr_ctrl rockchip_cur_ctr[] = {
|
||||||
|
- /* pixelclk bpp8 bpp10 bpp12 */
|
||||||
|
+ /* pixelclk bpp8 bpp10 bpp12 */
|
||||||
|
{
|
||||||
|
- 40000000, { 0x0018, 0x0018, 0x0018 },
|
||||||
|
- }, {
|
||||||
|
- 65000000, { 0x0028, 0x0028, 0x0028 },
|
||||||
|
- }, {
|
||||||
|
- 66000000, { 0x0038, 0x0038, 0x0038 },
|
||||||
|
- }, {
|
||||||
|
- 74250000, { 0x0028, 0x0038, 0x0038 },
|
||||||
|
- }, {
|
||||||
|
- 83500000, { 0x0028, 0x0038, 0x0038 },
|
||||||
|
- }, {
|
||||||
|
- 146250000, { 0x0038, 0x0038, 0x0038 },
|
||||||
|
+ 600000000, { 0x0000, 0x0000, 0x0000 },
|
||||||
|
}, {
|
||||||
|
- 148500000, { 0x0000, 0x0038, 0x0038 },
|
||||||
|
- }, {
|
||||||
|
- ~0UL, { 0x0000, 0x0000, 0x0000},
|
||||||
|
+ ~0UL, { 0x0000, 0x0000, 0x0000},
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct dw_hdmi_phy_config rockchip_phy_config[] = {
|
||||||
|
- /*pixelclk symbol term vlev*/
|
||||||
|
- { 74250000, 0x8009, 0x0004, 0x0272},
|
||||||
|
- { 148500000, 0x802b, 0x0004, 0x028d},
|
||||||
|
- { 297000000, 0x8039, 0x0005, 0x028d},
|
||||||
|
- { ~0UL, 0x0000, 0x0000, 0x0000}
|
||||||
|
+ /*pixelclk symbol term vlev*/
|
||||||
|
+ { CLK_PLUS_SLOP(74250000), 0x8009, 0x0004, 0x0272},
|
||||||
|
+ { CLK_PLUS_SLOP(165000000), 0x802b, 0x0004, 0x0209},
|
||||||
|
+ { CLK_PLUS_SLOP(297000000), 0x8039, 0x0005, 0x028d},
|
||||||
|
+ { ~0UL, 0x0000, 0x0000, 0x0000}
|
||||||
|
};
|
||||||
|
|
||||||
|
static int rockchip_hdmi_parse_dt(struct rockchip_hdmi *hdmi)
|
||||||
|
{
|
||||||
|
struct device_node *np = hdmi->dev->of_node;
|
||||||
|
+ int rates_cnt;
|
||||||
|
|
||||||
|
hdmi->regmap = syscon_regmap_lookup_by_phandle(np, "rockchip,grf");
|
||||||
|
if (IS_ERR(hdmi->regmap)) {
|
||||||
|
@@ -237,27 +256,55 @@ static int rockchip_hdmi_parse_dt(struct rockchip_hdmi *hdmi)
|
||||||
|
if (IS_ERR(hdmi->avdd_1v8))
|
||||||
|
return PTR_ERR(hdmi->avdd_1v8);
|
||||||
|
|
||||||
|
+ if ((rates_cnt = of_property_count_u32_elems(np, "rockchip,hdmi-rates-hz")) > 0) {
|
||||||
|
+ int rv;
|
||||||
|
+ u32 *rates = devm_kmalloc_array(hdmi->dev, rates_cnt, sizeof(u32), GFP_KERNEL);
|
||||||
|
+ if (!rates)
|
||||||
|
+ return -ENOMEM;
|
||||||
|
+ rv = of_property_read_u32_array(np, "rockchip,hdmi-rates-hz", rates, rates_cnt);
|
||||||
|
+ if (rv)
|
||||||
|
+ return rv;
|
||||||
|
+ hdmi->rates = rates;
|
||||||
|
+ hdmi->rates_cnt = rates_cnt;
|
||||||
|
+ } else {
|
||||||
|
+ rates_cnt = ARRAY_SIZE(dw_hdmi_fallback_rates);
|
||||||
|
+ hdmi->rates = devm_kmalloc_array(hdmi->dev, rates_cnt, sizeof(u32), GFP_KERNEL);
|
||||||
|
+ if (!hdmi->rates)
|
||||||
|
+ return -ENOMEM;
|
||||||
|
+ memcpy(hdmi->rates, dw_hdmi_fallback_rates, rates_cnt * sizeof(u32));
|
||||||
|
+ hdmi->rates_cnt = rates_cnt;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static enum drm_mode_status
|
||||||
|
-dw_hdmi_rockchip_mode_valid(struct dw_hdmi *hdmi, void *data,
|
||||||
|
- const struct drm_display_info *info,
|
||||||
|
+dw_hdmi_rockchip_encoder_mode_valid(struct drm_encoder *encoder,
|
||||||
|
const struct drm_display_mode *mode)
|
||||||
|
{
|
||||||
|
- const struct dw_hdmi_mpll_config *mpll_cfg = rockchip_mpll_cfg;
|
||||||
|
+ struct rockchip_hdmi *hdmi = to_rockchip_hdmi(encoder);
|
||||||
|
int pclk = mode->clock * 1000;
|
||||||
|
- bool valid = false;
|
||||||
|
+ int num_rates = hdmi->rates_cnt;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
- for (i = 0; mpll_cfg[i].mpixelclock != (~0UL); i++) {
|
||||||
|
- if (pclk == mpll_cfg[i].mpixelclock) {
|
||||||
|
- valid = true;
|
||||||
|
- break;
|
||||||
|
- }
|
||||||
|
+ /*
|
||||||
|
+ * Pixel clocks we support are always < 2GHz and so fit in an
|
||||||
|
+ * int. We should make sure source rate does too so we don't get
|
||||||
|
+ * overflow when we multiply by 1000.
|
||||||
|
+ */
|
||||||
|
+ if (mode->clock > INT_MAX / 1000)
|
||||||
|
+ return MODE_BAD;
|
||||||
|
+
|
||||||
|
+ for (i = 0; i < num_rates; i++) {
|
||||||
|
+ int slop = CLK_SLOP(pclk);
|
||||||
|
+
|
||||||
|
+ if ((pclk >= hdmi->rates[i] - slop) &&
|
||||||
|
+ (pclk <= hdmi->rates[i] + slop))
|
||||||
|
+ return MODE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
- return (valid) ? MODE_OK : MODE_BAD;
|
||||||
|
+ return MODE_BAD;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void dw_hdmi_rockchip_encoder_disable(struct drm_encoder *encoder)
|
||||||
|
@@ -269,7 +316,39 @@ dw_hdmi_rockchip_encoder_mode_fixup(struct drm_encoder *encoder,
|
||||||
|
const struct drm_display_mode *mode,
|
||||||
|
struct drm_display_mode *adj_mode)
|
||||||
|
{
|
||||||
|
- return true;
|
||||||
|
+ struct rockchip_hdmi *hdmi = to_rockchip_hdmi(encoder);
|
||||||
|
+ int pclk = adj_mode->clock * 1000;
|
||||||
|
+ int best_diff = INT_MAX;
|
||||||
|
+ int best_clock = 0;
|
||||||
|
+ int slop;
|
||||||
|
+ int i;
|
||||||
|
+
|
||||||
|
+ /* Pick the best clock */
|
||||||
|
+ for (i = 0; i < hdmi->rates_cnt; i++) {
|
||||||
|
+ int diff = hdmi->rates[i] - pclk;
|
||||||
|
+
|
||||||
|
+ if (diff < 0)
|
||||||
|
+ diff = -diff;
|
||||||
|
+ if (diff < best_diff) {
|
||||||
|
+ best_diff = diff;
|
||||||
|
+ best_clock = hdmi->rates[i];
|
||||||
|
+
|
||||||
|
+ /* Bail early if we're exact */
|
||||||
|
+ if (best_diff == 0)
|
||||||
|
+ return true;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /* Double check that it's OK */
|
||||||
|
+ slop = CLK_SLOP(pclk);
|
||||||
|
+ if ((pclk >= best_clock - slop) && (pclk <= best_clock + slop)) {
|
||||||
|
+ adj_mode->clock = DIV_ROUND_UP(best_clock, 1000);
|
||||||
|
+ return true;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /* Shoudn't be here; we should have said rate wasn't valid */
|
||||||
|
+ dev_warn(hdmi->dev, "tried to set invalid rate %d\n", adj_mode->clock);
|
||||||
|
+ return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void dw_hdmi_rockchip_encoder_mode_set(struct drm_encoder *encoder,
|
||||||
|
@@ -325,6 +404,7 @@ dw_hdmi_rockchip_encoder_atomic_check(struct drm_encoder *encoder,
|
||||||
|
}
|
||||||
|
|
||||||
|
static const struct drm_encoder_helper_funcs dw_hdmi_rockchip_encoder_helper_funcs = {
|
||||||
|
+ .mode_valid = dw_hdmi_rockchip_encoder_mode_valid,
|
||||||
|
.mode_fixup = dw_hdmi_rockchip_encoder_mode_fixup,
|
||||||
|
.mode_set = dw_hdmi_rockchip_encoder_mode_set,
|
||||||
|
.enable = dw_hdmi_rockchip_encoder_enable,
|
||||||
|
@@ -425,7 +505,6 @@ static struct rockchip_hdmi_chip_data rk3228_chip_data = {
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct dw_hdmi_plat_data rk3228_hdmi_drv_data = {
|
||||||
|
- .mode_valid = dw_hdmi_rockchip_mode_valid,
|
||||||
|
.mpll_cfg = rockchip_mpll_cfg,
|
||||||
|
.cur_ctr = rockchip_cur_ctr,
|
||||||
|
.phy_config = rockchip_phy_config,
|
||||||
|
@@ -442,7 +521,6 @@ static struct rockchip_hdmi_chip_data rk3288_chip_data = {
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct dw_hdmi_plat_data rk3288_hdmi_drv_data = {
|
||||||
|
- .mode_valid = dw_hdmi_rockchip_mode_valid,
|
||||||
|
.mpll_cfg = rockchip_mpll_cfg,
|
||||||
|
.cur_ctr = rockchip_cur_ctr,
|
||||||
|
.phy_config = rockchip_phy_config,
|
||||||
|
@@ -462,7 +540,6 @@ static struct rockchip_hdmi_chip_data rk3328_chip_data = {
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct dw_hdmi_plat_data rk3328_hdmi_drv_data = {
|
||||||
|
- .mode_valid = dw_hdmi_rockchip_mode_valid,
|
||||||
|
.mpll_cfg = rockchip_mpll_cfg,
|
||||||
|
.cur_ctr = rockchip_cur_ctr,
|
||||||
|
.phy_config = rockchip_phy_config,
|
||||||
|
@@ -480,7 +557,6 @@ static struct rockchip_hdmi_chip_data rk3399_chip_data = {
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct dw_hdmi_plat_data rk3399_hdmi_drv_data = {
|
||||||
|
- .mode_valid = dw_hdmi_rockchip_mode_valid,
|
||||||
|
.mpll_cfg = rockchip_mpll_cfg,
|
||||||
|
.cur_ctr = rockchip_cur_ctr,
|
||||||
|
.phy_config = rockchip_phy_config,
|
||||||
|
@@ -493,7 +569,6 @@ static struct rockchip_hdmi_chip_data rk3568_chip_data = {
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct dw_hdmi_plat_data rk3568_hdmi_drv_data = {
|
||||||
|
- .mode_valid = dw_hdmi_rockchip_mode_valid,
|
||||||
|
.mpll_cfg = rockchip_mpll_cfg,
|
||||||
|
.cur_ctr = rockchip_cur_ctr,
|
||||||
|
.phy_config = rockchip_phy_config,
|
||||||
|
@@ -623,6 +698,7 @@ static int dw_hdmi_rockchip_bind(struct device *dev, struct device *master,
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
err_bind:
|
||||||
|
+ devm_kfree(hdmi->dev, hdmi->rates);
|
||||||
|
drm_encoder_cleanup(encoder);
|
||||||
|
clk_disable_unprepare(hdmi->ref_clk);
|
||||||
|
err_clk:
|
||||||
|
@@ -638,6 +714,7 @@ static void dw_hdmi_rockchip_unbind(struct device *dev, struct device *master,
|
||||||
|
{
|
||||||
|
struct rockchip_hdmi *hdmi = dev_get_drvdata(dev);
|
||||||
|
|
||||||
|
+ devm_kfree(hdmi->dev, hdmi->rates);
|
||||||
|
dw_hdmi_unbind(hdmi->hdmi);
|
||||||
|
clk_disable_unprepare(hdmi->ref_clk);
|
||||||
|
|
||||||
|
--
|
||||||
|
2.36.1
|
||||||
|
|
|
@ -0,0 +1,35 @@
|
||||||
|
From 4ade7af42f03522c31bd9450710c41b47b866766 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Urja Rannikko <urjaman@gmail.com>
|
||||||
|
Date: Mon, 27 Aug 2018 19:00:50 +0000
|
||||||
|
Subject: [PATCH] dts: rk3288: support for dedicating npll to a vop
|
||||||
|
|
||||||
|
Add the VOP DCLKs to the assigned clocks list so their
|
||||||
|
parents can be set in the dts include files for
|
||||||
|
devices that do dedicate npll to a vop.
|
||||||
|
|
||||||
|
Signed-off-by: Urja Rannikko <urjaman@gmail.com>
|
||||||
|
---
|
||||||
|
arch/arm/boot/dts/rk3288.dtsi | 6 ++++--
|
||||||
|
1 file changed, 4 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/arch/arm/boot/dts/rk3288.dtsi b/arch/arm/boot/dts/rk3288.dtsi
|
||||||
|
index aaaa61875701d..e8cb4dc8c27da 100644
|
||||||
|
--- a/arch/arm/boot/dts/rk3288.dtsi
|
||||||
|
+++ b/arch/arm/boot/dts/rk3288.dtsi
|
||||||
|
@@ -865,12 +865,14 @@
|
||||||
|
rockchip,grf = <&grf>;
|
||||||
|
#clock-cells = <1>;
|
||||||
|
#reset-cells = <1>;
|
||||||
|
- assigned-clocks = <&cru PLL_GPLL>, <&cru PLL_CPLL>,
|
||||||
|
+ assigned-clocks = <&cru DCLK_VOP0>, <&cru DCLK_VOP1>,
|
||||||
|
+ <&cru PLL_GPLL>, <&cru PLL_CPLL>,
|
||||||
|
<&cru PLL_NPLL>, <&cru ACLK_CPU>,
|
||||||
|
<&cru HCLK_CPU>, <&cru PCLK_CPU>,
|
||||||
|
<&cru ACLK_PERI>, <&cru HCLK_PERI>,
|
||||||
|
<&cru PCLK_PERI>;
|
||||||
|
- assigned-clock-rates = <594000000>, <400000000>,
|
||||||
|
+ assigned-clock-rates = <0>, <0>,
|
||||||
|
+ <594000000>, <400000000>,
|
||||||
|
<500000000>, <300000000>,
|
||||||
|
<150000000>, <75000000>,
|
||||||
|
<300000000>, <150000000>,
|
|
@ -0,0 +1,89 @@
|
||||||
|
From ec5ba9f43454a7d630e25c062718b4daa836fdf8 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Urja Rannikko <urjaman@gmail.com>
|
||||||
|
Date: Mon, 27 Aug 2018 19:03:49 +0000
|
||||||
|
Subject: [PATCH] dts: rk3288-veyron-chromebook: dedicate npll to VOP0/HDMI +
|
||||||
|
HDMI rates
|
||||||
|
|
||||||
|
This enables flexible HDMI rates on the rk3288 chromebooks so that they
|
||||||
|
actually work with displays (also others than a 1080p one) in the wild.
|
||||||
|
|
||||||
|
The frequency list matches what ChromeOS allows.
|
||||||
|
|
||||||
|
Signed-off-by: Urja Rannikko <urjaman@gmail.com>
|
||||||
|
---
|
||||||
|
.../boot/dts/rk3288-veyron-chromebook.dtsi | 62 +++++++++++++++++++
|
||||||
|
1 file changed, 62 insertions(+)
|
||||||
|
|
||||||
|
diff --git a/arch/arm/boot/dts/rk3288-veyron-chromebook.dtsi b/arch/arm/boot/dts/rk3288-veyron-chromebook.dtsi
|
||||||
|
index 05112c25176d3..4d972bd6741c1 100644
|
||||||
|
--- a/arch/arm/boot/dts/rk3288-veyron-chromebook.dtsi
|
||||||
|
+++ b/arch/arm/boot/dts/rk3288-veyron-chromebook.dtsi
|
||||||
|
@@ -83,6 +83,68 @@
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
+&cru {
|
||||||
|
+ /* Dedicate NPLL for VOP0 / VOP_BIG for HDMI. */
|
||||||
|
+ rockchip,npll-for-vop = <0>;
|
||||||
|
+ /* The first assigned clocks are DCLK_VOP0 and DCLK_VOP1 */
|
||||||
|
+ assigned-clock-parents = <&cru PLL_NPLL>, <&cru PLL_GPLL>;
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+/* Delete the nodes that allow non-desirable VOP - connector links. That
|
||||||
|
+ * is the eDP cannot use vopb and HDMI cannot use vopl. */
|
||||||
|
+
|
||||||
|
+/delete-node/ &edp_in_vopb;
|
||||||
|
+/delete-node/ &vopb_out_edp;
|
||||||
|
+/delete-node/ &hdmi_in_vopl;
|
||||||
|
+/delete-node/ &vopl_out_hdmi;
|
||||||
|
+
|
||||||
|
+&hdmi {
|
||||||
|
+ /* These depend on NPLL being dedicated to HDMI use. */
|
||||||
|
+ rockchip,hdmi-rates-hz = <
|
||||||
|
+ 25176471 /* for 25.175 MHz, 0.006% off */
|
||||||
|
+ 25200000
|
||||||
|
+ 27000000
|
||||||
|
+ 28320000
|
||||||
|
+ 30240000
|
||||||
|
+ 31500000
|
||||||
|
+ 32000000
|
||||||
|
+ 33750000
|
||||||
|
+ 36000000
|
||||||
|
+ 40000000
|
||||||
|
+ 49500000
|
||||||
|
+ 50000000
|
||||||
|
+ 54000000
|
||||||
|
+ 57290323 /* for 57.284 MHz, .011 % off */
|
||||||
|
+ 65000000
|
||||||
|
+ 68250000
|
||||||
|
+ 71000000
|
||||||
|
+ 72000000
|
||||||
|
+ 73250000
|
||||||
|
+ 74250000
|
||||||
|
+ 74437500 /* for 74.44 MHz, .003% off */
|
||||||
|
+ 75000000
|
||||||
|
+ 78750000
|
||||||
|
+ 78800000
|
||||||
|
+ 79500000
|
||||||
|
+ 83500000
|
||||||
|
+ 85500000
|
||||||
|
+ 88750000
|
||||||
|
+ 97750000
|
||||||
|
+ 101000000
|
||||||
|
+ 106500000
|
||||||
|
+ 108000000
|
||||||
|
+ 115500000
|
||||||
|
+ 118666667 /* for 118.68 MHz, .011% off */
|
||||||
|
+ 119000000
|
||||||
|
+ 121714286 /* for 121.75 MHz, .029% off */
|
||||||
|
+ 135000000
|
||||||
|
+ 136800000 /* for 136.75 MHz, .037% off */
|
||||||
|
+ 146250000
|
||||||
|
+ 148500000
|
||||||
|
+ 154000000
|
||||||
|
+ 162000000 >;
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
&rk808 {
|
||||||
|
vcc11-supply = <&vcc_5v>;
|
||||||
|
|
|
@ -0,0 +1,149 @@
|
||||||
|
From 5a9a3b3418ab920a30ef09fdd8836ca90ab99e1e Mon Sep 17 00:00:00 2001
|
||||||
|
From: "Miouyouyou (Myy)" <myy@miouyouyou.fr>
|
||||||
|
Date: Tue, 9 Oct 2018 22:01:07 +0200
|
||||||
|
Subject: [PATCH] block: partitions: efi: Ignore bizarre Chromebook GPT
|
||||||
|
partitions
|
||||||
|
|
||||||
|
This patch is based on @SolidHal work here :
|
||||||
|
https://raw.githubusercontent.com/SolidHal/PrawnOS/master/resources/BuildResources/patches-tested/kernel/0001-block-partitions-efi-Add-support-for-IGNOREME-GPT-si.patch
|
||||||
|
|
||||||
|
Here's the initial commit message :
|
||||||
|
|
||||||
|
8<---
|
||||||
|
|
||||||
|
This patch adds support for a special GPT header signature marker (using
|
||||||
|
the string 'IGNOREME' instead of the spec's 'EFI PART'). This tells the
|
||||||
|
kernel to ignore this GPT completely and look at the other one instead.
|
||||||
|
Since the kernel always prefers the primary GPT anyway, all we really
|
||||||
|
need to do effectively is to check whether the primary GPT is marked
|
||||||
|
'IGNOREME' and force evaluation of the secondary one in that case.
|
||||||
|
|
||||||
|
Borrowed from the chrome os 3.14 kernel, the commit can be found here:
|
||||||
|
https://chromium.googlesource.com/chromiumos/third_party/kernel/+/abba28d0a1b7361da6e2023352e92687166ca30d
|
||||||
|
|
||||||
|
Also bundled in this commit
|
||||||
|
https://chromium.googlesource.com/chromiumos/third_party/kernel/+/bd0c62c7de0c8a63314b7955e5718d8f6192f9d2%5E%21/#F0
|
||||||
|
Which is a small compiler warning fix for the above patch
|
||||||
|
|
||||||
|
This patch fixes how the kernel detects and handles certain mmc
|
||||||
|
manufatures devices, and allows the partitions on the mmc to be bootable
|
||||||
|
and mountable.
|
||||||
|
|
||||||
|
>8---
|
||||||
|
|
||||||
|
Signed-off-by: Miouyouyou (Myy) <myy@miouyouyou.fr>
|
||||||
|
---
|
||||||
|
block/partitions/efi.c | 33 +++++++++++++++++++++++----------
|
||||||
|
block/partitions/efi.h | 3 ++-
|
||||||
|
2 files changed, 25 insertions(+), 11 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/block/partitions/efi.c b/block/partitions/efi.c
|
||||||
|
index 7ca5c4c374d4..54531e49c6ab 100644
|
||||||
|
--- a/block/partitions/efi.c
|
||||||
|
+++ b/block/partitions/efi.c
|
||||||
|
@@ -328,23 +328,34 @@ static gpt_header *alloc_read_gpt_header(struct parsed_partitions *state,
|
||||||
|
* @lba: logical block address of the GPT header to test
|
||||||
|
* @gpt: GPT header ptr, filled on return.
|
||||||
|
* @ptes: PTEs ptr, filled on return.
|
||||||
|
+ * @ignored is filled on return with 1 if this is an IGNOREME GPT,
|
||||||
|
+ * 0 otherwise. May be NULL.
|
||||||
|
*
|
||||||
|
* Description: returns 1 if valid, 0 on error.
|
||||||
|
* If valid, returns pointers to newly allocated GPT header and PTEs.
|
||||||
|
*/
|
||||||
|
static int is_gpt_valid(struct parsed_partitions *state, u64 lba,
|
||||||
|
- gpt_header **gpt, gpt_entry **ptes)
|
||||||
|
+ gpt_header **gpt, gpt_entry **ptes, int *ignored)
|
||||||
|
{
|
||||||
|
u32 crc, origcrc;
|
||||||
|
u64 lastlba, pt_size;
|
||||||
|
|
||||||
|
+ if (ignored)
|
||||||
|
+ *ignored = 0;
|
||||||
|
if (!ptes)
|
||||||
|
return 0;
|
||||||
|
if (!(*gpt = alloc_read_gpt_header(state, lba)))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
/* Check the GUID Partition Table signature */
|
||||||
|
- if (le64_to_cpu((*gpt)->signature) != GPT_HEADER_SIGNATURE) {
|
||||||
|
+
|
||||||
|
+ if (le64_to_cpu((*gpt)->signature) == GPT_HEADER_SIGNATURE_IGNORED) {
|
||||||
|
+ pr_debug("GUID Partition Table at LBA %llu marked IGNOREME\n",
|
||||||
|
+ (unsigned long long)lba);
|
||||||
|
+ if (ignored)
|
||||||
|
+ *ignored = 1;
|
||||||
|
+ goto fail;
|
||||||
|
+ } else if (le64_to_cpu((*gpt)->signature) != GPT_HEADER_SIGNATURE) {
|
||||||
|
pr_debug("GUID Partition Table Header signature is wrong:"
|
||||||
|
"%lld != %lld\n",
|
||||||
|
(unsigned long long)le64_to_cpu((*gpt)->signature),
|
||||||
|
@@ -581,7 +592,7 @@ compare_gpts(gpt_header *pgpt, gpt_header *agpt, u64 lastlba)
|
||||||
|
static int find_valid_gpt(struct parsed_partitions *state, gpt_header **gpt,
|
||||||
|
gpt_entry **ptes)
|
||||||
|
{
|
||||||
|
- int good_pgpt = 0, good_agpt = 0, good_pmbr = 0;
|
||||||
|
+ int good_pgpt = 0, good_agpt = 0, good_pmbr = 0, pgpt_ignored = 0;
|
||||||
|
gpt_header *pgpt = NULL, *agpt = NULL;
|
||||||
|
gpt_entry *pptes = NULL, *aptes = NULL;
|
||||||
|
legacy_mbr *legacymbr;
|
||||||
|
@@ -613,13 +624,13 @@ static int find_valid_gpt(struct parsed_partitions *state, gpt_header **gpt,
|
||||||
|
}
|
||||||
|
|
||||||
|
good_pgpt = is_gpt_valid(state, GPT_PRIMARY_PARTITION_TABLE_LBA,
|
||||||
|
- &pgpt, &pptes);
|
||||||
|
+ &pgpt, &pptes, &pgpt_ignored);
|
||||||
|
if (good_pgpt)
|
||||||
|
good_agpt = is_gpt_valid(state,
|
||||||
|
le64_to_cpu(pgpt->alternate_lba),
|
||||||
|
- &agpt, &aptes);
|
||||||
|
- if (!good_agpt && force_gpt)
|
||||||
|
- good_agpt = is_gpt_valid(state, lastlba, &agpt, &aptes);
|
||||||
|
+ &agpt, &aptes, NULL);
|
||||||
|
+ if (!good_agpt && (force_gpt || pgpt_ignored))
|
||||||
|
+ good_agpt = is_gpt_valid(state, lastlba, &agpt, &aptes, NULL);
|
||||||
|
|
||||||
|
if (!good_agpt && force_gpt && fops->alternative_gpt_sector) {
|
||||||
|
sector_t agpt_sector;
|
||||||
|
@@ -628,14 +639,15 @@ static int find_valid_gpt(struct parsed_partitions *state, gpt_header **gpt,
|
||||||
|
err = fops->alternative_gpt_sector(disk, &agpt_sector);
|
||||||
|
if (!err)
|
||||||
|
good_agpt = is_gpt_valid(state, agpt_sector,
|
||||||
|
- &agpt, &aptes);
|
||||||
|
+ &agpt, &aptes, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* The obviously unsuccessful case */
|
||||||
|
if (!good_pgpt && !good_agpt)
|
||||||
|
goto fail;
|
||||||
|
|
||||||
|
- compare_gpts(pgpt, agpt, lastlba);
|
||||||
|
+ if (!pgpt_ignored)
|
||||||
|
+ compare_gpts(pgpt, agpt, lastlba);
|
||||||
|
|
||||||
|
/* The good cases */
|
||||||
|
if (good_pgpt) {
|
||||||
|
@@ -652,7 +664,8 @@ static int find_valid_gpt(struct parsed_partitions *state, gpt_header **gpt,
|
||||||
|
*ptes = aptes;
|
||||||
|
kfree(pgpt);
|
||||||
|
kfree(pptes);
|
||||||
|
- pr_warn("Primary GPT is invalid, using alternate GPT.\n");
|
||||||
|
+ pr_warn("Primary GPT is %s, using alternate GPT.\n",
|
||||||
|
+ pgpt_ignored ? "being ignored" : "invalid");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
diff --git a/block/partitions/efi.h b/block/partitions/efi.h
|
||||||
|
index 8cc2b88d0aa8..fcf65ebbaa85 100644
|
||||||
|
--- a/block/partitions/efi.h
|
||||||
|
+++ b/block/partitions/efi.h
|
||||||
|
@@ -27,7 +27,8 @@
|
||||||
|
#define GPT_MBR_PROTECTIVE 1
|
||||||
|
#define GPT_MBR_HYBRID 2
|
||||||
|
|
||||||
|
-#define GPT_HEADER_SIGNATURE 0x5452415020494645ULL
|
||||||
|
+#define GPT_HEADER_SIGNATURE 0x5452415020494645ULL /* 'EFI PART' */
|
||||||
|
+#define GPT_HEADER_SIGNATURE_IGNORED 0x454d45524f4e4749ULL /* 'IGNOREME' */
|
||||||
|
#define GPT_HEADER_REVISION_V1 0x00010000
|
||||||
|
#define GPT_PRIMARY_PARTITION_TABLE_LBA 1
|
||||||
|
|
|
@ -0,0 +1,163 @@
|
||||||
|
From 0aa7fbf8bf1e578a349445fe639171ca45b1003b Mon Sep 17 00:00:00 2001
|
||||||
|
From: Urja Rannikko <urjaman@gmail.com>
|
||||||
|
Date: Mon, 27 Aug 2018 10:30:55 +0000
|
||||||
|
Subject: [PATCH] drivers: clk-rk3288: support for dedicating NPLL to a VOP
|
||||||
|
|
||||||
|
As controlled by the just introduced dts property.
|
||||||
|
|
||||||
|
Signed-off-by: Urja Rannikko <urjaman@gmail.com>
|
||||||
|
---
|
||||||
|
drivers/clk/rockchip/clk-rk3288.c | 69 +++++++++++++++++++++++++------
|
||||||
|
drivers/clk/rockchip/clk.h | 3 ++
|
||||||
|
2 files changed, 60 insertions(+), 12 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/drivers/clk/rockchip/clk-rk3288.c b/drivers/clk/rockchip/clk-rk3288.c
|
||||||
|
index baa5aebd32771..11493f0be2b1d 100644
|
||||||
|
--- a/drivers/clk/rockchip/clk-rk3288.c
|
||||||
|
+++ b/drivers/clk/rockchip/clk-rk3288.c
|
||||||
|
@@ -195,10 +195,14 @@ PNAME(mux_ddrphy_p) = { "dpll_ddr", "gpll_ddr" };
|
||||||
|
PNAME(mux_aclk_cpu_src_p) = { "cpll_aclk_cpu", "gpll_aclk_cpu" };
|
||||||
|
|
||||||
|
PNAME(mux_pll_src_cpll_gpll_p) = { "cpll", "gpll" };
|
||||||
|
-PNAME(mux_pll_src_npll_cpll_gpll_p) = { "npll", "cpll", "gpll" };
|
||||||
|
-PNAME(mux_pll_src_cpll_gpll_npll_p) = { "cpll", "gpll", "npll" };
|
||||||
|
+PNAME_ED(mux_pll_src_npll_cpll_gpll_p) = { "npll", "cpll", "gpll" };
|
||||||
|
+
|
||||||
|
+PNAME_ED(mux_pll_src_cgn_pll_nonvop_p) = { "cpll", "gpll", "npll" };
|
||||||
|
+PNAME_ED(mux_pll_src_cgn_pll_vop0_p) = { "cpll", "gpll", "npll" };
|
||||||
|
+PNAME_ED(mux_pll_src_cgn_pll_vop1_p) = { "cpll", "gpll", "npll" };
|
||||||
|
+
|
||||||
|
PNAME(mux_pll_src_cpll_gpll_usb480m_p) = { "cpll", "gpll", "unstable:usbphy480m_src" };
|
||||||
|
-PNAME(mux_pll_src_cpll_gll_usb_npll_p) = { "cpll", "gpll", "unstable:usbphy480m_src", "npll" };
|
||||||
|
+PNAME_ED(mux_pll_src_cpll_gll_usb_npll_p) = { "cpll", "gpll", "unstable:usbphy480m_src", "npll" };
|
||||||
|
|
||||||
|
PNAME(mux_mmc_src_p) = { "cpll", "gpll", "xin24m", "xin24m" };
|
||||||
|
PNAME(mux_i2s_pre_p) = { "i2s_src", "i2s_frac", "ext_i2s", "xin12m" };
|
||||||
|
@@ -442,24 +446,24 @@ static struct rockchip_clk_branch rk3288_clk_branches[] __initdata = {
|
||||||
|
RK3288_CLKSEL_CON(30), 14, 2, MFLAGS, 8, 5, DFLAGS,
|
||||||
|
RK3288_CLKGATE_CON(3), 4, GFLAGS),
|
||||||
|
|
||||||
|
- COMPOSITE(DCLK_VOP0, "dclk_vop0", mux_pll_src_cpll_gpll_npll_p, 0,
|
||||||
|
+ COMPOSITE(DCLK_VOP0, "dclk_vop0", mux_pll_src_cgn_pll_vop0_p, 0,
|
||||||
|
RK3288_CLKSEL_CON(27), 0, 2, MFLAGS, 8, 8, DFLAGS,
|
||||||
|
RK3288_CLKGATE_CON(3), 1, GFLAGS),
|
||||||
|
- COMPOSITE(DCLK_VOP1, "dclk_vop1", mux_pll_src_cpll_gpll_npll_p, 0,
|
||||||
|
+ COMPOSITE(DCLK_VOP1, "dclk_vop1", mux_pll_src_cgn_pll_vop1_p, 0,
|
||||||
|
RK3288_CLKSEL_CON(29), 6, 2, MFLAGS, 8, 8, DFLAGS,
|
||||||
|
RK3288_CLKGATE_CON(3), 3, GFLAGS),
|
||||||
|
|
||||||
|
COMPOSITE_NODIV(SCLK_EDP_24M, "sclk_edp_24m", mux_edp_24m_p, 0,
|
||||||
|
RK3288_CLKSEL_CON(28), 15, 1, MFLAGS,
|
||||||
|
RK3288_CLKGATE_CON(3), 12, GFLAGS),
|
||||||
|
- COMPOSITE(SCLK_EDP, "sclk_edp", mux_pll_src_cpll_gpll_npll_p, 0,
|
||||||
|
+ COMPOSITE(SCLK_EDP, "sclk_edp", mux_pll_src_cgn_pll_nonvop_p, 0,
|
||||||
|
RK3288_CLKSEL_CON(28), 6, 2, MFLAGS, 0, 6, DFLAGS,
|
||||||
|
RK3288_CLKGATE_CON(3), 13, GFLAGS),
|
||||||
|
|
||||||
|
- COMPOSITE(SCLK_ISP, "sclk_isp", mux_pll_src_cpll_gpll_npll_p, 0,
|
||||||
|
+ COMPOSITE(SCLK_ISP, "sclk_isp", mux_pll_src_cgn_pll_nonvop_p, 0,
|
||||||
|
RK3288_CLKSEL_CON(6), 6, 2, MFLAGS, 0, 6, DFLAGS,
|
||||||
|
RK3288_CLKGATE_CON(3), 14, GFLAGS),
|
||||||
|
- COMPOSITE(SCLK_ISP_JPE, "sclk_isp_jpe", mux_pll_src_cpll_gpll_npll_p, 0,
|
||||||
|
+ COMPOSITE(SCLK_ISP_JPE, "sclk_isp_jpe", mux_pll_src_cgn_pll_nonvop_p, 0,
|
||||||
|
RK3288_CLKSEL_CON(6), 14, 2, MFLAGS, 8, 6, DFLAGS,
|
||||||
|
RK3288_CLKGATE_CON(3), 15, GFLAGS),
|
||||||
|
|
||||||
|
@@ -468,16 +472,16 @@ static struct rockchip_clk_branch rk3288_clk_branches[] __initdata = {
|
||||||
|
GATE(SCLK_HDMI_CEC, "sclk_hdmi_cec", "xin32k", 0,
|
||||||
|
RK3288_CLKGATE_CON(5), 11, GFLAGS),
|
||||||
|
|
||||||
|
- COMPOSITE(ACLK_HEVC, "aclk_hevc", mux_pll_src_cpll_gpll_npll_p, 0,
|
||||||
|
+ COMPOSITE(ACLK_HEVC, "aclk_hevc", mux_pll_src_cgn_pll_nonvop_p, 0,
|
||||||
|
RK3288_CLKSEL_CON(39), 14, 2, MFLAGS, 8, 5, DFLAGS,
|
||||||
|
RK3288_CLKGATE_CON(13), 13, GFLAGS),
|
||||||
|
DIV(HCLK_HEVC, "hclk_hevc", "aclk_hevc", 0,
|
||||||
|
RK3288_CLKSEL_CON(40), 12, 2, DFLAGS),
|
||||||
|
|
||||||
|
- COMPOSITE(SCLK_HEVC_CABAC, "sclk_hevc_cabac", mux_pll_src_cpll_gpll_npll_p, 0,
|
||||||
|
+ COMPOSITE(SCLK_HEVC_CABAC, "sclk_hevc_cabac", mux_pll_src_cgn_pll_nonvop_p, 0,
|
||||||
|
RK3288_CLKSEL_CON(42), 6, 2, MFLAGS, 0, 5, DFLAGS,
|
||||||
|
RK3288_CLKGATE_CON(13), 14, GFLAGS),
|
||||||
|
- COMPOSITE(SCLK_HEVC_CORE, "sclk_hevc_core", mux_pll_src_cpll_gpll_npll_p, 0,
|
||||||
|
+ COMPOSITE(SCLK_HEVC_CORE, "sclk_hevc_core", mux_pll_src_cgn_pll_nonvop_p, 0,
|
||||||
|
RK3288_CLKSEL_CON(42), 14, 2, MFLAGS, 8, 5, DFLAGS,
|
||||||
|
RK3288_CLKGATE_CON(13), 15, GFLAGS),
|
||||||
|
|
||||||
|
@@ -551,7 +555,7 @@ static struct rockchip_clk_branch rk3288_clk_branches[] __initdata = {
|
||||||
|
COMPOSITE(0, "sclk_tspout", mux_tspout_p, 0,
|
||||||
|
RK3288_CLKSEL_CON(35), 14, 2, MFLAGS, 8, 5, DFLAGS,
|
||||||
|
RK3288_CLKGATE_CON(4), 11, GFLAGS),
|
||||||
|
- COMPOSITE(0, "sclk_tsp", mux_pll_src_cpll_gpll_npll_p, 0,
|
||||||
|
+ COMPOSITE(0, "sclk_tsp", mux_pll_src_cgn_pll_nonvop_p, 0,
|
||||||
|
RK3288_CLKSEL_CON(35), 6, 2, MFLAGS, 0, 5, DFLAGS,
|
||||||
|
RK3288_CLKGATE_CON(4), 10, GFLAGS),
|
||||||
|
|
||||||
|
@@ -932,6 +936,7 @@ static void __init rk3288_common_init(struct device_node *np,
|
||||||
|
enum rk3288_variant soc)
|
||||||
|
{
|
||||||
|
struct rockchip_clk_provider *ctx;
|
||||||
|
+ s32 npll_vop = -1;
|
||||||
|
|
||||||
|
rk3288_cru_base = of_iomap(np, 0);
|
||||||
|
if (!rk3288_cru_base) {
|
||||||
|
@@ -939,6 +944,46 @@ static void __init rk3288_common_init(struct device_node *np,
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ if (!of_property_read_s32(np, "rockchip,npll-for-vop", &npll_vop)) {
|
||||||
|
+ if ((npll_vop < -1) || (npll_vop > 1)) {
|
||||||
|
+ pr_warn("%s: invalid VOP to dedicate NPLL to: %d\n",
|
||||||
|
+ __func__, npll_vop);
|
||||||
|
+ } else if (npll_vop >= 0) {
|
||||||
|
+ unsigned int vop_clk_id;
|
||||||
|
+ const char ** npll_names;
|
||||||
|
+ const char ** non_npll_names;
|
||||||
|
+ int i;
|
||||||
|
+
|
||||||
|
+ /* Firstly, not-VOP needs to not use npll */
|
||||||
|
+ mux_pll_src_npll_cpll_gpll_p[0] = "dummy_npll";
|
||||||
|
+ mux_pll_src_cgn_pll_nonvop_p[2] = "dummy_npll";
|
||||||
|
+ mux_pll_src_cpll_gll_usb_npll_p[3] = "dummy_npll";
|
||||||
|
+
|
||||||
|
+ /* Then the npll VOP needs to only use npll, and the other one not use npll. */
|
||||||
|
+ if (npll_vop) {
|
||||||
|
+ vop_clk_id = DCLK_VOP1;
|
||||||
|
+ npll_names = mux_pll_src_cgn_pll_vop1_p;
|
||||||
|
+ non_npll_names = mux_pll_src_cgn_pll_vop0_p;
|
||||||
|
+ } else {
|
||||||
|
+ vop_clk_id = DCLK_VOP0;
|
||||||
|
+ npll_names = mux_pll_src_cgn_pll_vop0_p;
|
||||||
|
+ non_npll_names = mux_pll_src_cgn_pll_vop1_p;
|
||||||
|
+ }
|
||||||
|
+ npll_names[0] = "dummy_cpll";
|
||||||
|
+ npll_names[1] = "dummy_gpll";
|
||||||
|
+ non_npll_names[2] = "dummy_npll";
|
||||||
|
+
|
||||||
|
+ /* Lastly the npll-dedicated-VOP needs to be able to control npll. */
|
||||||
|
+ for (i = 0; i < ARRAY_SIZE(rk3288_clk_branches); i++) {
|
||||||
|
+ if (rk3288_clk_branches[i].id == vop_clk_id) {
|
||||||
|
+ rk3288_clk_branches[i].flags |= CLK_SET_RATE_PARENT;
|
||||||
|
+ break;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ pr_debug("%s: npll dedicated for VOP %d\n", __func__, npll_vop);
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
ctx = rockchip_clk_init(np, rk3288_cru_base, CLK_NR_CLKS);
|
||||||
|
if (IS_ERR(ctx)) {
|
||||||
|
pr_err("%s: rockchip clk init failed\n", __func__);
|
||||||
|
diff --git a/drivers/clk/rockchip/clk.h b/drivers/clk/rockchip/clk.h
|
||||||
|
index 7aa45cc70287a..18c7071ad017e 100644
|
||||||
|
--- a/drivers/clk/rockchip/clk.h
|
||||||
|
+++ b/drivers/clk/rockchip/clk.h
|
||||||
|
@@ -423,6 +423,9 @@ struct clk *rockchip_clk_register_muxgrf(const char *name,
|
||||||
|
|
||||||
|
#define PNAME(x) static const char *const x[] __initconst
|
||||||
|
|
||||||
|
+/* For when you want to be able to modify the pointers. */
|
||||||
|
+#define PNAME_ED(x) static const char * x[] __initdata
|
||||||
|
+
|
||||||
|
enum rockchip_clk_branch_type {
|
||||||
|
branch_composite,
|
||||||
|
branch_mux,
|
Loading…
Reference in a new issue