qp_gc9107_opcodes.h (7054B)
- // Copyright 2024 Fernando Birra
- // SPDX-License-Identifier: GPL-2.0-or-later
- #pragma once
- ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
- // Quantum Painter GC9107 command opcodes
- ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
- #define GC9107_GET_POWER_MODE 0x0A // Get power mode
- #define GC9107_GET_MADCTL 0x0B // Get MADCTL
- #define GC9107_GET_PIXEL_FMT 0x0C // Get pixel format
- #define GC9107_GET_IMAGE_FMT 0x0D // Get image format
- #define GC9107_GET_SIGNAL_MODE 0x0E // Get signal mode
- #define GC9107_GET_DIAG_RESULT 0x0F // Get self-diagnostic results
- #define GC9107_SET_FRAME_RATE 0xA8 // Set frame rate
- #define GC9107_SET_COMPLEMENT_RGB 0xAC // Set complement Principle RGB
- #define GC9107_SET_BLANK_PORCH 0xAD // Set blank porch control, 0;front_porch[6:0],0;back_porch[6:0]
- #define GC9107_SET_FUNCTION_CTL1 0xB1 // Set access to AVDD_VCL_CLK and VGH_VGL_CLK commands
- #define GC9107_SET_FUNCTION_CTL2 0xB2 // Set access to VGH, VGH control commands
- #define GC9107_SET_FUNCTION_CTL3 0xB3 // Set access to Gamma control commands
- #define GC9107_SET_DISPLAY_INVERSION 0xB4 // Set Display Inversion control
- #define GC9107_SET_FUNCTION_CTL6 0xB6 // Set access to commands SET_FRAME_RATE, SET_COMPLEMENT_RGB and SET_BLANK_PORCH
- #define GC9107_SET_CUSTOM_ID_INFO 0xD3 // Set customized display id information
- #define GC9107_AVDD_VCL_CLK 0xE3 // AVDD_CLK
- #define GC9107_SET_VGH 0xE8 // Set VGH
- #define GC9107_SET_VGL 0xE9 // Set VGL
- #define GC9107_SET_VGH_VGL_CLK 0xEA // Set VGH and VGL clock divisors
- ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
- // GC9107 Parameter constants
- // Parameter values for
- // GC9107_SET_PIXEL_FORMAT
- #define GC9107_PIXEL_FORMAT_12_BPP_IFPF (0b001 << 0) // 12 bits per pixel
- #define GC9107_PIXEL_FORMAT_16_BPP_IFPF (0b101 << 0) // 16 bits per pixel
- #define GC9107_PIXEL_FORMAT_18_BPP_IFPB (0b110 << 0) // 18 bits per pixel
- // Parameter values for
- // GC9107_SET_COMPLEMENT_RGB
- #define GC9107_COMPLEMENT_WITH_0 0x00 // R0 <- B0 <- 0, except if data is FFh
- #define GC9107_COMPLEMENT_WITH_1 0x40 // R0 <- B0 <- 1, except if data is 00h
- #define GC9107_COMPLEMENT_WITH_MSB 0x80 // R0 <- R5, B0 <- B5
- #define GC9107_COMPLEMENT_WITH_LSB 0xC0 // R0 <- B0 <- G0
- // Parameter masks for
- // GC9107_SET_FUNCTION_CTL1
- #define GC9107_ALLOW_AVDD_VCL_CLK 0b00001000 // Allow AVDD_VCL_CLK command
- // Parameter masks for
- // GC9107_SET_FUNCTION_CTL2
- #define GC9107_ALLOW_SET_VGH 0b00000001 // Allow GC9107_SET_VGH
- #define GC9107_ALLOW_SET_VGL 0b00000010 // Allow GC9107_SET_VGL
- #define GC9107_ALLOW_SET_VGH_VGL_CLK 0b00000100 // Allow GC9107_SET_VGH_VGL_CLK
- // Parameter masks for
- // GC9107_SET_FUNCTION_CTL3
- #define GC9107_ALLOW_SET_GAMMA1 0b00000001 // Allow GC9107_SET_GAMMA1
- #define GC9107_ALLOW_SET_GAMMA2 0b00000010 // Allow GC9107_SET_GAMMA2
- // Parameter mask for
- // GC9107_SET_FUNCTION_CTL6
- #define GC9107_ALLOW_SET_FRAMERATE 0b000000001 // Allow GC9107_SET_FRAME_RATE
- #define GC9107_ALLOW_SET_COMPLEMENT_RGB 0b000010000 // Allow GC9107_SET_COMPLEMENT_RGB
- #define GC9107_ALLOW_SET_BLANK_PORCH 0b000100000 // Allow GFC9107_SET_BLANK_PORCH
- // Parameter values for
- // AVDD_CLK_AD part (Most significant nibble)
- #define GC9107_AVDD_CLK_AD_2T 0x00
- #define GC9107_AVDD_CLK_AD_3T 0x10
- #define GC9107_AVDD_CLK_AD_4T 0x20
- #define GC9107_AVDD_CLK_AD_5T 0x30
- #define GC9107_AVDD_CLK_AD_6T 0x40
- #define GC9107_AVDD_CLK_AD_7T 0x50
- #define GC9107_AVDD_CLK_AD_8T 0x60
- #define GC9107_AVDD_CLK_AD_9T 0x70
- // Parameter values for
- // VCL_CLK_AD part (Least significant nibble)
- #define GC9107_VCL_CLK_AD_2T 0x00
- #define GC9107_VCL_CLK_AD_3T 0x01
- #define GC9107_VCL_CLK_AD_4T 0x02
- #define GC9107_VCL_CLK_AD_5T 0x03
- #define GC9107_VCL_CLK_AD_6T 0x04
- #define GC9107_VCL_CLK_AD_7T 0x05
- #define GC9107_VCL_CLK_AD_8T 0x06
- #define GC9107_VCL_CLK_AD_9T 0x07
- // Parameter values for
- // GC9107_SET_VGH
- #define GC9107_VGH_P100 0x20 // +10 V
- #define GC9107_VGH_P110 0x21 // +11 V
- #define GC9107_VGH_P120 0x22 // +12 V
- #define GC9107_VGH_P130 0x23 // +13 V
- #define GC9107_VGH_P140 0x24 // +14 V
- #define GC9107_VGH_P150 0x25 // +15 V
- // Parameter values for
- // GC9107_SET_VGL
- #define VGL_N_075 0x40 // -7.5 V
- #define VGL_N_085 0x41 // -8.5 V
- #define VGL_N_095 0x42 // -9.5 V
- #define VGL_N_100 0x43 // -10.0 V
- #define VGL_N_105 0x44 // -10.5 V
- #define VGL_N_110 0x45 // -11.0 V
- #define VGL_N_120 0x46 // -12.0 V
- #define VGL_N_130 0x47 // -13.0 V
- // Parameter masks for
- // GC9107_SET_VGH_VGL_CLK (VGH Divisor)
- #define GC9107_VGH_CLK_DIV_2 0x00 // Clock divisor = 2 -> 6.0 Mhz
- #define GC9107_VGH_CLK_DIV_3 0x10 // Clock divisor = 3 -> 4.0 Mhz
- #define GC9107_VGH_CLK_DIV_4 0x20 // Clock divisor = 4 -> 3.0 Mhz
- #define GC9107_VGH_CLK_DIV_5 0x30 // Clock divisor = 5 -> 2.4 Mhz
- #define GC9107_VGH_CLK_DIV_6 0x40 // Clock divisor = 6 -> 2.0 Mhz
- #define GC9107_VGH_CLK_DIV_7 0x50 // Clock divisor = 7 -> 1.7 Mhz
- #define GC9107_VGH_CLK_DIV_8 0x60 // Clock divisor = 8 -> 1.5 Mhz
- #define GC9107_VGH_CLK_DIV_9 0x70 // Clock divisor = 9 -> 1.3 Mhz
- #define GC9107_VGH_CLK_DIV_10 0x80 // Clock divisor = 10 -> 1.2 Mhz
- #define GC9107_VGH_CLK_DIV_12 0x90 // Clock divisor = 12 -> 1.0 Mhz
- #define GC9107_VGH_CLK_DIV_15 0xA0 // Clock divisor = 15 -> 0.8 Mhz
- #define GC9107_VGH_CLK_DIV_20 0xB0 // Clock divisor = 20 -> 0.6 Mhz
- #define GC9107_VGH_CLK_DIV_24 0xC0 // Clock divisor = 24 -> 0.5 Mhz
- #define GC9107_VGH_CLK_DIV_30 0xD0 // Clock divisor = 30 -> 0.4 Mhz
- #define GC9107_VGH_CLK_DIV_40 0xE0 // Clock divisor = 40 -> 0.3 Mhz
- #define GC9107_VGH_CLK_DIV_60 0xE0 // Clock divisor = 40 -> 0.2 Mhz
- // Parameter masks for
- // GC9107_SET_VGH_VGL_CLK (VGL Divisor)
- #define GC9107_VGL_CLK_DIV_2 0x00 // Clock divisor = 2 -> 6.0 Mhz
- #define GC9107_VGL_CLK_DIV_3 0x01 // Clock divisor = 3 -> 4.0 Mhz
- #define GC9107_VGL_CLK_DIV_4 0x02 // Clock divisor = 4 -> 3.0 Mhz
- #define GC9107_VGL_CLK_DIV_5 0x03 // Clock divisor = 5 -> 2.4 Mhz
- #define GC9107_VGL_CLK_DIV_6 0x04 // Clock divisor = 6 -> 2.0 Mhz
- #define GC9107_VGL_CLK_DIV_7 0x05 // Clock divisor = 7 -> 1.7 Mhz
- #define GC9107_VGL_CLK_DIV_8 0x06 // Clock divisor = 8 -> 1.5 Mhz
- #define GC9107_VGL_CLK_DIV_9 0x07 // Clock divisor = 9 -> 1.3 Mhz
- #define GC9107_VGL_CLK_DIV_10 0x08 // Clock divisor = 10 -> 1.2 Mhz
- #define GC9107_VGL_CLK_DIV_12 0x09 // Clock divisor = 12 -> 1.0 Mhz
- #define GC9107_VGL_CLK_DIV_15 0x0A // Clock divisor = 15 -> 0.8 Mhz
- #define GC9107_VGL_CLK_DIV_20 0x0B // Clock divisor = 20 -> 0.6 Mhz
- #define GC9107_VGL_CLK_DIV_24 0x0C // Clock divisor = 24 -> 0.5 Mhz
- #define GC9107_VGL_CLK_DIV_30 0x0D // Clock divisor = 30 -> 0.4 Mhz
- #define GC9107_VGL_CLK_DIV_40 0x0E // Clock divisor = 40 -> 0.3 Mhz
- #define GC9107_VGL_CLK_DIV_60 0x0E // Clock divisor = 40 -> 0.2 Mhz