SSD1351 register problem

This site uses cookies. By continuing to browse this site, you are agreeing to our Cookie Policy.

  • SSD1351 register problem

    I'm working with STEmWin V5.28 with an SSD1351 Oled display. 8 bit parallel interface.
    I've configured the Flex driver like this (removed some irrelevant code lines)

    C Source Code

    1. pDevice = GUI_DEVICE_CreateAndLink(GUIDRV_FLEXCOLOR, GUICC_565, 0, 0);
    2. Config.Orientation = 0;
    3. GUIDRV_FlexColor_Config(pDevice, &Config);
    4. GUIDRV_FlexColor_SetFunc(pDevice, &PortAPI, GUIDRV_FLEXCOLOR_F66722, GUIDRV_FLEXCOLOR_M16C0B8);



    On Init the driver writes to the register 0xA0 a value of 0x00, which is the wrong value.

    Referring here:
    hpinfotech.ro/SSD1351.pdf


    Register 0xA0 bits 7:6 set the colour depth. 00b is 256 colour, despite the driver being set for 565. The correct value is 01b for 65K colour.
    Also for my display bit 5 needs to be set (enable COMsplit odd even) and bit 4 to be set (scan from COM[N-1} to COM0.)
    So my display works with a value of 0x70.

    I've hacked my code to intercept that register write and change the value, but is there something with my configuration that is causing this?
    Thanks.
  • Hi,

    You wrote: "Register 0xA0 bits 7:6 set the colour depth. 00b is 256 colour"

    Please note that this is not right:
    [img][/img]

    Bit 5 can be set using the configuration structure. Here is a sample:

    C Source Code

    1. void LCD_X_Config(void) {
    2. GUI_DEVICE * pDevice;
    3. GUI_PORT_API PortAPI = {0};
    4. CONFIG_FLEXCOLOR Config = {0};
    5. pDevice = GUI_DEVICE_CreateAndLink(DISPLAY_DRIVER, COLOR_CONVERSION, 0, 0);
    6. LCD_SetSizeEx (0, XSIZE_PHYS, YSIZE_PHYS);
    7. LCD_SetVSizeEx(0, VXSIZE_PHYS, VYSIZE_PHYS);
    8. PortAPI.pfWrite8_A0 = LCD_X_6800_8_Write00;
    9. PortAPI.pfWrite8_A1 = LCD_X_6800_8_Write01;
    10. PortAPI.pfWriteM8_A1 = LCD_X_6800_8_WriteM01;
    11. PortAPI.pfReadM8_A1 = LCD_X_6800_8_ReadM01;
    12. GUIDRV_FlexColor_SetFunc(pDevice, &PortAPI, GUIDRV_FLEXCOLOR_F66722, GUIDRV_FLEXCOLOR_M16C0B8);
    13. Config.RegEntryMode = 0x20; // Enable COM Split Odd Even
    14. GUIDRV_FlexColor_Config(pDevice, &Config);
    15. }
    Display All


    Regards, Jörg
    Please read the forum rules before posting.

    Keep in mind, this is *not* a support forum.
    Our engineers will try to answer your questions between their projects if possible but this can be delayed by longer periods of time.
    Should you be entitled to support you can contact us via our support system: segger.com/ticket/

    Or you can contact us via e-mail.
  • Thank you for the reply.

    Which data sheet did you get those register details from?

    The one I linked (page 32), and my display, say this:

    A[7:6] Set Color Depth,
    00b 256 color
    01b 65K color, [reset]
    10b 262k color, 8/18-bit,16 bit (1st option) MCU interface
    11b 262k color, 16 - bit MCU interface