From 43464026953de02af2df28d0e161618dc09737a8 Mon Sep 17 00:00:00 2001
From: Hacker1245 <kacper12455@gmail.com>
Date: Fri, 1 Feb 2019 18:45:00 +0100
Subject: [PATCH] motorola-cedric: fix X11 framebuffer (!187)

This patch fixes Xorg. Adapted from the Xiaomi A1.

[skip ci]: already built successfully in CI
---
 device/linux-motorola-cedric/APKBUILD       |  6 +-
 device/linux-motorola-cedric/fb-fixed.patch | 96 +++++++++++++++++++++
 2 files changed, 100 insertions(+), 2 deletions(-)
 create mode 100644 device/linux-motorola-cedric/fb-fixed.patch

diff --git a/device/linux-motorola-cedric/APKBUILD b/device/linux-motorola-cedric/APKBUILD
index 030ddbd2d..a07ca1246 100644
--- a/device/linux-motorola-cedric/APKBUILD
+++ b/device/linux-motorola-cedric/APKBUILD
@@ -3,7 +3,7 @@
 
 pkgname="linux-motorola-cedric"
 pkgver=3.18.49
-pkgrel=1
+pkgrel=2
 pkgdesc="Motorola Moto G5 kernel fork"
 arch="aarch64"
 _carch="arm64"
@@ -28,6 +28,7 @@ source="
 	03_fix_rndis_ipa_trace_header_not_found.patch
 	05_fix_u_f_header.patch
 	06_fix_usb_gadget_function.patch
+	fb-fixed.patch
 "
 builddir="$srcdir/${_repository}-${_commit}"
 
@@ -74,4 +75,5 @@ sha512sums="706b37cf09d23abab80ba6e8dfbd8c806e4ecb4c3a31f0b0b5ba7ac29c7922716c46
 197d40a214ada87fcb2dfc0ae4911704b9a93354b75179cd6b4aadbb627a37ec262cf516921c84a8b1806809b70a7b440cdc8310a4a55fca5d2c0baa988e3967  gcc8-fix-put-user.patch
 9c549714f03c7a7666e8aa7508a48cfdccab7cf3e97fb59c4df8fa97f75492365926f82c4a677c50780d68d4905504dcccbdd6de6344bd8d4b88b2331933ed46  03_fix_rndis_ipa_trace_header_not_found.patch
 b408f157cc025d410b38f5aee9be977e670e1ac3f195f6c3a6681446fa0c3887067d62a4f729cfcd058fab42fca355b0265764dc2d21515f6e023ed025f55d41  05_fix_u_f_header.patch
-1f23466d1a864f2d2c67ae4250b0c166ecb7755779bbdad6732808a001cc2826cc1d013c2281d2ca1d5abd7d60d13783f0b9f11bb8359971f2b30b911e627220  06_fix_usb_gadget_function.patch"
+1f23466d1a864f2d2c67ae4250b0c166ecb7755779bbdad6732808a001cc2826cc1d013c2281d2ca1d5abd7d60d13783f0b9f11bb8359971f2b30b911e627220  06_fix_usb_gadget_function.patch
+99a3fda1246449b64d5be7cafeb287a04c234dcb3e7c8617d2aa31442974bf8788857b4935a6000fc157542f713ec253718133b92caab8932d808a760e3b667a  fb-fixed.patch"
diff --git a/device/linux-motorola-cedric/fb-fixed.patch b/device/linux-motorola-cedric/fb-fixed.patch
new file mode 100644
index 000000000..1611e18ca
--- /dev/null
+++ b/device/linux-motorola-cedric/fb-fixed.patch
@@ -0,0 +1,96 @@
+diff -r -u mdss/mdss_fb.c android_kernel_motorola_msm8937/drivers/video/msm/mdss/mdss_fb.c
+--- mdss/mdss_fb.c	2019-01-24 20:56:07.984371000 +0100
++++ android_kernel_motorola_msm8937/drivers/video/msm/mdss/mdss_fb.c	2019-01-24 21:06:44.513242695 +0100
+@@ -1962,7 +1962,7 @@
+ 		if (is_panel_split(mfd) && pdata->next)
+ 			mdss_fb_validate_split(pdata->panel_info.xres,
+ 					pdata->next->panel_info.xres, mfd);
+-		mdss_panelinfo_to_fb_var(panel_info, var);
++		mdss_panelinfo_to_fb_var(mfd);
+ 		if (mdss_fb_send_panel_event(mfd, MDSS_EVENT_CHECK_PARAMS,
+ 							panel_info))
+ 			pr_err("Failed to send panel event CHECK_PARAMS\n");
+@@ -2077,7 +2077,7 @@
+ 		 * programmed in the controller.
+ 		 * Update this info in the upstream structs.
+ 		 */
+-		mdss_panelinfo_to_fb_var(panel_info, var);
++		mdss_panelinfo_to_fb_var(mfd);
+ 
+ 		/* Start the work thread to signal idle time */
+ 		if (mfd->idle_time)
+@@ -2807,7 +2807,7 @@
+ 		return ret;
+ 	}
+ 
+-	mdss_panelinfo_to_fb_var(panel_info, var);
++	mdss_panelinfo_to_fb_var(mfd);
+ 
+ 	fix->type = panel_info->is_3d_panel;
+ 	if (mfd->mdp.fb_stride)
+@@ -3512,7 +3512,7 @@
+ 	}
+ 	var->xres_virtual = var->xres;
+ 	var->yres_virtual = pinfo->yres * mfd->fb_page;
+-	mdss_panelinfo_to_fb_var(pinfo, var);
++	mdss_panelinfo_to_fb_var(mfd);
+ }
+ 
+ int mdss_fb_atomic_commit(struct fb_info *info,
+@@ -3731,9 +3731,14 @@
+ 		pinfo->mipi.dsi_pclk_rate = pinfo->clk_rate;
+ }
+ 
+-void mdss_panelinfo_to_fb_var(struct mdss_panel_info *pinfo,
+-						struct fb_var_screeninfo *var)
++void mdss_panelinfo_to_fb_var(struct msm_fb_data_type *mfd)
+ {
++	if (!mfd)
++		return -EINVAL;
++
++	struct mdss_panel_info *pinfo = mfd->panel_info;
++	struct fb_info *fbi = mfd->fbi;
++	struct fb_var_screeninfo *var = &fbi->var;
+ 	u32 frame_rate;
+ 
+ 	var->xres = mdss_fb_get_panel_xres(pinfo);
+@@ -3767,7 +3772,14 @@
+ 	if (pinfo->physical_height)
+ 		var->height = pinfo->physical_height;
+ 
+-	pr_debug("ScreenInfo: res=%dx%d [%d, %d] [%d, %d]\n",
++	//Hack to update current fbi->mode according to fbi->var when var is updated from panel info
++	if (fbi->mode) {
++		printk("Updating mdss fb mode from fb var\n");
++		fb_var_to_videomode(fbi->mode, var);
++	}
++
++	printk("ScreenInfo: res=%dx%d [%d, %d] [%d, %d]\n",
++
+ 		var->xres, var->yres, var->left_margin,
+ 		var->right_margin, var->upper_margin,
+ 		var->lower_margin);
+diff -r -u mdss/mdss_fb.h android_kernel_motorola_msm8937/drivers/video/msm/mdss/mdss_fb.h
+--- mdss/mdss_fb.h	2019-01-24 20:56:07.984371000 +0100
++++ android_kernel_motorola_msm8937/drivers/video/msm/mdss/mdss_fb.h	2019-01-24 21:07:52.105682759 +0100
+@@ -449,6 +449,5 @@
+ 
+ u32 mdss_fb_get_mode_switch(struct msm_fb_data_type *mfd);
+ void mdss_fb_report_panel_dead(struct msm_fb_data_type *mfd);
+-void mdss_panelinfo_to_fb_var(struct mdss_panel_info *pinfo,
+-						struct fb_var_screeninfo *var);
++void mdss_panelinfo_to_fb_var(struct msm_fb_data_type *mfd);
+ #endif /* MDSS_FB_H */
+diff -r -u mdss/mdss_mdp_overlay.c android_kernel_motorola_msm8937/drivers/video/msm/mdss/mdss_mdp_overlay.c
+--- mdss/mdss_mdp_overlay.c	2019-01-24 20:56:08.004371000 +0100
++++ android_kernel_motorola_msm8937/drivers/video/msm/mdss/mdss_mdp_overlay.c	2019-01-24 21:08:47.682038150 +0100
+@@ -2982,7 +2982,7 @@
+ 	 * data, so any further call to get the screen
+ 	 * info has the updated timings.
+ 	 */
+-	mdss_panelinfo_to_fb_var(&pdata->panel_info, var);
++	mdss_panelinfo_to_fb_var(mfd);
+ 
+ 	MDSS_XLOG(dfps);
+ 	mutex_unlock(&mdp5_data->dfps_lock);
+