xref: /OK3568_Linux_fs/kernel/drivers/gpu/drm/i915/display/intel_quirks.c (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun // SPDX-License-Identifier: MIT
2*4882a593Smuzhiyun /*
3*4882a593Smuzhiyun  * Copyright © 2018 Intel Corporation
4*4882a593Smuzhiyun  */
5*4882a593Smuzhiyun 
6*4882a593Smuzhiyun #include <linux/dmi.h>
7*4882a593Smuzhiyun 
8*4882a593Smuzhiyun #include "intel_display_types.h"
9*4882a593Smuzhiyun #include "intel_quirks.h"
10*4882a593Smuzhiyun 
11*4882a593Smuzhiyun /*
12*4882a593Smuzhiyun  * Some machines (Lenovo U160) do not work with SSC on LVDS for some reason
13*4882a593Smuzhiyun  */
quirk_ssc_force_disable(struct drm_i915_private * i915)14*4882a593Smuzhiyun static void quirk_ssc_force_disable(struct drm_i915_private *i915)
15*4882a593Smuzhiyun {
16*4882a593Smuzhiyun 	i915->quirks |= QUIRK_LVDS_SSC_DISABLE;
17*4882a593Smuzhiyun 	drm_info(&i915->drm, "applying lvds SSC disable quirk\n");
18*4882a593Smuzhiyun }
19*4882a593Smuzhiyun 
20*4882a593Smuzhiyun /*
21*4882a593Smuzhiyun  * A machine (e.g. Acer Aspire 5734Z) may need to invert the panel backlight
22*4882a593Smuzhiyun  * brightness value
23*4882a593Smuzhiyun  */
quirk_invert_brightness(struct drm_i915_private * i915)24*4882a593Smuzhiyun static void quirk_invert_brightness(struct drm_i915_private *i915)
25*4882a593Smuzhiyun {
26*4882a593Smuzhiyun 	i915->quirks |= QUIRK_INVERT_BRIGHTNESS;
27*4882a593Smuzhiyun 	drm_info(&i915->drm, "applying inverted panel brightness quirk\n");
28*4882a593Smuzhiyun }
29*4882a593Smuzhiyun 
30*4882a593Smuzhiyun /* Some VBT's incorrectly indicate no backlight is present */
quirk_backlight_present(struct drm_i915_private * i915)31*4882a593Smuzhiyun static void quirk_backlight_present(struct drm_i915_private *i915)
32*4882a593Smuzhiyun {
33*4882a593Smuzhiyun 	i915->quirks |= QUIRK_BACKLIGHT_PRESENT;
34*4882a593Smuzhiyun 	drm_info(&i915->drm, "applying backlight present quirk\n");
35*4882a593Smuzhiyun }
36*4882a593Smuzhiyun 
37*4882a593Smuzhiyun /* Toshiba Satellite P50-C-18C requires T12 delay to be min 800ms
38*4882a593Smuzhiyun  * which is 300 ms greater than eDP spec T12 min.
39*4882a593Smuzhiyun  */
quirk_increase_t12_delay(struct drm_i915_private * i915)40*4882a593Smuzhiyun static void quirk_increase_t12_delay(struct drm_i915_private *i915)
41*4882a593Smuzhiyun {
42*4882a593Smuzhiyun 	i915->quirks |= QUIRK_INCREASE_T12_DELAY;
43*4882a593Smuzhiyun 	drm_info(&i915->drm, "Applying T12 delay quirk\n");
44*4882a593Smuzhiyun }
45*4882a593Smuzhiyun 
46*4882a593Smuzhiyun /*
47*4882a593Smuzhiyun  * GeminiLake NUC HDMI outputs require additional off time
48*4882a593Smuzhiyun  * this allows the onboard retimer to correctly sync to signal
49*4882a593Smuzhiyun  */
quirk_increase_ddi_disabled_time(struct drm_i915_private * i915)50*4882a593Smuzhiyun static void quirk_increase_ddi_disabled_time(struct drm_i915_private *i915)
51*4882a593Smuzhiyun {
52*4882a593Smuzhiyun 	i915->quirks |= QUIRK_INCREASE_DDI_DISABLED_TIME;
53*4882a593Smuzhiyun 	drm_info(&i915->drm, "Applying Increase DDI Disabled quirk\n");
54*4882a593Smuzhiyun }
55*4882a593Smuzhiyun 
56*4882a593Smuzhiyun struct intel_quirk {
57*4882a593Smuzhiyun 	int device;
58*4882a593Smuzhiyun 	int subsystem_vendor;
59*4882a593Smuzhiyun 	int subsystem_device;
60*4882a593Smuzhiyun 	void (*hook)(struct drm_i915_private *i915);
61*4882a593Smuzhiyun };
62*4882a593Smuzhiyun 
63*4882a593Smuzhiyun /* For systems that don't have a meaningful PCI subdevice/subvendor ID */
64*4882a593Smuzhiyun struct intel_dmi_quirk {
65*4882a593Smuzhiyun 	void (*hook)(struct drm_i915_private *i915);
66*4882a593Smuzhiyun 	const struct dmi_system_id (*dmi_id_list)[];
67*4882a593Smuzhiyun };
68*4882a593Smuzhiyun 
intel_dmi_reverse_brightness(const struct dmi_system_id * id)69*4882a593Smuzhiyun static int intel_dmi_reverse_brightness(const struct dmi_system_id *id)
70*4882a593Smuzhiyun {
71*4882a593Smuzhiyun 	DRM_INFO("Backlight polarity reversed on %s\n", id->ident);
72*4882a593Smuzhiyun 	return 1;
73*4882a593Smuzhiyun }
74*4882a593Smuzhiyun 
75*4882a593Smuzhiyun static const struct intel_dmi_quirk intel_dmi_quirks[] = {
76*4882a593Smuzhiyun 	{
77*4882a593Smuzhiyun 		.dmi_id_list = &(const struct dmi_system_id[]) {
78*4882a593Smuzhiyun 			{
79*4882a593Smuzhiyun 				.callback = intel_dmi_reverse_brightness,
80*4882a593Smuzhiyun 				.ident = "NCR Corporation",
81*4882a593Smuzhiyun 				.matches = {DMI_MATCH(DMI_SYS_VENDOR, "NCR Corporation"),
82*4882a593Smuzhiyun 					    DMI_MATCH(DMI_PRODUCT_NAME, ""),
83*4882a593Smuzhiyun 				},
84*4882a593Smuzhiyun 			},
85*4882a593Smuzhiyun 			{
86*4882a593Smuzhiyun 				.callback = intel_dmi_reverse_brightness,
87*4882a593Smuzhiyun 				.ident = "Thundersoft TST178 tablet",
88*4882a593Smuzhiyun 				/* DMI strings are too generic, also match on BIOS date */
89*4882a593Smuzhiyun 				.matches = {DMI_EXACT_MATCH(DMI_BOARD_VENDOR, "AMI Corporation"),
90*4882a593Smuzhiyun 					    DMI_EXACT_MATCH(DMI_BOARD_NAME, "Aptio CRB"),
91*4882a593Smuzhiyun 					    DMI_EXACT_MATCH(DMI_PRODUCT_NAME, "To be filled by O.E.M."),
92*4882a593Smuzhiyun 					    DMI_EXACT_MATCH(DMI_BIOS_DATE, "04/15/2014"),
93*4882a593Smuzhiyun 				},
94*4882a593Smuzhiyun 			},
95*4882a593Smuzhiyun 			{ }  /* terminating entry */
96*4882a593Smuzhiyun 		},
97*4882a593Smuzhiyun 		.hook = quirk_invert_brightness,
98*4882a593Smuzhiyun 	},
99*4882a593Smuzhiyun };
100*4882a593Smuzhiyun 
101*4882a593Smuzhiyun static struct intel_quirk intel_quirks[] = {
102*4882a593Smuzhiyun 	/* Lenovo U160 cannot use SSC on LVDS */
103*4882a593Smuzhiyun 	{ 0x0046, 0x17aa, 0x3920, quirk_ssc_force_disable },
104*4882a593Smuzhiyun 
105*4882a593Smuzhiyun 	/* Sony Vaio Y cannot use SSC on LVDS */
106*4882a593Smuzhiyun 	{ 0x0046, 0x104d, 0x9076, quirk_ssc_force_disable },
107*4882a593Smuzhiyun 
108*4882a593Smuzhiyun 	/* Acer Aspire 5734Z must invert backlight brightness */
109*4882a593Smuzhiyun 	{ 0x2a42, 0x1025, 0x0459, quirk_invert_brightness },
110*4882a593Smuzhiyun 
111*4882a593Smuzhiyun 	/* Acer/eMachines G725 */
112*4882a593Smuzhiyun 	{ 0x2a42, 0x1025, 0x0210, quirk_invert_brightness },
113*4882a593Smuzhiyun 
114*4882a593Smuzhiyun 	/* Acer/eMachines e725 */
115*4882a593Smuzhiyun 	{ 0x2a42, 0x1025, 0x0212, quirk_invert_brightness },
116*4882a593Smuzhiyun 
117*4882a593Smuzhiyun 	/* Acer/Packard Bell NCL20 */
118*4882a593Smuzhiyun 	{ 0x2a42, 0x1025, 0x034b, quirk_invert_brightness },
119*4882a593Smuzhiyun 
120*4882a593Smuzhiyun 	/* Acer Aspire 4736Z */
121*4882a593Smuzhiyun 	{ 0x2a42, 0x1025, 0x0260, quirk_invert_brightness },
122*4882a593Smuzhiyun 
123*4882a593Smuzhiyun 	/* Acer Aspire 5336 */
124*4882a593Smuzhiyun 	{ 0x2a42, 0x1025, 0x048a, quirk_invert_brightness },
125*4882a593Smuzhiyun 
126*4882a593Smuzhiyun 	/* Acer C720 and C720P Chromebooks (Celeron 2955U) have backlights */
127*4882a593Smuzhiyun 	{ 0x0a06, 0x1025, 0x0a11, quirk_backlight_present },
128*4882a593Smuzhiyun 
129*4882a593Smuzhiyun 	/* Acer C720 Chromebook (Core i3 4005U) */
130*4882a593Smuzhiyun 	{ 0x0a16, 0x1025, 0x0a11, quirk_backlight_present },
131*4882a593Smuzhiyun 
132*4882a593Smuzhiyun 	/* Apple Macbook 2,1 (Core 2 T7400) */
133*4882a593Smuzhiyun 	{ 0x27a2, 0x8086, 0x7270, quirk_backlight_present },
134*4882a593Smuzhiyun 
135*4882a593Smuzhiyun 	/* Apple Macbook 4,1 */
136*4882a593Smuzhiyun 	{ 0x2a02, 0x106b, 0x00a1, quirk_backlight_present },
137*4882a593Smuzhiyun 
138*4882a593Smuzhiyun 	/* Toshiba CB35 Chromebook (Celeron 2955U) */
139*4882a593Smuzhiyun 	{ 0x0a06, 0x1179, 0x0a88, quirk_backlight_present },
140*4882a593Smuzhiyun 
141*4882a593Smuzhiyun 	/* HP Chromebook 14 (Celeron 2955U) */
142*4882a593Smuzhiyun 	{ 0x0a06, 0x103c, 0x21ed, quirk_backlight_present },
143*4882a593Smuzhiyun 
144*4882a593Smuzhiyun 	/* Dell Chromebook 11 */
145*4882a593Smuzhiyun 	{ 0x0a06, 0x1028, 0x0a35, quirk_backlight_present },
146*4882a593Smuzhiyun 
147*4882a593Smuzhiyun 	/* Dell Chromebook 11 (2015 version) */
148*4882a593Smuzhiyun 	{ 0x0a16, 0x1028, 0x0a35, quirk_backlight_present },
149*4882a593Smuzhiyun 
150*4882a593Smuzhiyun 	/* Toshiba Satellite P50-C-18C */
151*4882a593Smuzhiyun 	{ 0x191B, 0x1179, 0xF840, quirk_increase_t12_delay },
152*4882a593Smuzhiyun 
153*4882a593Smuzhiyun 	/* GeminiLake NUC */
154*4882a593Smuzhiyun 	{ 0x3185, 0x8086, 0x2072, quirk_increase_ddi_disabled_time },
155*4882a593Smuzhiyun 	{ 0x3184, 0x8086, 0x2072, quirk_increase_ddi_disabled_time },
156*4882a593Smuzhiyun 	/* ASRock ITX*/
157*4882a593Smuzhiyun 	{ 0x3185, 0x1849, 0x2212, quirk_increase_ddi_disabled_time },
158*4882a593Smuzhiyun 	{ 0x3184, 0x1849, 0x2212, quirk_increase_ddi_disabled_time },
159*4882a593Smuzhiyun 	/* ECS Liva Q2 */
160*4882a593Smuzhiyun 	{ 0x3185, 0x1019, 0xa94d, quirk_increase_ddi_disabled_time },
161*4882a593Smuzhiyun 	{ 0x3184, 0x1019, 0xa94d, quirk_increase_ddi_disabled_time },
162*4882a593Smuzhiyun };
163*4882a593Smuzhiyun 
intel_init_quirks(struct drm_i915_private * i915)164*4882a593Smuzhiyun void intel_init_quirks(struct drm_i915_private *i915)
165*4882a593Smuzhiyun {
166*4882a593Smuzhiyun 	struct pci_dev *d = i915->drm.pdev;
167*4882a593Smuzhiyun 	int i;
168*4882a593Smuzhiyun 
169*4882a593Smuzhiyun 	for (i = 0; i < ARRAY_SIZE(intel_quirks); i++) {
170*4882a593Smuzhiyun 		struct intel_quirk *q = &intel_quirks[i];
171*4882a593Smuzhiyun 
172*4882a593Smuzhiyun 		if (d->device == q->device &&
173*4882a593Smuzhiyun 		    (d->subsystem_vendor == q->subsystem_vendor ||
174*4882a593Smuzhiyun 		     q->subsystem_vendor == PCI_ANY_ID) &&
175*4882a593Smuzhiyun 		    (d->subsystem_device == q->subsystem_device ||
176*4882a593Smuzhiyun 		     q->subsystem_device == PCI_ANY_ID))
177*4882a593Smuzhiyun 			q->hook(i915);
178*4882a593Smuzhiyun 	}
179*4882a593Smuzhiyun 	for (i = 0; i < ARRAY_SIZE(intel_dmi_quirks); i++) {
180*4882a593Smuzhiyun 		if (dmi_check_system(*intel_dmi_quirks[i].dmi_id_list) != 0)
181*4882a593Smuzhiyun 			intel_dmi_quirks[i].hook(i915);
182*4882a593Smuzhiyun 	}
183*4882a593Smuzhiyun }
184