return val;             \
        } while (0)
 
+#define ST7789V_IDS { 0x85, 0x85, 0x52 }
+#define ST7789V_IDS_SIZE 3
+
 struct st7789_panel_info {
        const struct drm_display_mode *mode;
        u32 bus_format;
        return st7789v_spi_write(ctx, ST7789V_DATA, cmd);
 }
 
+static int st7789v_read_data(struct st7789v *ctx, u8 cmd, u8 *buf,
+                            unsigned int len)
+{
+       struct spi_transfer xfer[2] = { };
+       struct spi_message msg;
+       u16 txbuf = ((ST7789V_COMMAND & 1) << 8) | cmd;
+       u16 rxbuf[4] = {};
+       u8 bit9 = 0;
+       int ret, i;
+
+       switch (len) {
+       case 1:
+       case 3:
+       case 4:
+               break;
+       default:
+               return -EOPNOTSUPP;
+       }
+
+       spi_message_init(&msg);
+
+       xfer[0].tx_buf = &txbuf;
+       xfer[0].len = sizeof(txbuf);
+       spi_message_add_tail(&xfer[0], &msg);
+
+       xfer[1].rx_buf = rxbuf;
+       xfer[1].len = len * 2;
+       spi_message_add_tail(&xfer[1], &msg);
+
+       ret = spi_sync(ctx->spi, &msg);
+       if (ret)
+               return ret;
+
+       for (i = 0; i < len; i++) {
+               buf[i] = rxbuf[i] >> i | (bit9 << (9 - i));
+               if (i)
+                       bit9 = rxbuf[i] & GENMASK(i - 1, 0);
+       }
+
+       return 0;
+}
+
+static int st7789v_check_id(struct drm_panel *panel)
+{
+       const u8 st7789v_ids[ST7789V_IDS_SIZE] = ST7789V_IDS;
+       struct st7789v *ctx = panel_to_st7789v(panel);
+       bool invalid_ids = false;
+       int ret, i;
+       u8 ids[3];
+
+       if (ctx->spi->mode & SPI_NO_RX)
+               return 0;
+
+       ret = st7789v_read_data(ctx, MIPI_DCS_GET_DISPLAY_ID, ids, ST7789V_IDS_SIZE);
+       if (ret)
+               return ret;
+
+       for (i = 0; i < ST7789V_IDS_SIZE; i++) {
+               if (ids[i] != st7789v_ids[i]) {
+                       invalid_ids = true;
+                       break;
+               }
+       }
+
+       if (invalid_ids)
+               return -EIO;
+
+       return 0;
+}
+
 static const struct drm_display_mode default_mode = {
        .clock = 7000,
        .hdisplay = 240,
        gpiod_set_value(ctx->reset, 0);
        msleep(120);
 
+       /*
+        * Avoid failing if the IDs are invalid in case the Rx bus width
+        * description is missing.
+        */
+       ret = st7789v_check_id(panel);
+       if (ret)
+               dev_warn(panel->dev, "Unrecognized panel IDs");
+
        ST7789V_TEST(ret, st7789v_write_command(ctx, MIPI_DCS_EXIT_SLEEP_MODE));
 
        /* We need to wait 120ms after a sleep out command */