Ignoring i915's PSR setup time check
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# Maintainer: Jan Alexander Steffens (heftig) <heftig@archlinux.org> | |
pkgbase=linux-zen-psrfix | |
pkgver=5.19.9.zen1 | |
pkgrel=1 | |
pkgdesc='Linux ZEN' | |
_srctag=v${pkgver%.*}-${pkgver##*.} | |
url="https://github.com/zen-kernel/zen-kernel/commits/$_srctag" | |
arch=(x86_64) | |
license=(GPL2) | |
makedepends=( | |
bc libelf pahole cpio perl tar xz | |
xmlto python-sphinx python-sphinx_rtd_theme graphviz imagemagick texlive-latexextra | |
git | |
) | |
options=('!strip') | |
_srcname=zen-kernel | |
source=( | |
"$_srcname::git+https://github.com/zen-kernel/zen-kernel?signed#tag=$_srctag" | |
"psr-ignore-setup-time.patch" | |
config # the main kernel config file | |
) | |
validpgpkeys=( | |
'ABAF11C65A2970B130ABE3C479BE3E4300411886' # Linus Torvalds | |
'647F28654894E3BD457199BE38DBBDC86092693E' # Greg Kroah-Hartman | |
'A2FF3A36AAA56654109064AB19802F8B0D70FC30' # Jan Alexander Steffens (heftig) | |
'C5ADB4F3FEBBCE27A3E54D7D9AE4078033F8024D' # Steven Barrett <steven@liquorix.net> | |
) | |
sha256sums=('SKIP' | |
'SKIP' | |
'49c471ab3cf341c6333f08957c0c3cfccc38a7cef2c9ca1895888f4674b441ec' | |
) | |
export KBUILD_BUILD_HOST=archlinux | |
export KBUILD_BUILD_USER=$pkgbase | |
export KBUILD_BUILD_TIMESTAMP="$(date -Ru${SOURCE_DATE_EPOCH:+d @$SOURCE_DATE_EPOCH})" | |
prepare() { | |
cd $_srcname | |
echo "Setting version..." | |
scripts/setlocalversion --save-scmversion | |
echo "-$pkgrel" > localversion.10-pkgrel | |
echo "${pkgbase#linux}" > localversion.20-pkgname | |
local src | |
for src in "${source[@]}"; do | |
src="${src%%::*}" | |
src="${src##*/}" | |
[[ $src = *.patch ]] || continue | |
echo "Applying patch $src..." | |
patch -Np1 < "../$src" | |
done | |
echo "Setting config..." | |
cp ../config .config | |
make olddefconfig | |
diff -u ../config .config || : | |
make -s kernelrelease > version | |
echo "Prepared $pkgbase version $(<version)" | |
} | |
build() { | |
cd $_srcname | |
make all | |
} | |
_package() { | |
pkgdesc="The $pkgdesc kernel and modules" | |
depends=(coreutils kmod initramfs) | |
optdepends=('wireless-regdb: to set the correct wireless channels of your country' | |
'linux-firmware: firmware images needed for some devices') | |
provides=(VIRTUALBOX-GUEST-MODULES WIREGUARD-MODULE KSMBD-MODULE VHBA-MODULE | |
UKSMD-BUILTIN) | |
replaces=() | |
cd $_srcname | |
local kernver="$(<version)" | |
local modulesdir="$pkgdir/usr/lib/modules/$kernver" | |
echo "Installing boot image..." | |
# systemd expects to find the kernel here to allow hibernation | |
# https://github.com/systemd/systemd/commit/edda44605f06a41fb86b7ab8128dcf99161d2344 | |
install -Dm644 "$(make -s image_name)" "$modulesdir/vmlinuz" | |
# Used by mkinitcpio to name the kernel | |
echo "$pkgbase" | install -Dm644 /dev/stdin "$modulesdir/pkgbase" | |
echo "Installing modules..." | |
make INSTALL_MOD_PATH="$pkgdir/usr" INSTALL_MOD_STRIP=1 \ | |
DEPMOD=/doesnt/exist modules_install # Suppress depmod | |
# remove build and source links | |
rm "$modulesdir"/{source,build} | |
} | |
_package-headers() { | |
pkgdesc="Headers and scripts for building modules for the $pkgdesc kernel" | |
depends=(pahole) | |
cd $_srcname | |
local builddir="$pkgdir/usr/lib/modules/$(<version)/build" | |
echo "Installing build files..." | |
install -Dt "$builddir" -m644 .config Makefile Module.symvers System.map \ | |
localversion.* version vmlinux | |
install -Dt "$builddir/kernel" -m644 kernel/Makefile | |
install -Dt "$builddir/arch/x86" -m644 arch/x86/Makefile | |
cp -t "$builddir" -a scripts | |
# required when STACK_VALIDATION is enabled | |
install -Dt "$builddir/tools/objtool" tools/objtool/objtool | |
# required when DEBUG_INFO_BTF_MODULES is enabled | |
install -Dt "$builddir/tools/bpf/resolve_btfids" tools/bpf/resolve_btfids/resolve_btfids | |
echo "Installing headers..." | |
cp -t "$builddir" -a include | |
cp -t "$builddir/arch/x86" -a arch/x86/include | |
install -Dt "$builddir/arch/x86/kernel" -m644 arch/x86/kernel/asm-offsets.s | |
install -Dt "$builddir/drivers/md" -m644 drivers/md/*.h | |
install -Dt "$builddir/net/mac80211" -m644 net/mac80211/*.h | |
# https://bugs.archlinux.org/task/13146 | |
install -Dt "$builddir/drivers/media/i2c" -m644 drivers/media/i2c/msp3400-driver.h | |
# https://bugs.archlinux.org/task/20402 | |
install -Dt "$builddir/drivers/media/usb/dvb-usb" -m644 drivers/media/usb/dvb-usb/*.h | |
install -Dt "$builddir/drivers/media/dvb-frontends" -m644 drivers/media/dvb-frontends/*.h | |
install -Dt "$builddir/drivers/media/tuners" -m644 drivers/media/tuners/*.h | |
# https://bugs.archlinux.org/task/71392 | |
install -Dt "$builddir/drivers/iio/common/hid-sensors" -m644 drivers/iio/common/hid-sensors/*.h | |
echo "Installing KConfig files..." | |
find . -name 'Kconfig*' -exec install -Dm644 {} "$builddir/{}" \; | |
echo "Removing unneeded architectures..." | |
local arch | |
for arch in "$builddir"/arch/*/; do | |
[[ $arch = */x86/ ]] && continue | |
echo "Removing $(basename "$arch")" | |
rm -r "$arch" | |
done | |
echo "Removing documentation..." | |
rm -r "$builddir/Documentation" | |
echo "Removing broken symlinks..." | |
find -L "$builddir" -type l -printf 'Removing %P\n' -delete | |
echo "Removing loose objects..." | |
find "$builddir" -type f -name '*.o' -printf 'Removing %P\n' -delete | |
echo "Stripping build tools..." | |
local file | |
while read -rd '' file; do | |
case "$(file -bi "$file")" in | |
application/x-sharedlib\;*) # Libraries (.so) | |
strip -v $STRIP_SHARED "$file" ;; | |
application/x-archive\;*) # Libraries (.a) | |
strip -v $STRIP_STATIC "$file" ;; | |
application/x-executable\;*) # Binaries | |
strip -v $STRIP_BINARIES "$file" ;; | |
application/x-pie-executable\;*) # Relocatable binaries | |
strip -v $STRIP_SHARED "$file" ;; | |
esac | |
done < <(find "$builddir" -type f -perm -u+x ! -name vmlinux -print0) | |
echo "Stripping vmlinux..." | |
strip -v $STRIP_STATIC "$builddir/vmlinux" | |
echo "Adding symlink..." | |
mkdir -p "$pkgdir/usr/src" | |
ln -sr "$builddir" "$pkgdir/usr/src/$pkgbase" | |
} | |
_package-docs() { | |
pkgdesc="Documentation for the $pkgdesc kernel" | |
cd $_srcname | |
local builddir="$pkgdir/usr/lib/modules/$(<version)/build" | |
echo "Installing documentation..." | |
local src dst | |
while read -rd '' src; do | |
dst="${src#Documentation/}" | |
dst="$builddir/Documentation/${dst#output/}" | |
install -Dm644 "$src" "$dst" | |
done < <(find Documentation -name '.*' -prune -o ! -type d -print0) | |
echo "Adding symlink..." | |
mkdir -p "$pkgdir/usr/share/doc" | |
ln -sr "$builddir/Documentation" "$pkgdir/usr/share/doc/$pkgbase" | |
} | |
pkgname=("$pkgbase" "$pkgbase-headers") | |
for _p in "${pkgname[@]}"; do | |
eval "package_$_p() { | |
$(declare -f "_package${_p#$pkgbase}") | |
_package${_p#$pkgbase} | |
}" | |
done | |
# vim:set ts=8 sts=2 sw=2 et: |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
diff --color -ruN linux-5.19.8/drivers/gpu/drm/i915/display/intel_psr.c linux-5.19.8-final/drivers/gpu/drm/i915/display/intel_psr.c | |
--- linux-5.19.8/drivers/gpu/drm/i915/display/intel_psr.c 2022-09-08 02:24:08.000000000 -0700 | |
+++ linux-5.19.8-final/drivers/gpu/drm/i915/display/intel_psr.c 2022-09-13 21:01:50.425323000 -0700 | |
@@ -979,20 +979,25 @@ | |
return; | |
} | |
- psr_setup_time = drm_dp_psr_setup_time(intel_dp->psr_dpcd); | |
- if (psr_setup_time < 0) { | |
- drm_dbg_kms(&dev_priv->drm, | |
- "PSR condition failed: Invalid PSR setup time (0x%02x)\n", | |
- intel_dp->psr_dpcd[1]); | |
- return; | |
- } | |
+ if (dev_priv->params.psr_ignore_setup_time) { | |
+ drm_WARN_ON(&dev_priv->drm, | |
+ "PSR force enabled: kernel parameter psr_ignore_setup_time is set\n"); | |
+ } else { | |
+ psr_setup_time = drm_dp_psr_setup_time(intel_dp->psr_dpcd); | |
+ if (psr_setup_time < 0) { | |
+ drm_dbg_kms(&dev_priv->drm, | |
+ "PSR condition failed: Invalid PSR setup time (0x%02x)\n", | |
+ intel_dp->psr_dpcd[1]); | |
+ return; | |
+ } | |
- if (intel_usecs_to_scanlines(adjusted_mode, psr_setup_time) > | |
- adjusted_mode->crtc_vtotal - adjusted_mode->crtc_vdisplay - 1) { | |
- drm_dbg_kms(&dev_priv->drm, | |
- "PSR condition failed: PSR setup time (%d us) too long\n", | |
- psr_setup_time); | |
- return; | |
+ if (intel_usecs_to_scanlines(adjusted_mode, psr_setup_time) > | |
+ adjusted_mode->crtc_vtotal - adjusted_mode->crtc_vdisplay - 1) { | |
+ drm_dbg_kms(&dev_priv->drm, | |
+ "PSR condition failed: PSR setup time (%d us) too long\n", | |
+ psr_setup_time); | |
+ return; | |
+ } | |
} | |
crtc_state->has_psr = true; | |
diff --color -ruN linux-5.19.8/drivers/gpu/drm/i915/i915_params.c linux-5.19.8-final/drivers/gpu/drm/i915/i915_params.c | |
--- linux-5.19.8/drivers/gpu/drm/i915/i915_params.c 2022-09-08 02:24:08.000000000 -0700 | |
+++ linux-5.19.8-final/drivers/gpu/drm/i915/i915_params.c 2022-09-13 20:51:14.473324000 -0700 | |
@@ -104,6 +104,10 @@ | |
"is helpful to detect if PSR issues are related to bad values set in " | |
" VBT. (0=use VBT parameters, 1=use safest parameters)"); | |
+i915_param_named(psr_ignore_setup_time, bool, 0400, | |
+ "Ignore dp's PSR setup time check." | |
+ " (0=default behavior, 1=ignore PSR setup time check)"); | |
+ | |
i915_param_named_unsafe(enable_psr2_sel_fetch, bool, 0400, | |
"Enable PSR2 selective fetch " | |
"(0=disabled, 1=enabled) " | |
diff --color -ruN linux-5.19.8/drivers/gpu/drm/i915/i915_params.h linux-5.19.8-final/drivers/gpu/drm/i915/i915_params.h | |
--- linux-5.19.8/drivers/gpu/drm/i915/i915_params.h 2022-09-08 02:24:08.000000000 -0700 | |
+++ linux-5.19.8-final/drivers/gpu/drm/i915/i915_params.h 2022-09-13 20:48:09.253316000 -0700 | |
@@ -55,6 +55,7 @@ | |
param(int, enable_fbc, -1, 0600) \ | |
param(int, enable_psr, -1, 0600) \ | |
param(bool, psr_safest_params, false, 0400) \ | |
+ param(bool, psr_ignore_setup_time, false, 0400) \ | |
param(bool, enable_psr2_sel_fetch, true, 0400) \ | |
param(int, disable_power_well, -1, 0400) \ | |
param(int, enable_ips, 1, 0600) \ |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment