# tc358870xbg parameter main.h 檔須修改的參數 面板解析度 以196 x 196為例子 STX0_FPX 0 暫存器 0X500C STX0_LPX 195 暫存器0x500E 還有 DRIVER IC 2A 2B 30 31 的參數 ```c= #ifndef __MAIN_H #define __MAIN_H #include <stdio.h> #define TC358778XBG 0x0f //i2c slave address //User modify start //Split Control Reg DSI_TX0 #define STX0_FPX 0 //start pixel #define STX0_LPX 195 //End pixel //RM6D020 #define _2A2B3031 #define _2A 0x001800DB #define _2B 0x000000C3 #define _31 0x001800DB #define _30 0x000000C3 //User modify end #define STX0_WC_H (STX0_WC >> 8) & 0xFF #define STX0_WC_L STX0_WC & 0xFF #define STX0_FPX_H (STX0_FPX >> 8) & 0xFF #define STX0_FPX_L STX0_FPX & 0xFF #define STX0_LPX_H (STX0_LPX >> 8) & 0xFF #define STX0_LPX_L STX0_LPX & 0xFF #define _2A00 (_2A >> 24) & 0xFF #define _2A01 (_2A >> 16) & 0xFF #define _2A02 (_2A >> 8) & 0xFF #define _2A03 _2A & 0xFF #define _2B00 (_2B >> 24) & 0xFF #define _2B01 (_2B >> 16) & 0xFF #define _2B02 (_2B >> 8) & 0xFF #define _2B03 _2B & 0xFF #define _3100 (_31 >> 24) & 0xFF #define _3101 (_31 >> 16) & 0xFF #define _3102 (_31 >> 8) & 0xFF #define _3103 _31 & 0xFF #define _3000 (_30 >> 24) & 0xFF #define _3001 (_30 >> 16) & 0xFF #define _3002 (_30 >> 8) & 0xFF #define _3003 _30 & 0xFF #endif ``` </br> </br> </br> tc358870xbg 暫存器設定 ex : {6, 0x01, 0x08, 0x01, 0x02, 0x03, 0x04} 看Datasheet 0x0108 設定 6 表示後面一次丟6 bytes 資料 依序丟出 : 0x01, 0x08, 0x01, 0x02, 0x03, 0x04 0x01, 0x08 : 0x01 表示暫存器的MSB 0x08 表示暫存器的LSB 0x01, 0x02, 0x03, 0x04 : 0x01 -> 0x04 表示data的 LSB -> MSB 以下tc358870xbg 依序執行陣列中參數 tc358[][7] -> RM6D020[][7] -> split_dsi_tx_reg[][7] ```c= static const uint8_t tc358[][7] = { //Soft Reset {4, 0x00, 0x04, 0x04, 0x00},//Confctl0 {4, 0x00, 0x02, 0x01, 0x3F},//SystemCtl Reset 操作 {0xFE, 0x12}, //delay 1500 us ,usleep( ) {4, 0X00, 0X02, 0x00, 0x00},//SystemCtl {0xFE, 0x03}, //delay 300 us {4, 0x00, 0x06, 0x08, 0x00},//系統用Relclk 做clk來源 {0xFE, 0x06}, //delay 600 us //0x84 0x85 HDMI Rx System Ctrl //0x86 HDMI Rx Audio Ctrl // HDMI PHY {3, 0x84, 0x10, 0x03}, // PHY CTL {3, 0x84, 0x13, 0x3F}, // PHY_ENB {3, 0x84, 0xF0, 0x31}, //APLL_CTL {3, 0x84, 0xF4, 0x01}, // DDCIO_CTL // HDMI Clock {4, 0x85, 0x40, 0xC0, 0x12}, // SYS_FREQ0_1 crystal 48MHz //{3, 0x86, 0x30, 0x00}, // LOCKDET_FREQ0 //{4, 0x86, 0X31, 0x53, 0x07}, // LOCKDET_REF1_2 //{3, 0x86, 0x70, 0x02}, // NCO_F0_MOD {4, 0x8A, 0x0C, 0xC0, 0x12}, // CSC_SCLK0_1 // HDMI Interrupt Mask, Clear {3, 0x85, 0x02, 0xFF},// SYS_INT {3, 0x85, 0x12, 0xFE},// SYS_INTM // Interrupt Control (TOP level) {4, 0X00, 0X14, 0xBF, 0x0F},//InitStatus {4, 0x00, 0x16, 0xFF, 0x0F},//IntMask //EDID {3, 0x85, 0xE0, 0x01}, //EDID MODE {4, 0x85, 0xE3, 0x00, 0x01},//EDID_LEN1 //Video Ouput Format Setting //{3, 0x8A, 0x00, 0x00},//VOUT_FMT //{3, 0x8A, 0x01, 0x14},//VOUT_FIL {3, 0x8A, 0x02, 0x42},//VOUT_SYNC0 0x42 default //{3, 0x8A, 0x08, 0x11},//VOUT_CSC // HDMI SYSTEM {3, 0x85, 0x43, 0x02},// DDC_CTL {3, 0x85, 0x44, 0x11},// HPD_CTL //HDMI Source start access {3, 0x85, 0x4A, 0x01},// INIT_END {4, 0x00, 0x02, 0x00, 0x00}, {4, 0x00, 0x06, 0x08, 0x00}, {0xFE, 0x01}, //delay 100 us ,usleep( ) //DSI_TX0 {6, 0x01, 0x08, 0x01, 0x00, 0x00, 0x00},//DSI_TX_CLKEN {6, 0x01, 0x0C, 0x01, 0x00, 0x00, 0x00},//DSI_TX_CLKSEL {6, 0x02, 0xA0, 0x01, 0x00, 0x00, 0x00},//MIPI_PLL_CTRL {6, 0x02, 0xAC, 0xAF, 0x94, 0x00, 0x00},//!!!MIPI_PLL_CONF 250MHz ~ 500MHz, input division ratio = 10, feedback division = 176 {0xFE, 0x14}, //delay 2 ms ,usleep( ) {6, 0x02, 0xA0, 0x03, 0x00, 0x00, 0x00},//MIPI_PLL_CTRL {6, 0x01, 0x18, 0x11, 0x00, 0x00, 0x00},//LANE_EANBLE {6, 0x01, 0x20, 0x63, 0x0B, 0x00, 0x00},//!!!LINE_INIT_CNT = 2915 {6, 0x01, 0x24, 0x00, 0x00, 0x00, 0x00},//!!!HSTX_TO_COUNT = 0 {6, 0x01, 0x28, 0x01, 0x01, 0x00, 0x00},//FUNC_ENABLE {6, 0x01, 0x30, 0x00, 0x00, 0x01, 0x00},//datasheet no DSI_TATO_COUNT {6, 0x01, 0x34, 0x00, 0x50, 0x00, 0x00},//datasheet no DSI_PRESP_BTA_COUNT {6, 0x01, 0x38, 0x00, 0x00, 0x01, 0x00},//datasheet no DSI_PRESP_LPR_COUNT {6, 0x01, 0x3C, 0x00, 0x00, 0x01, 0x00},//DSI_PRESP_LPW_COUNT {6, 0x01, 0x40, 0x00, 0x00, 0x01, 0x00},//no DSI_PRESP_HSR_COUNT {6, 0x01, 0x44, 0x00, 0x00, 0x01, 0x00},//DSI_PRESP_HSW_COUNT {6, 0x01, 0x48, 0x00, 0x10, 0x00, 0x00},//datasheet no DSI_PR_TO_COUNT {6, 0x01, 0x4C, 0x00, 0x00, 0x01, 0x00},//datasheet no DSI_LRX-H_TO_COUNT {6, 0x01, 0x50, 0x60, 0x01, 0x00, 0x00},//FUNC_MODE {6, 0x01, 0x54, 0x01, 0x00, 0x00, 0x00},//DSIRX_VC_ENABLE ,RXVC0_EN Virtual Channel-0 supported in LPRX path {6, 0x01, 0x58, 0xC8, 0x00, 0x00, 0x00},//IND_TO_COUNT = 200 {6, 0x01, 0x68, 0x2A, 0x00, 0x00, 0x00},//datasheet no DSI_HSYNC_STOP_COUNT = 42 {6, 0x01, 0x70, 0x9D, 0x06, 0x00, 0x00},//APF_VDELAYCNT = 1693 {6, 0x01, 0x7C, 0x81, 0x00, 0x00, 0x00},//DSI_TX_MODE {6, 0x01, 0x8C, 0x22, 0x00, 0x00, 0x00},//!!!DSI_HSYNC_WIDTH = 34 {6, 0x01, 0x90, 0xBA, 0x02, 0x00, 0x00},//!!!DSI_HBPR = 698 {6, 0x01, 0xA4, 0x00, 0x00, 0x00, 0x00},//DSI_RX_STATE_INT_MASK all no mask {6, 0x01, 0xC0, 0x15, 0x00, 0x00, 0x00},//DSI_LPRX_THRESH_COUNT = 21 {6, 0x02, 0x14, 0x00, 0x00, 0x00, 0x00},//APP_SIDE_ERR_INT_MASK all no mask {6, 0x02, 0x1C, 0x80, 0x00, 0x00, 0x00},//DSI_RX_ERR_INT_MASK {6, 0x02, 0x24, 0x00, 0x00, 0x00, 0x00},//DSI_LPTX_INT_MASK {0xFE, 0x01}, //delay 100 us ,usleep( ) {6, 0x02, 0x54, 0x02, 0x00, 0x00, 0x00},//!!!LPTXTIMECNT = 2 {6, 0x02, 0x58, 0x02, 0x02, 0x13, 0x00},//!!!PPI_DPHY_TCLK_HEADERCNT TCLK_PrepareCnt = 2, TCLK-PreCnt = 2, TCLK_PREEZEROCNT = 19 {6, 0x02, 0x5C, 0x06, 0x00, 0x06, 0x00},//!!!PPI_DPHY_TCLK_TRAILCNT TCLK_TrailCnt = 6, TCLK_ExitCnt = 6 {6, 0x02, 0x60, 0x04, 0x00, 0x0A, 0x00},//!!!PPI_DPHY_THS_HEADERCNT THS_PrepareCnt = 4, THS_PREZEROCNT = 10 {6, 0x02, 0x64, 0xEA, 0x4B, 0x00, 0x00},//!!!PPI_DPHY_TWAKEUPCNT = 19434 {6, 0x02, 0x68, 0x0A, 0x00, 0x00, 0x00},//!!!PPI_DPHY_TCLK_POSTCNT = 10 {6, 0x02, 0x6C, 0x05, 0x00, 0x06, 0x00},//!!!PPI_DPHY_THSTRAILCNT THS_TrailCnt = 5, THS_ExitCnt = 6 {6, 0x02, 0x70, 0x20, 0x00, 0x00, 0x00},//!!!PPI_DPHY_HSTXVREGCNT = 32 {6, 0x02, 0x74, 0x03, 0x00, 0x00, 0x00},//PPI_DPHY_HSTXVREGEN HSTX CLK Enable, HSTX Data Lane Enable {6, 0x02, 0x78, 0x02, 0x00, 0x02, 0x00},//PPI_DSI_BTA_COUNT RXTASURECNT = 2, TXTAGOCNT = 2 {6, 0x02, 0x7C, 0x02, 0x00, 0x00, 0x00},//PPI_DPHYTX_ADJUST {6, 0x02, 0x88, 0xAA, 0x02, 0x00, 0x00},//PPI_DPHY_CAP {6, 0x01, 0x1C, 0x01, 0x00, 0x00, 0x00},//DSITX_START {0xFE, 0x0D}, //delay 1.3 ms ,usleep( ) {0xFF, 0x00, 0x00} //end mark }; ``` ```c= static const uint8_t RM6D020[][7] = { {4, 0x05, 0x04, 0x15, 0x80}, {4, 0x05, 0x04, 0xFE, 0x80},//page 0 #ifdef _2A2B3031 //2A Generic Long Write Packet with 5 bytes data 0x2A, NULL, 0x00, 0x0A, 0x01, 0xCF {4, 0x05, 0x04, 0x29, 0x80}, {4, 0x05, 0x04, 0x05, 0x00}, {4, 0x05, 0x04, 0x2A, _2A00}, {4, 0x05, 0x04, _2A01, _2A02}, {4, 0x05, 0x04, _2A03, 0x00}, //2B Generic Long Write Packet with 5 bytes data 0x2B, NULL, 0x00, 0x00, 0x01, 0xC5 {4, 0x05, 0x04, 0x29, 0x80}, {4, 0x05, 0x04, 0x05, 0x00}, {4, 0x05, 0x04, 0x2B, _2B00}, {4, 0x05, 0x04, _2B01, _2B02}, {4, 0x05, 0x04, _2B03, 0x00}, //31 Generic Long Write Packet with 5 bytes data 0x31, NULL, 0x00, 0x0A, 0x01, 0xCF {4, 0x05, 0x04, 0x29, 0x80}, {4, 0x05, 0x04, 0x05, 0x00}, {4, 0x05, 0x04, 0x31, _3100}, {4, 0x05, 0x04, _3101, _3102}, {4, 0x05, 0x04, _3103, 0x00}, //30 Generic Long Write Packet with 5 bytes data 0x30, NULL, 0x00, 0x00, 0x01, 0xC5 {4, 0x05, 0x04, 0x29, 0x80}, {4, 0x05, 0x04, 0x05, 0x00}, {4, 0x05, 0x04, 0x30, _3000}, {4, 0x05, 0x04, _3001, _3002}, {4, 0x05, 0x04, _3003, 0x00}, #endif {4, 0x05, 0x04, 0x05, 0x00}, {4, 0x05, 0x04, 0x12, 0x00},//partial mode on {4, 0x05, 0x04, 0x15, 0x00}, {4, 0x05, 0x04, 0x35, 0x00},//TE {4, 0x05, 0x04, 0x15, 0x00}, {4, 0x05, 0x04, 0x53, 0x20},//BC dimming off {4, 0x05, 0x04, 0x15, 0x00}, {4, 0x05, 0x04, 0x51, 0xFF},//set britness {4, 0x05, 0x04, 0x15, 0x00}, {4, 0x05, 0x04, 0x63, 0xFF},//HBM BCFF {4, 0x05, 0x04, 0x05, 0x00}, {4, 0x05, 0x04, 0x29, 0x00}, //display on {0xFE, 0x02}, //delay 200 us ,usleep( ) }; ``` ```c= static const uint8_t split_dsi_tx_reg[][7] = { //DSI SETTING //TX0 {4, 0x50, 0x00, 0x00, 0x00},//STX0_CTRL {4, 0x50, 0x08, STX0_WC_L, STX0_WC_H},//STX0_WC 1362 subpixel per line 這不影響可以不要 {4, 0x50, 0x0C, STX0_FPX_L, STX0_FPX_H},//STX0_FPX Output Start Pixel {4, 0x50, 0x0E, STX0_LPX_L, STX0_LPX_H},//STX0_LPX Output End Pixel // {4, 0x00, 0x04, 0x37, 0x0C},//OK {4, 0x00, 0x06, 0x00, 0x00},//OK {6, 0x01, 0x10, 0x06, 0x00, 0x00, 0x00},//OK //{6, 0x03, 0x10, 0x06, 0x00, 0x00, 0x00},//OK {0xFF, 0x00, 0x00} //end mark }; ```