mirror of
https://github.com/archr-linux/Arch-R.git
synced 2026-03-31 14:41:55 -07:00
Major architecture change: move from BSP kernel 6.6 with pre-merged panel DTBs to mainline kernel 6.12.61 LTS with separated board DTBs + panel overlays. - Board DTB = hardware profile (GPIOs, PMIC, joypad, audio). 16 boards. Auto-selected by U-Boot via SARADC ADC reading (hwrev). - Panel overlay = display init sequence. 20 panels. Applied at boot time via boot.ini fdt apply. - Two image variants: original (a_boot.ini) and clone (b_boot.ini) - Kernel cross-compiles from x86 host (no ARM chroot needed) - Initramfs boot splash with SVG rendering at 0.7s - Out-of-tree joypad driver (singleadc-joypad) for clone boards - Panel generic-dsi driver with archr,generic-dsi compatible Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
236 lines
11 KiB
Diff
236 lines
11 KiB
Diff
diff --git a/drivers/gpu/drm/panel/panel-newvision-nv3051d.c b/drivers/gpu/drm/panel/panel-newvision-nv3051d.c
|
|
index 5d115ecd5dd4..1b199662e7ed 100644
|
|
--- a/drivers/gpu/drm/panel/panel-newvision-nv3051d.c
|
|
+++ b/drivers/gpu/drm/panel/panel-newvision-nv3051d.c
|
|
@@ -480,14 +480,14 @@ static const struct drm_display_mode nv3051d_rgxx3_modes[] = {
|
|
static const struct drm_display_mode nv3051d_rk2023_modes[] = {
|
|
{
|
|
.hdisplay = 640,
|
|
- .hsync_start = 640 + 40,
|
|
- .hsync_end = 640 + 40 + 2,
|
|
- .htotal = 640 + 40 + 2 + 80,
|
|
+ .hsync_start = 640 + 48,
|
|
+ .hsync_end = 640 + 48 + 2,
|
|
+ .htotal = 640 + 48 + 2 + 47,
|
|
.vdisplay = 480,
|
|
- .vsync_start = 480 + 18,
|
|
- .vsync_end = 480 + 18 + 2,
|
|
- .vtotal = 480 + 18 + 2 + 4,
|
|
- .clock = 24150,
|
|
+ .vsync_start = 480 + 2,
|
|
+ .vsync_end = 480 + 2 + 4,
|
|
+ .vtotal = 480 + 2 + 4 + 3,
|
|
+ .clock = 21600,
|
|
.flags = DRM_MODE_FLAG_NHSYNC | DRM_MODE_FLAG_NVSYNC,
|
|
},
|
|
};
|
|
@@ -520,7 +520,8 @@ static const struct nv3051d_panel_info nv3051d_rk2023_info = {
|
|
.height_mm = 57,
|
|
.bus_flags = DRM_BUS_FLAG_DE_LOW | DRM_BUS_FLAG_PIXDATA_DRIVE_NEGEDGE,
|
|
.mode_flags = MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_BURST |
|
|
- MIPI_DSI_MODE_LPM | MIPI_DSI_MODE_NO_EOT_PACKET,
|
|
+ MIPI_DSI_MODE_LPM | MIPI_DSI_MODE_NO_EOT_PACKET |
|
|
+ MIPI_DSI_CLOCK_NON_CONTINUOUS,
|
|
};
|
|
|
|
static const struct of_device_id newvision_nv3051d_of_match[] = {
|
|
diff --git a/drivers/gpu/drm/panel/panel-sitronix-st7703.c b/drivers/gpu/drm/panel/panel-sitronix-st7703.c
|
|
index 67e8e45498cb..a9cc6c6c0fc1 100644
|
|
--- a/drivers/gpu/drm/panel/panel-sitronix-st7703.c
|
|
+++ b/drivers/gpu/drm/panel/panel-sitronix-st7703.c
|
|
@@ -673,6 +673,182 @@ static const struct st7703_panel_desc gameforcechi_desc = {
|
|
.init_sequence = gameforcechi_init_sequence,
|
|
};
|
|
|
|
+static void xu10_init_sequence(struct mipi_dsi_multi_context *dsi_ctx)
|
|
+{
|
|
+ /*
|
|
+ * Init sequence was supplied by the panel vendor.
|
|
+ */
|
|
+
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETEXTC, 0xf1, 0x12, 0x83);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETAPID, 0x00, 0x00, 0x00,
|
|
+ 0xda, 0x80);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETDISP, 0x00, 0x03, 0xf0);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETRGBIF, 0x10, 0x10, 0x28,
|
|
+ 0x28, 0x03, 0xff, 0x00, 0x00, 0x00, 0x00);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETCYC, 0x80);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETBGP, 0x0a, 0x0a);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETVCOM, 0x8e, 0x8e);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETPOWER_EXT, 0x26, 0x22,
|
|
+ 0xf0, 0x13);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETMIPI, 0x33, 0x81, 0x05,
|
|
+ 0xf9, 0x0e, 0x0e, 0x20, 0x00, 0x00, 0x00, 0x00,
|
|
+ 0x00, 0x00, 0x00, 0x44, 0x25, 0x00, 0x90, 0x0a,
|
|
+ 0x00, 0x00, 0x01, 0x4f, 0x01, 0x00, 0x00, 0x37);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETVDC, 0x47);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_UNKNOWN_BF, 0x02, 0x11, 0x00);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETSCR, 0x73, 0x73, 0x50, 0x50,
|
|
+ 0x00, 0x00, 0x12, 0x70, 0x00);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETPOWER, 0x53, 0x00, 0x32,
|
|
+ 0x32, 0x77, 0xd1, 0xcc, 0xcc, 0x77, 0x77, 0x33,
|
|
+ 0x33);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETECO, 0x82, 0x00, 0xbf, 0xff,
|
|
+ 0x00, 0xff);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETIO, 0xb8, 0x00, 0x0a, 0x00,
|
|
+ 0x00, 0x00);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETCABC, 0x10, 0x40, 0x1e,
|
|
+ 0x02);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETPANEL, 0x0b);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETGAMMA, 0x00, 0x06, 0x0a,
|
|
+ 0x2a, 0x3d, 0x3f, 0x3b, 0x37, 0x06, 0x0b, 0x0c,
|
|
+ 0x10, 0x11, 0x10, 0x13, 0x12, 0x18, 0x00, 0x06,
|
|
+ 0x0a, 0x2a, 0x3d, 0x3f, 0x3b, 0x37, 0x06, 0x0b,
|
|
+ 0x0c, 0x10, 0x11, 0x10, 0x13, 0x12, 0x18);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETEQ, 0x07, 0x07, 0x0b, 0x0b,
|
|
+ 0x0b, 0x0b, 0x00, 0x00, 0x00, 0x00, 0xff, 0x00,
|
|
+ 0xc0, 0x10);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETGIP1, 0xc8, 0x10, 0x02, 0x00,
|
|
+ 0x00, 0xb0, 0xb1, 0x11, 0x31, 0x23, 0x28, 0x80,
|
|
+ 0xb0, 0xb1, 0x27, 0x08, 0x00, 0x04, 0x02, 0x00,
|
|
+ 0x00, 0x00, 0x00, 0x04, 0x02, 0x00, 0x00, 0x00,
|
|
+ 0x88, 0x88, 0xba, 0x60, 0x24, 0x08, 0x88, 0x88,
|
|
+ 0x88, 0x88, 0x88, 0x88, 0x88, 0xba, 0x71, 0x35,
|
|
+ 0x18, 0x88, 0x88, 0x88, 0x88, 0x88, 0x00, 0x00,
|
|
+ 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
+ 0x00, 0x00, 0x00);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETGIP2, 0x97, 0x0a, 0x82, 0x02,
|
|
+ 0x03, 0x07, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
+ 0x81, 0x88, 0xba, 0x17, 0x53, 0x88, 0x88, 0x88,
|
|
+ 0x88, 0x88, 0x88, 0x80, 0x88, 0xba, 0x06, 0x42,
|
|
+ 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x23, 0x00,
|
|
+ 0x00, 0x02, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
+ 0x00);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_UNKNOWN_EF, 0xff, 0xff, 0x01, 0x05, 0x96, 0x01, 0x11, 0x05, 0x78, 0x01, 0x29);
|
|
+}
|
|
+
|
|
+static const struct drm_display_mode xu10_mode = {
|
|
+ .hdisplay = 640,
|
|
+ .hsync_start = 640 + 120,
|
|
+ .hsync_end = 640 + 120 + 10,
|
|
+ .htotal = 640 + 120 + 10 + 120,
|
|
+ .vdisplay = 480,
|
|
+ .vsync_start = 480 + 17,
|
|
+ .vsync_end = 480 + 17 + 4,
|
|
+ .vtotal = 480 + 17 + 4 + 13,
|
|
+ .clock = 30000,
|
|
+ .flags = DRM_MODE_FLAG_NHSYNC | DRM_MODE_FLAG_NVSYNC,
|
|
+ .width_mm = 52,
|
|
+ .height_mm = 70,
|
|
+};
|
|
+
|
|
+static const struct st7703_panel_desc xu10_desc = {
|
|
+ .mode = &xu10_mode,
|
|
+ .lanes = 4,
|
|
+ .mode_flags = MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_BURST |
|
|
+ MIPI_DSI_MODE_NO_EOT_PACKET | MIPI_DSI_MODE_LPM,
|
|
+ .format = MIPI_DSI_FMT_RGB888,
|
|
+ .init_sequence = xu10_init_sequence,
|
|
+};
|
|
+
|
|
+static void r36s_init_sequence(struct mipi_dsi_multi_context *dsi_ctx)
|
|
+{
|
|
+ /*
|
|
+ * Init sequence was supplied by the panel vendor.
|
|
+ */
|
|
+
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETEXTC, 0xf1, 0x12, 0x83);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETAPID, 0x00, 0x00, 0x00,
|
|
+ 0xda, 0x80);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETDISP, 0x00, 0x13, 0x70);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETRGBIF, 0x10, 0x10, 0x28,
|
|
+ 0x28, 0x03, 0xff, 0x00, 0x00, 0x00, 0x00);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETCYC, 0x80);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETBGP, 0x0a, 0x0a);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETVCOM, 0x7f, 0x7f);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETPOWER_EXT, 0x26, 0x62,
|
|
+ 0xf0, 0x63);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETMIPI, 0x33, 0x81, 0x05,
|
|
+ 0xf9, 0x0e, 0x0e, 0x20, 0x00, 0x00, 0x00, 0x00,
|
|
+ 0x00, 0x00, 0x00, 0x44, 0x25, 0x00, 0x90, 0x0a,
|
|
+ 0x00, 0x00, 0x01, 0x4f, 0x01, 0x00, 0x00, 0x37);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETVDC, 0x47);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_UNKNOWN_BF, 0x02, 0x11, 0x00);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETSCR, 0x73, 0x73, 0x50, 0x50,
|
|
+ 0x00, 0x00, 0x12, 0x50, 0x00);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETPOWER, 0x53, 0xc0, 0x32,
|
|
+ 0x32, 0x77, 0xe1, 0xdd, 0xdd, 0x77, 0x77, 0x33,
|
|
+ 0x33);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETECO, 0x82, 0x00, 0xbf, 0xff,
|
|
+ 0x00, 0xff);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETIO, 0xb8, 0x00, 0x0a, 0x00,
|
|
+ 0x00, 0x00);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETCABC, 0x10, 0x40, 0x1e,
|
|
+ 0x02);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETPANEL, 0x0b);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETGAMMA, 0x00, 0x07, 0x0d,
|
|
+ 0x37, 0x35, 0x3f, 0x41, 0x44, 0x06, 0x0c, 0x0d,
|
|
+ 0x0f, 0x11, 0x10, 0x12, 0x14, 0x1a, 0x00, 0x07,
|
|
+ 0x0d, 0x37, 0x35, 0x3f, 0x41, 0x44, 0x06, 0x0c,
|
|
+ 0x0d, 0x0f, 0x11, 0x10, 0x12, 0x14, 0x1a);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETEQ, 0x07, 0x07, 0x0b, 0x0b,
|
|
+ 0x0b, 0x0b, 0x00, 0x00, 0x00, 0x00, 0xff, 0x00,
|
|
+ 0xc0, 0x10);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETGIP1, 0xc8, 0x10, 0x02, 0x00,
|
|
+ 0x00, 0xb0, 0xb1, 0x11, 0x31, 0x23, 0x28, 0x80,
|
|
+ 0xb0, 0xb1, 0x27, 0x08, 0x00, 0x04, 0x02, 0x00,
|
|
+ 0x00, 0x00, 0x00, 0x04, 0x02, 0x00, 0x00, 0x00,
|
|
+ 0x88, 0x88, 0xba, 0x60, 0x24, 0x08, 0x88, 0x88,
|
|
+ 0x88, 0x88, 0x88, 0x88, 0x88, 0xba, 0x71, 0x35,
|
|
+ 0x18, 0x88, 0x88, 0x88, 0x88, 0x88, 0x00, 0x00,
|
|
+ 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
+ 0x00, 0x00, 0x00);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_SETGIP2, 0x97, 0x0a, 0x82, 0x02,
|
|
+ 0x03, 0x07, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
+ 0x81, 0x88, 0xba, 0x17, 0x53, 0x88, 0x88, 0x88,
|
|
+ 0x88, 0x88, 0x88, 0x80, 0x88, 0xba, 0x06, 0x42,
|
|
+ 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x23, 0x00,
|
|
+ 0x00, 0x02, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
+ 0x00);
|
|
+ mipi_dsi_dcs_write_seq_multi(dsi_ctx, ST7703_CMD_UNKNOWN_EF, 0xff, 0xff, 0x01, 0x05, 0xc8, 0x01, 0x11, 0x05, 0x32, 0x01, 0x29);
|
|
+}
|
|
+
|
|
+static const struct drm_display_mode r36s_mode = {
|
|
+ .hdisplay = 640,
|
|
+ .hsync_start = 640 + 450,
|
|
+ .hsync_end = 640 + 450 + 70,
|
|
+ .htotal = 640 + 450 + 70 + 450,
|
|
+ .vdisplay = 480,
|
|
+ .vsync_start = 480 + 17,
|
|
+ .vsync_end = 480 + 17 + 5,
|
|
+ .vtotal = 480 + 17 + 5 + 13,
|
|
+ .clock = 50000,
|
|
+ .flags = DRM_MODE_FLAG_NHSYNC | DRM_MODE_FLAG_NVSYNC,
|
|
+ .width_mm = 52,
|
|
+ .height_mm = 70,
|
|
+};
|
|
+
|
|
+static const struct st7703_panel_desc r36s_desc = {
|
|
+ .mode = &r36s_mode,
|
|
+ .lanes = 4,
|
|
+ .mode_flags = MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_BURST |
|
|
+ MIPI_DSI_MODE_NO_EOT_PACKET | MIPI_DSI_MODE_LPM,
|
|
+ .format = MIPI_DSI_FMT_RGB888,
|
|
+ .init_sequence = r36s_init_sequence,
|
|
+};
|
|
+
|
|
static int st7703_enable(struct drm_panel *panel)
|
|
{
|
|
struct st7703 *ctx = panel_to_st7703(panel);
|
|
@@ -916,8 +1092,11 @@ static void st7703_remove(struct mipi_dsi_device *dsi)
|
|
}
|
|
|
|
static const struct of_device_id st7703_of_match[] = {
|
|
+ { .compatible = "anbernic,rg351v-panel-v2", .data = &rg353v2_desc },
|
|
{ .compatible = "anbernic,rg353v-panel-v2", .data = &rg353v2_desc },
|
|
+ { .compatible = "gameconsole,r36s-panel", .data = &r36s_desc },
|
|
{ .compatible = "gameforce,chi-panel", .data = &gameforcechi_desc },
|
|
+ { .compatible = "magicx,xu10-panel", .data = &xu10_desc },
|
|
{ .compatible = "powkiddy,rgb10max3-panel", .data = &rgb10max3_panel_desc },
|
|
{ .compatible = "powkiddy,rgb30-panel", .data = &rgb30panel_desc },
|
|
{ .compatible = "rocktech,jh057n00900", .data = &jh057n00900_panel_desc },
|