[PATCH 2/4] drm/solomon: use ssd130x_run_cmd_seq() in ssd130x_init()
From: Alberto Ruiz via B4 Relay
Date: Fri Jun 12 2026 - 13:18:18 EST
From: Alberto Ruiz <aruiz@xxxxxxxxxx>
Replace individual ssd130x_write_cmd() calls and per-command error
checks with flat command arrays dispatched through ssd130x_run_cmd_seq().
Signed-off-by: Alberto Ruiz <aruiz@xxxxxxxxxx>
---
drivers/gpu/drm/solomon/ssd130x.c | 72 ++++++++++++++-------------------------
1 file changed, 26 insertions(+), 46 deletions(-)
diff --git a/drivers/gpu/drm/solomon/ssd130x.c b/drivers/gpu/drm/solomon/ssd130x.c
index 46e2c277a9bf..ec6bf9f6c7c8 100644
--- a/drivers/gpu/drm/solomon/ssd130x.c
+++ b/drivers/gpu/drm/solomon/ssd130x.c
@@ -451,39 +451,25 @@ static int ssd130x_init(struct ssd130x_device *ssd130x)
bool scan_mode;
int ret;
- /* Set initial contrast */
- ret = ssd130x_write_cmd(ssd130x, 2, SSD13XX_CONTRAST, ssd130x->contrast);
- if (ret < 0)
- return ret;
-
- /* Set segment re-map */
seg_remap = (SSD13XX_SET_SEG_REMAP |
- SSD13XX_SET_SEG_REMAP_SET(ssd130x->seg_remap));
- ret = ssd130x_write_cmd(ssd130x, 1, seg_remap);
- if (ret < 0)
- return ret;
-
- /* Set COM direction */
+ SSD13XX_SET_SEG_REMAP_SET(ssd130x->seg_remap));
com_invdir = (SSD130X_SET_COM_SCAN_DIR |
- SSD130X_SET_COM_SCAN_DIR_SET(ssd130x->com_invdir));
- ret = ssd130x_write_cmd(ssd130x, 1, com_invdir);
- if (ret < 0)
- return ret;
-
- /* Set multiplex ratio value */
- ret = ssd130x_write_cmd(ssd130x, 2, SSD13XX_SET_MULTIPLEX_RATIO, ssd130x->height - 1);
- if (ret < 0)
- return ret;
-
- /* set display offset value */
- ret = ssd130x_write_cmd(ssd130x, 2, SSD130X_SET_DISPLAY_OFFSET, ssd130x->com_offset);
- if (ret < 0)
- return ret;
-
- /* Set clock frequency */
+ SSD130X_SET_COM_SCAN_DIR_SET(ssd130x->com_invdir));
dclk = (SSD130X_SET_CLOCK_DIV_SET(ssd130x->dclk_div - 1) |
SSD130X_SET_CLOCK_FREQ_SET(ssd130x->dclk_frq));
- ret = ssd130x_write_cmd(ssd130x, 2, SSD130X_SET_CLOCK_FREQ, dclk);
+
+ const u8 *cmds = (const u8[]) {
+ 2, SSD13XX_CONTRAST, ssd130x->contrast,
+ /* Set segment re-map */
+ 1, seg_remap,
+ /* Set COM scan direction */
+ 1, com_invdir,
+ 2, SSD13XX_SET_MULTIPLEX_RATIO, ssd130x->height - 1,
+ 2, SSD130X_SET_DISPLAY_OFFSET, ssd130x->com_offset,
+ 2, SSD130X_SET_CLOCK_FREQ, dclk,
+ 0,
+ };
+ ret = ssd130x_run_cmd_seq(ssd130x, cmds);
if (ret < 0)
return ret;
@@ -505,36 +491,30 @@ static int ssd130x_init(struct ssd130x_device *ssd130x)
/* Set precharge period in number of ticks from the internal clock */
precharge = (SSD130X_SET_PRECHARGE_PERIOD1_SET(ssd130x->prechargep1) |
SSD130X_SET_PRECHARGE_PERIOD2_SET(ssd130x->prechargep2));
- ret = ssd130x_write_cmd(ssd130x, 2, SSD130X_SET_PRECHARGE_PERIOD, precharge);
- if (ret < 0)
- return ret;
- /* Set COM pins configuration */
- compins = BIT(1);
- /*
+ /* Set COM pins configuration
+ *
* The COM scan mode field values are the inverse of the boolean DT
* property "solomon,com-seq". The value 0b means scan from COM0 to
* COM[N - 1] while 1b means scan from COM[N - 1] to COM0.
*/
scan_mode = !ssd130x->com_seq;
- compins |= (SSD130X_SET_COM_PINS_CONFIG1_SET(scan_mode) |
+ compins = BIT(1) | (SSD130X_SET_COM_PINS_CONFIG1_SET(scan_mode) |
SSD130X_SET_COM_PINS_CONFIG2_SET(ssd130x->com_lrremap));
- ret = ssd130x_write_cmd(ssd130x, 2, SSD130X_SET_COM_PINS_CONFIG, compins);
- if (ret < 0)
- return ret;
-
- /* Set VCOMH */
- ret = ssd130x_write_cmd(ssd130x, 2, SSD130X_SET_VCOMH, ssd130x->vcomh);
- if (ret < 0)
- return ret;
/* Turn on the DC-DC Charge Pump */
chargepump = BIT(4);
-
if (ssd130x->device_info->need_chargepump)
chargepump |= BIT(2);
- ret = ssd130x_write_cmd(ssd130x, 2, SSD130X_CHARGE_PUMP, chargepump);
+ cmds = (const u8[]) {
+ 2, SSD130X_SET_PRECHARGE_PERIOD, precharge,
+ 2, SSD130X_SET_COM_PINS_CONFIG, compins,
+ 2, SSD130X_SET_VCOMH, ssd130x->vcomh,
+ 2, SSD130X_CHARGE_PUMP, chargepump,
+ 0
+ };
+ ret = ssd130x_run_cmd_seq(ssd130x, cmds);
if (ret < 0)
return ret;
--
2.53.0