| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056 |
- #define LOG_TAG "ddp_path"
- #include "ddp_log.h"
- #include <linux/types.h>
- #ifdef CONFIG_MTK_CLKMGR
- #include <mach/mt_clkmgr.h>
- #endif
- #define DISP_LIST_SCENARIO
- #include "ddp_reg.h"
- #include "disp_drv_platform.h"
- #include "ddp_debug.h"
- #include "ddp_path.h"
- #include "primary_display.h"
- #include "ddp_hal.h"
- #include "m4u.h"
- #include "ddp_drv.h"
- #pragma GCC optimize("O0")
- /* 1st para is mout's input, 2nd para is mout's output*/
- mout_t mout_map[DDP_MOUT_NUM] = {
- /* OVL_MOUT */
- {DISP_MODULE_OVL0,
- {{DISP_MODULE_COLOR0, 1 << 0}, {DISP_MODULE_WDMA0, 1 << 1}, {-1, 0} }, 0, 0},
- {DISP_MODULE_OVL1,
- {{DISP_MODULE_RDMA1, 1 << 0}, {DISP_MODULE_WDMA1, 1 << 1}, {DISP_MODULE_OVL0, 1 << 2},
- {-1, 0} }, 0, 0},
- /* DITHER0_MOUT */
- {DISP_MODULE_DITHER,
- {{DISP_MODULE_RDMA0, 1 << 0}, {DISP_MODULE_UFOE, 1 << 1}, {DISP_MODULE_WDMA0, 1 << 2},
- {-1, 0} }, 0, 0},
- /* UFOE_MOUT */
- {DISP_MODULE_UFOE,
- {{DISP_MODULE_DSI0, 1 << 0}, {DISP_MODULE_DPI, 1 << 1}, {DISP_MODULE_WDMA0, 1 << 2},
- {-1, 0} }, 0, 0},
- };
- sel_t sel_out_map[DDP_SEL_OUT_NUM] = {
- /* RDMA_SOUT */
- {DISP_MODULE_RDMA0,
- {DISP_MODULE_UFOE, DISP_MODULE_COLOR0, DISP_MODULE_DSI0, DISP_MODULE_DPI, -1}, 0, 0},
- {DISP_MODULE_RDMA1,
- {DISP_MODULE_DSI0, DISP_MODULE_DPI, -1}, 0, 0},
- };
- /* 1st para is sout's output, 2nd para is sout's input*/
- sel_t sel_in_map[DDP_SEL_IN_NUM] = {
- /* COLOR_SEL */
- {DISP_MODULE_COLOR0,
- {DISP_MODULE_RDMA0, DISP_MODULE_OVL0, -1}, 0, 0},
- /*UFOE_SEL */
- {DISP_MODULE_UFOE,
- {DISP_MODULE_RDMA0, DISP_MODULE_DITHER, -1}, 0, 0},
- /*DSI0_SEL */
- {DISP_MODULE_DSI0,
- {DISP_MODULE_UFOE, DISP_MODULE_RDMA0, DISP_MODULE_RDMA1, -1}, 0, 0},
- /*DPI0_SEL */
- {DISP_MODULE_DPI,
- {DISP_MODULE_UFOE, DISP_MODULE_RDMA0, DISP_MODULE_RDMA1, -1}, 0, 0},
- /* WDMA_SEL */
- {DISP_MODULE_WDMA0,
- {DISP_MODULE_OVL0, DISP_MODULE_DITHER, DISP_MODULE_UFOE, -1}, 0, 0},
- };
- int ddp_path_init(void)
- {
- /* mout */
- mout_map[0].reg = (volatile unsigned long *)DISP_REG_CONFIG_DISP_OVL0_MOUT_EN;
- #if defined(MTK_FB_OVL1_SUPPORT)
- mout_map[1].reg = (volatile unsigned long *)DISP_REG_CONFIG_DISP_OVL1_MOUT_EN;
- #endif
- mout_map[2].reg = (volatile unsigned long *)DISP_REG_CONFIG_DISP_DITHER_MOUT_EN;
- mout_map[3].reg = (volatile unsigned long *)DISP_REG_CONFIG_DISP_UFOE_MOUT_EN;
- /* sel_out */
- sel_out_map[0].reg = (volatile unsigned long *)DISP_REG_CONFIG_DISP_RDMA0_SOUT_SEL_IN;
- sel_out_map[1].reg = (volatile unsigned long *)DISP_REG_CONFIG_DISP_RDMA1_SOUT_SEL_IN;
- /* sel_in */
- sel_in_map[0].reg = (volatile unsigned long *)DISP_REG_CONFIG_DISP_COLOR0_SEL_IN; /* COLOR_SEL */
- sel_in_map[1].reg = (volatile unsigned long *)DISP_REG_CONFIG_DISP_UFOE_SEL_IN; /* UFOE_SEL */
- sel_in_map[2].reg = (volatile unsigned long *)DISP_REG_CONFIG_DSI0_SEL_IN; /* DSI0_SEL */
- sel_in_map[3].reg = (volatile unsigned long *)DISP_REG_CONFIG_DPI0_SEL_IN; /* DPI0_SEL */
- sel_in_map[4].reg = (volatile unsigned long *)DISP_REG_CONFIG_DISP_WDMA0_SEL_IN; /* WDMA_SEL */
- return 0;
- }
- char *ddp_get_scenario_name(DDP_SCENARIO_ENUM scenario)
- {
- switch (scenario) {
- case DDP_SCENARIO_PRIMARY_DISP:
- return "primary_disp";
- case DDP_SCENARIO_PRIMARY_RDMA0_COLOR0_DISP:
- return "primary_rdma0_color0_disp";
- case DDP_SCENARIO_PRIMARY_RDMA0_DISP:
- return "primary_rdma0_disp";
- case DDP_SCENARIO_PRIMARY_BYPASS_RDMA:
- return "primary_bypass_rdma";
- case DDP_SCENARIO_PRIMARY_OVL_MEMOUT:
- return "primary_ovl_memout";
- case DDP_SCENARIO_PRIMARY_DITHER_MEMOUT:
- return "primary_dither_memout";
- case DDP_SCENARIO_PRIMARY_UFOE_MEMOUT:
- return "primary_ufoe_memout";
- case DDP_SCENARIO_SUB_DISP:
- return "sub_disp";
- case DDP_SCENARIO_SUB_RDMA1_DISP:
- return "sub_rdma1_disp";
- case DDP_SCENARIO_SUB_OVL_MEMOUT:
- return "sub_ovl_memout";
- case DDP_SCENARIO_PRIMARY_ALL:
- return "primary_all";
- case DDP_SCENARIO_SUB_ALL:
- return "sub_all";
- case DDP_SCENARIO_MULTIPLE_OVL:
- return "multi_ovl";
- default:
- DDPMSG("invalid scenario id=%d\n", scenario);
- return "unknown";
- }
- }
- int ddp_is_scenario_on_primary(DDP_SCENARIO_ENUM scenario)
- {
- int on_primary = 0;
- switch (scenario) {
- case DDP_SCENARIO_PRIMARY_DISP:
- case DDP_SCENARIO_PRIMARY_RDMA0_COLOR0_DISP:
- case DDP_SCENARIO_PRIMARY_RDMA0_DISP:
- case DDP_SCENARIO_PRIMARY_BYPASS_RDMA:
- case DDP_SCENARIO_PRIMARY_OVL_MEMOUT:
- case DDP_SCENARIO_PRIMARY_DITHER_MEMOUT:
- case DDP_SCENARIO_PRIMARY_UFOE_MEMOUT:
- case DDP_SCENARIO_PRIMARY_ALL:
- case DDP_SCENARIO_MULTIPLE_OVL:
- on_primary = 1;
- break;
- case DDP_SCENARIO_SUB_DISP:
- case DDP_SCENARIO_SUB_RDMA1_DISP:
- case DDP_SCENARIO_SUB_OVL_MEMOUT:
- case DDP_SCENARIO_SUB_ALL:
- on_primary = 0;
- break;
- default:
- DDPMSG("invalid scenario id=%d\n", scenario);
- }
- return on_primary;
- }
- char *ddp_get_mutex_sof_name(MUTEX_SOF mode)
- {
- switch (mode) {
- case SOF_SINGLE:
- return "single";
- case SOF_DSI0:
- return "dsi0";
- case SOF_DSI1:
- return "dsi1";
- case SOF_DPI0:
- return "dpi0";
- default:
- DDPMSG("invalid sof =%d\n", mode);
- return "unknown";
- }
- }
- char *ddp_get_mode_name(DDP_MODE ddp_mode)
- {
- switch (ddp_mode) {
- case DDP_VIDEO_MODE:
- return "vido_mode";
- case DDP_CMD_MODE:
- return "cmd_mode";
- default:
- DDPMSG("invalid ddp mode =%d\n", ddp_mode);
- return "unknown";
- }
- }
- static int ddp_get_module_num_l(int *module_list)
- {
- unsigned int num = 0;
- while (*(module_list + num) != -1) {
- num++;
- if (num == DDP_ENING_NUM)
- break;
- }
- return num;
- }
- /* config mout/msel to creat a compelte path */
- static void ddp_connect_path_l(int *module_list, void *handle)
- {
- unsigned int i, j, k;
- int step = 0;
- unsigned int mout = 0;
- unsigned int reg_mout = 0;
- unsigned int mout_idx = 0;
- unsigned int module_num = ddp_get_module_num_l(module_list);
- DDPDBG("connect_path: %s to %s\n", ddp_get_module_name(module_list[0]),
- ddp_get_module_name(module_list[module_num - 1]));
- /* connect mout */
- for (i = 0; i < module_num - 1; i++) {
- for (j = 0; j < DDP_MOUT_NUM; j++) {
- if (module_list[i] == mout_map[j].id) {
- /* find next module which can be connected */
- step = i + 1;
- while (module_can_connect[module_list[step]].bit == 0
- && step < module_num) {
- step++;
- }
- ASSERT(step < module_num);
- mout = mout_map[j].reg_val;
- for (k = 0; k < 5; k++) {
- if (mout_map[j].out_id_bit_map[k].m == -1)
- break;
- if (mout_map[j].out_id_bit_map[k].m == module_list[step]) {
- mout |= mout_map[j].out_id_bit_map[k].v;
- reg_mout |= mout;
- mout_idx = j;
- DDPDBG("connect mout %s to %s value 0x%x\n",
- ddp_get_module_name(module_list[i]),
- ddp_get_module_name(module_list[step]),
- reg_mout);
- break;
- }
- }
- mout_map[j].reg_val = mout;
- mout = 0;
- }
- }
- if (reg_mout) {
- DISP_REG_SET(handle, mout_map[mout_idx].reg, reg_mout);
- reg_mout = 0;
- mout_idx = 0;
- }
- }
- /* connect out select */
- for (i = 0; i < module_num - 1; i++) {
- for (j = 0; j < DDP_SEL_OUT_NUM; j++) {
- if (module_list[i] == sel_out_map[j].id) {
- step = i + 1;
- /* find next module which can be connected */
- while (module_can_connect[module_list[step]].bit == 0
- && step < module_num) {
- step++;
- }
- ASSERT(step < module_num);
- for (k = 0; k < 4; k++) {
- if (sel_out_map[j].id_bit_map[k] == -1)
- break;
- if (sel_out_map[j].id_bit_map[k] == module_list[step]) {
- DDPDBG("connect out_s %s to %s, bits=0x%x\n",
- ddp_get_module_name(module_list[i]),
- ddp_get_module_name(module_list[step]), k);
- DISP_REG_SET(handle, sel_out_map[j].reg, (uint16_t)k);
- break;
- }
- }
- }
- }
- }
- /* connect input select */
- for (i = 1; i < module_num; i++) {
- for (j = 0; j < DDP_SEL_IN_NUM; j++) {
- if (module_list[i] == sel_in_map[j].id) {
- step = i - 1;
- /* find next module which can be connected */
- while (module_can_connect[module_list[step]].bit == 0 && step > 0)
- step--;
- ASSERT(step >= 0);
- for (k = 0; k < 4; k++) {
- if (sel_in_map[j].id_bit_map[k] == -1)
- break;
- if (sel_in_map[j].id_bit_map[k] == module_list[step]) {
- DDPDBG("connect in_s %s to %s, bits=0x%x\n",
- ddp_get_module_name(module_list[step]),
- ddp_get_module_name(module_list[i]), k);
- DISP_REG_SET(handle, sel_in_map[j].reg, (uint16_t)k);
- break;
- }
- }
- }
- }
- }
- }
- static void ddp_check_path_l(int *module_list)
- {
- unsigned int i, j, k;
- int step = 0;
- int valid = 0;
- unsigned int mout;
- unsigned int path_error = 0;
- unsigned int module_num = ddp_get_module_num_l(module_list);
- DDPDUMP("check_path: %s to %s\n", ddp_get_module_name(module_list[0])
- , ddp_get_module_name(module_list[module_num - 1]));
- /* check mout */
- for (i = 0; i < module_num - 1; i++) {
- for (j = 0; j < DDP_MOUT_NUM; j++) {
- if (module_list[i] == mout_map[j].id) {
- mout = 0;
- /* find next module which can be connected */
- step = i + 1;
- while (module_can_connect[module_list[step]].bit == 0
- && step < module_num) {
- step++;
- }
- ASSERT(step < module_num);
- for (k = 0; k < 5; k++) {
- if (mout_map[j].out_id_bit_map[k].m == -1)
- break;
- if (mout_map[j].out_id_bit_map[k].m == module_list[step]) {
- mout |= mout_map[j].out_id_bit_map[k].v;
- valid = 1;
- break;
- }
- }
- if (valid) {
- valid = 0;
- if ((DISP_REG_GET(mout_map[j].reg) & mout) == 0) {
- path_error += 1;
- DDPDUMP("error:%s mout, expect=0x%x, real=0x%x\n",
- ddp_get_module_name(module_list[i]),
- mout, DISP_REG_GET(mout_map[j].reg));
- } else if (DISP_REG_GET(mout_map[j].reg) != mout) {
- DDPDUMP
- ("warning: %s mout expect=0x%x, real=0x%x\n",
- ddp_get_module_name(module_list[i]), mout,
- DISP_REG_GET(mout_map[j].reg));
- }
- }
- break;
- }
- }
- }
- /* check out select */
- for (i = 0; i < module_num - 1; i++) {
- for (j = 0; j < DDP_SEL_OUT_NUM; j++) {
- if (module_list[i] != sel_out_map[j].id)
- continue;
- /* find next module which can be connected */
- step = i + 1;
- while (module_can_connect[module_list[step]].bit == 0
- && step < module_num) {
- step++;
- }
- ASSERT(step < module_num);
- for (k = 0; k < 4; k++) {
- if (sel_out_map[j].id_bit_map[k] == -1)
- break;
- if (sel_out_map[j].id_bit_map[k] == module_list[step]) {
- if (DISP_REG_GET(sel_out_map[j].reg) != k) {
- path_error += 1;
- DDPDUMP
- ("error:out_s %s not connect to %s,expect=0x%x,real=0x%x\n",
- ddp_get_module_name(module_list[i]),
- ddp_get_module_name(module_list[step]),
- k, DISP_REG_GET(sel_out_map[j].reg));
- }
- break;
- }
- }
- }
- }
- /* check input select */
- for (i = 1; i < module_num; i++) {
- for (j = 0; j < DDP_SEL_IN_NUM; j++) {
- if (module_list[i] != sel_in_map[j].id)
- continue;
- /* find next module which can be connected */
- step = i - 1;
- while (module_can_connect[module_list[step]].bit == 0 && step > 0)
- step--;
- ASSERT(step >= 0);
- for (k = 0; k < 4; k++) {
- if (sel_in_map[j].id_bit_map[k] == -1)
- break;
- if (sel_in_map[j].id_bit_map[k] == module_list[step]) {
- if (DISP_REG_GET(sel_in_map[j].reg) != k) {
- path_error += 1;
- DDPDUMP
- ("error:in_s%s not connect to %s,expect=0x%x,real=0x%x\n",
- ddp_get_module_name(module_list[step]),
- ddp_get_module_name(module_list[i]), k,
- DISP_REG_GET(sel_in_map[j].reg));
- }
- break;
- }
- }
- }
- }
- if (path_error == 0) {
- DDPDUMP("path: %s to %s is connected\n", ddp_get_module_name(module_list[0]),
- ddp_get_module_name(module_list[module_num - 1]));
- } else {
- DDPDUMP("path: %s to %s not connected!!!\n", ddp_get_module_name(module_list[0]),
- ddp_get_module_name(module_list[module_num - 1]));
- }
- }
- static void ddp_disconnect_path_l(int *module_list, void *handle)
- {
- unsigned int i, j, k;
- int step = 0;
- unsigned int mout = 0;
- unsigned int reg_mout = 0;
- unsigned int mout_idx = 0;
- unsigned int module_num = ddp_get_module_num_l(module_list);
- DDPDBG("disconnect_path: %s to %s\n", ddp_get_module_name(module_list[0]),
- ddp_get_module_name(module_list[module_num - 1]));
- for (i = 0; i < module_num - 1; i++) {
- for (j = 0; j < DDP_MOUT_NUM; j++) {
- if (module_list[i] == mout_map[j].id) {
- /* find next module which can be connected */
- step = i + 1;
- while (module_can_connect[module_list[step]].bit == 0
- && step < module_num) {
- step++;
- }
- ASSERT(step < module_num);
- for (k = 0; k < 5; k++) {
- if (mout_map[j].out_id_bit_map[k].m == -1)
- break;
- if (mout_map[j].out_id_bit_map[k].m == module_list[step]) {
- mout |= mout_map[j].out_id_bit_map[k].v;
- reg_mout |= mout;
- mout_idx = j;
- DDPDBG("disconnect mout %s to %s\n",
- ddp_get_module_name(module_list[i]),
- ddp_get_module_name(module_list[step]));
- break;
- }
- }
- /* update mout_value */
- mout_map[j].reg_val &= ~mout;
- mout = 0;
- }
- }
- if (reg_mout) {
- DISP_REG_SET(handle, mout_map[mout_idx].reg, mout_map[mout_idx].reg_val);
- reg_mout = 0;
- mout_idx = 0;
- }
- }
- }
- static MUTEX_SOF ddp_get_mutex_sof(DISP_MODULE_ENUM dest_module, DDP_MODE ddp_mode)
- {
- MUTEX_SOF mode = SOF_SINGLE;
- switch (dest_module) {
- case DISP_MODULE_DSI0:
- {
- mode = (ddp_mode == DDP_VIDEO_MODE ? SOF_DSI0 : SOF_SINGLE);
- break;
- }
- case DISP_MODULE_DSI1:
- {
- mode = (ddp_mode == DDP_VIDEO_MODE ? SOF_DSI1 : SOF_SINGLE);
- break;
- }
- case DISP_MODULE_DSIDUAL:
- {
- mode = (ddp_mode == DDP_VIDEO_MODE ? SOF_DSI0 : SOF_SINGLE);
- break;
- }
- case DISP_MODULE_DPI:
- {
- mode = SOF_DSI1; /* SOF_DPI0; has one DSI, so the DPI should use 1 for mutex_sof */
- break;
- }
- case DISP_MODULE_WDMA0:
- case DISP_MODULE_WDMA1:
- mode = SOF_SINGLE;
- break;
- default:
- DDPERR("get mutex sof, invalid param dst module = %s(%d), dis mode %s\n",
- ddp_get_module_name(dest_module), dest_module, ddp_get_mode_name(ddp_mode));
- }
- DDPDBG("mutex sof: %s dst module %s:%s\n",
- ddp_get_mutex_sof_name(mode), ddp_get_module_name(dest_module),
- ddp_get_mode_name(ddp_mode));
- return mode;
- }
- /* id: mutex ID, 0~5 */
- static int ddp_mutex_set_l(int mutex_id, int *module_list, DDP_MODE ddp_mode, void *handle)
- {
- int i = 0;
- uint32_t value = 0;
- int module_num = ddp_get_module_num_l(module_list);
- MUTEX_SOF mode = ddp_get_mutex_sof(module_list[module_num - 1], ddp_mode);
- if (mutex_id < DISP_MUTEX_DDP_FIRST || mutex_id > DISP_MUTEX_DDP_LAST) {
- DDPERR("exceed mutex max (0 ~ %d)\n", DISP_MUTEX_DDP_LAST);
- return -1;
- }
- for (i = 0; i < module_num; i++) {
- if (module_mutex_map[module_list[i]].bit != -1) {
- DDPDBG("module %s added to mutex %d\n", ddp_get_module_name(module_list[i]),
- mutex_id);
- value |= (1 << module_mutex_map[module_list[i]].bit);
- } else {
- DDPDBG("module %s not added to mutex %d\n",
- ddp_get_module_name(module_list[i]), mutex_id);
- }
- }
- DISP_REG_SET(handle, DISP_REG_CONFIG_MUTEX_MOD(mutex_id), value);
- DISP_REG_SET(handle, DISP_REG_CONFIG_MUTEX_SOF(mutex_id), mode);
- /* for primary config thread, save more time for register config */
- if (gEnableMutexRisingEdge == 1 && primary_display_is_video_mode() == 1 && mutex_id == 0) {
- DISP_REG_SET_FIELD(handle, SOF_FLD_MUTEX0_SOF_TIMING, DISP_REG_CONFIG_MUTEX0_SOF,
- 1);
- }
- if (gEnableSWTrigger == 1 && primary_display_is_video_mode() == 1 && mutex_id == 0) {
- /* set OVL0/OVL1 to separate mutex */
- DISP_REG_SET(handle, DISP_REG_CONFIG_MUTEX_MOD(DISP_OVL_SEPARATE_MUTEX_ID),
- value & ((1 << module_mutex_map[DISP_MODULE_OVL0].bit) |
- (1 << module_mutex_map[DISP_MODULE_OVL1].bit)));
- DISP_REG_SET(handle, DISP_REG_CONFIG_MUTEX_SOF(DISP_OVL_SEPARATE_MUTEX_ID),
- SOF_SINGLE);
- /* move OVL0/OVL1 out from primary path */
- DISP_REG_SET(handle, DISP_REG_CONFIG_MUTEX_MOD(mutex_id),
- value &
- (~
- ((1 << module_mutex_map[DISP_MODULE_OVL0].
- bit) | (1 << module_mutex_map[DISP_MODULE_OVL1].bit))));
- }
- DDPDBG("mutex %d value=0x%x, sof=%s\n", mutex_id, value, ddp_get_mutex_sof_name(mode));
- return 0;
- }
- static void ddp_check_mutex_l(int mutex_id, int *module_list, DDP_MODE ddp_mode)
- {
- int i = 0;
- uint32_t real_value = 0;
- uint32_t expect_value = 0;
- uint32_t real_sof = 0;
- MUTEX_SOF expect_sof = SOF_SINGLE;
- int module_num = ddp_get_module_num_l(module_list);
- if (mutex_id < DISP_MUTEX_DDP_FIRST || mutex_id > DISP_MUTEX_DDP_LAST) {
- DDPDUMP("error:check mutex fail:exceed mutex max (0 ~ %d)\n", DISP_MUTEX_DDP_LAST);
- return;
- }
- real_value = DISP_REG_GET(DISP_REG_CONFIG_MUTEX_MOD(mutex_id));
- for (i = 0; i < module_num; i++) {
- if (module_mutex_map[module_list[i]].bit != -1)
- expect_value |= (1 << module_mutex_map[module_list[i]].bit);
- }
- if (expect_value != real_value) {
- DDPDUMP("error:mutex %d error: expect 0x%x, real 0x%x\n", mutex_id, expect_value,
- real_value);
- }
- real_sof = DISP_REG_GET(DISP_REG_CONFIG_MUTEX_SOF(mutex_id));
- expect_sof = ddp_get_mutex_sof(module_list[module_num - 1], ddp_mode);
- if ((uint32_t) expect_sof != real_sof) {
- DDPDUMP("error:mutex %d sof error: expect %s, real %s\n", mutex_id,
- ddp_get_mutex_sof_name(expect_sof),
- ddp_get_mutex_sof_name((MUTEX_SOF) real_sof));
- }
- }
- static int ddp_mutex_enable_l(int mutex_idx, void *handle)
- {
- DDPDBG("mutex %d enable\n", mutex_idx);
- DISP_REG_SET(handle, DISP_REG_CONFIG_MUTEX_EN(mutex_idx), 1);
- return 0;
- }
- int ddp_mutex_hw_dcm_on(int mutex_idx, void *handle)
- {
- if (gMutexFreeRun == 1 && primary_display_is_video_mode() == 0 && mutex_idx == 0)
- DISP_REG_SET(handle, DISP_REG_CONFIG_MUTEX_HW_DCM, 1);
- DDPDBG("mutex %d hw_dcm 0x%x\n", mutex_idx, DISP_REG_GET(DISP_REG_CONFIG_MUTEX_HW_DCM));
- return 0;
- }
- int ddp_mutex_hw_dcm_off(int mutex_idx, void *handle)
- {
- if (gMutexFreeRun == 1 && primary_display_is_video_mode() == 0 && mutex_idx == 0)
- DISP_REG_SET(handle, DISP_REG_CONFIG_MUTEX_HW_DCM, 0);
- DDPDBG("mutex %d hw_dcm 0x%x\n", mutex_idx, DISP_REG_GET(DISP_REG_CONFIG_MUTEX_HW_DCM));
- return 0;
- }
- int ddp_get_module_num(DDP_SCENARIO_ENUM scenario)
- {
- return ddp_get_module_num_l(module_list_scenario[scenario]);
- }
- static void ddp_print_scenario(DDP_SCENARIO_ENUM scenario)
- {
- int i = 0;
- char path[512] = { '\0' };
- int num = ddp_get_module_num(scenario);
- for (i = 0; i < num; i++)
- strcat(path, ddp_get_module_name(module_list_scenario[scenario][i]));
- DDPMSG("scenario %s have modules: %s\n", ddp_get_scenario_name(scenario), path);
- }
- static int ddp_find_module_index(DDP_SCENARIO_ENUM ddp_scenario, DISP_MODULE_ENUM module)
- {
- int i = 0;
- for (i = 0; i < DDP_ENING_NUM; i++) {
- if (module_list_scenario[ddp_scenario][i] == module)
- return i;
- }
- DDPDBG("find module: can not find module %s on scenario %s\n", ddp_get_module_name(module),
- ddp_get_scenario_name(ddp_scenario));
- return -1;
- }
- /* set display interface when kernel init */
- int ddp_set_dst_module(DDP_SCENARIO_ENUM scenario, DISP_MODULE_ENUM dst_module)
- {
- int i = 0;
- DDPMSG("ddp_set_dst_module, scenario=%s, dst_module=%s\n",
- ddp_get_scenario_name(scenario), ddp_get_module_name(dst_module));
- if (ddp_find_module_index(scenario, dst_module) > 0) {
- DDPDBG("%s is already on path\n", ddp_get_module_name(dst_module));
- return 0;
- }
- i = ddp_get_module_num_l(module_list_scenario[scenario]) - 1;
- ASSERT(i >= 0);
- if (dst_module == DISP_MODULE_DSIDUAL) {
- if (i < (DDP_ENING_NUM - 1)) {
- module_list_scenario[scenario][i++] = DISP_MODULE_SPLIT1;
- } else {
- DDPERR("set dst module over up bound\n");
- return -1;
- }
- } else {
- if (ddp_get_dst_module(scenario) == DISP_MODULE_DSIDUAL) {
- if (i >= 1) {
- module_list_scenario[scenario][i--] = -1;
- } else {
- DDPERR("set dst module over low bound\n");
- return -1;
- }
- }
- }
- module_list_scenario[scenario][i] = dst_module;
- if (scenario == DDP_SCENARIO_PRIMARY_ALL)
- ddp_set_dst_module(DDP_SCENARIO_PRIMARY_DISP, dst_module);
- else if (scenario == DDP_SCENARIO_SUB_ALL)
- ddp_set_dst_module(DDP_SCENARIO_SUB_DISP, dst_module);
- ddp_print_scenario(scenario);
- return 0;
- }
- DISP_MODULE_ENUM ddp_get_dst_module(DDP_SCENARIO_ENUM ddp_scenario)
- {
- DISP_MODULE_ENUM module_name = DISP_MODULE_UNKNOWN;
- int module_num = ddp_get_module_num_l(module_list_scenario[ddp_scenario]) - 1;
- if (module_num >= 0)
- module_name = module_list_scenario[ddp_scenario][module_num];
- /* DDPMSG("ddp_get_dst_module, scneario=%s, dst_module=%s\n", */
- /* ddp_get_scenario_name(ddp_scenario), */
- /* ddp_get_module_name(module_name)); */
- return module_name;
- }
- int *ddp_get_scenario_list(DDP_SCENARIO_ENUM ddp_scenario)
- {
- return module_list_scenario[ddp_scenario];
- }
- int ddp_is_module_in_scenario(DDP_SCENARIO_ENUM ddp_scenario, DISP_MODULE_ENUM module)
- {
- int i = 0;
- for (i = 0; i < DDP_ENING_NUM; i++) {
- if (module_list_scenario[ddp_scenario][i] == module)
- return 1;
- }
- return 0;
- }
- int ddp_insert_module(DDP_SCENARIO_ENUM ddp_scenario, DISP_MODULE_ENUM place,
- DISP_MODULE_ENUM module)
- {
- int i = DDP_ENING_NUM - 1;
- int idx = ddp_find_module_index(ddp_scenario, place);
- if (idx < 0) {
- DDPERR("error: ddp_insert_module , place=%s is not in scenario %s!\n",
- ddp_get_module_name(place), ddp_get_scenario_name(ddp_scenario));
- return -1;
- }
- for (i = 0; i < DDP_ENING_NUM; i++) {
- if (module_list_scenario[ddp_scenario][i] == module) {
- DDPERR("error: ddp_insert_module , module=%s is already in scenario %s!\n",
- ddp_get_module_name(module), ddp_get_scenario_name(ddp_scenario));
- return -1;
- }
- }
- /* should have empty room for insert */
- ASSERT(module_list_scenario[ddp_scenario][DDP_ENING_NUM - 1] == -1);
- for (i = DDP_ENING_NUM - 2; i >= idx; i--)
- module_list_scenario[ddp_scenario][i + 1] = module_list_scenario[ddp_scenario][i];
- module_list_scenario[ddp_scenario][idx] = module;
- if (0) {
- int *modules = ddp_get_scenario_list(ddp_scenario);
- int module_num = ddp_get_module_num(ddp_scenario);
- DDPMSG("after insert module, module list is:\n");
- for (i = 0; i < module_num; i++)
- DDPMSG("%s-", ddp_get_module_name(modules[i]));
- }
- return 0;
- }
- int ddp_remove_module(DDP_SCENARIO_ENUM ddp_scenario, DISP_MODULE_ENUM module)
- {
- int i = 0;
- int idx = ddp_find_module_index(ddp_scenario, module);
- if (idx < 0) {
- DDPERR("ddp_remove_module, can not find module %s in scenario %s\n",
- ddp_get_module_name(module), ddp_get_scenario_name(ddp_scenario));
- return -1;
- }
- for (i = idx; i < DDP_ENING_NUM - 1; i++)
- module_list_scenario[ddp_scenario][i] = module_list_scenario[ddp_scenario][i + 1];
- module_list_scenario[ddp_scenario][DDP_ENING_NUM - 1] = -1;
- {
- int *modules = ddp_get_scenario_list(ddp_scenario);
- int module_num = ddp_get_module_num(ddp_scenario);
- DDPMSG("after remove module, module list is:\n");
- for (i = 0; i < module_num; i++)
- DDPMSG("%s-", ddp_get_module_name(modules[i]));
- }
- return 0;
- }
- void ddp_connect_path(DDP_SCENARIO_ENUM scenario, void *handle)
- {
- DDPDBG("path connect on scenario %s\n", ddp_get_scenario_name(scenario));
- if (scenario == DDP_SCENARIO_PRIMARY_ALL) {
- ddp_connect_path_l(module_list_scenario[DDP_SCENARIO_PRIMARY_DISP], handle);
- ddp_connect_path_l(module_list_scenario[DDP_SCENARIO_PRIMARY_OVL_MEMOUT], handle);
- } else if (scenario == DDP_SCENARIO_SUB_ALL) {
- ddp_connect_path_l(module_list_scenario[DDP_SCENARIO_SUB_DISP], handle);
- ddp_connect_path_l(module_list_scenario[DDP_SCENARIO_SUB_OVL_MEMOUT], handle);
- } else {
- ddp_connect_path_l(module_list_scenario[scenario], handle);
- }
- }
- void ddp_disconnect_path(DDP_SCENARIO_ENUM scenario, void *handle)
- {
- DDPDBG("path disconnect on scenario %s\n", ddp_get_scenario_name(scenario));
- if (scenario == DDP_SCENARIO_PRIMARY_ALL) {
- ddp_disconnect_path_l(module_list_scenario[DDP_SCENARIO_PRIMARY_DISP], handle);
- ddp_disconnect_path_l(module_list_scenario[DDP_SCENARIO_PRIMARY_OVL_MEMOUT],
- handle);
- } else if (scenario == DDP_SCENARIO_SUB_ALL) {
- ddp_disconnect_path_l(module_list_scenario[DDP_SCENARIO_SUB_DISP], handle);
- ddp_disconnect_path_l(module_list_scenario[DDP_SCENARIO_SUB_OVL_MEMOUT], handle);
- } else {
- ddp_disconnect_path_l(module_list_scenario[scenario], handle);
- }
- }
- void ddp_check_path(DDP_SCENARIO_ENUM scenario)
- {
- DDPDBG("path check path on scenario %s\n", ddp_get_scenario_name(scenario));
- if (scenario == DDP_SCENARIO_PRIMARY_ALL) {
- ddp_check_path_l(module_list_scenario[DDP_SCENARIO_PRIMARY_DISP]);
- ddp_check_path_l(module_list_scenario[DDP_SCENARIO_PRIMARY_OVL_MEMOUT]);
- } else if (scenario == DDP_SCENARIO_SUB_ALL) {
- ddp_check_path_l(module_list_scenario[DDP_SCENARIO_SUB_DISP]);
- ddp_check_path_l(module_list_scenario[DDP_SCENARIO_SUB_OVL_MEMOUT]);
- } else {
- ddp_check_path_l(module_list_scenario[scenario]);
- }
- }
- void ddp_check_mutex(int mutex_id, DDP_SCENARIO_ENUM scenario, DDP_MODE mode)
- {
- DDPDBG("check mutex %d on scenario %s\n", mutex_id, ddp_get_scenario_name(scenario));
- ddp_check_mutex_l(mutex_id, module_list_scenario[scenario], mode);
- }
- int ddp_mutex_set(int mutex_id, DDP_SCENARIO_ENUM scenario, DDP_MODE mode, void *handle)
- {
- if (scenario < DDP_SCENARIO_MAX)
- return ddp_mutex_set_l(mutex_id, module_list_scenario[scenario], mode, handle);
- DDPERR("Invalid scenario %d when setting mutex\n", scenario);
- return -1;
- }
- int ddp_mutex_Interrupt_enable(int mutex_id, void *handle)
- {
- DDPDBG("mutex %d interrupt enable\n", mutex_id);
- if (gEnableIRQ == 0 && mutex_id == 0)
- return 0;
- DISP_REG_MASK(handle, DISP_REG_CONFIG_MUTEX_INTEN, 0x1 << mutex_id, 0x1 << mutex_id);
- DISP_REG_MASK(handle, DISP_REG_CONFIG_MUTEX_INTEN, 1 << (mutex_id + DISP_MUTEX_TOTAL),
- 0x1 << (mutex_id + DISP_MUTEX_TOTAL));
- return 0;
- }
- int ddp_mutex_Interrupt_disable(int mutex_id, void *handle)
- {
- DDPDBG("mutex %d interrupt disenable\n", mutex_id);
- DISP_REG_MASK(handle, DISP_REG_CONFIG_MUTEX_INTEN, 0, 0x1 << mutex_id);
- DISP_REG_MASK(handle, DISP_REG_CONFIG_MUTEX_INTEN, 0, 0x1 << (mutex_id + DISP_MUTEX_TOTAL));
- return 0;
- }
- int ddp_mutex_reset(int mutex_id, void *handle)
- {
- DDPDBG("mutex %d reset\n", mutex_id);
- DISP_REG_SET(handle, DISP_REG_CONFIG_MUTEX_RST(mutex_id), 1);
- DISP_REG_SET(handle, DISP_REG_CONFIG_MUTEX_RST(mutex_id), 0);
- return 0;
- }
- int ddp_mutex_add_module(int mutex_id, DISP_MODULE_ENUM module, void *handle)
- {
- int value = 0;
- if (module < DISP_MODULE_UNKNOWN) {
- if (module_mutex_map[module].bit != -1) {
- DDPDBG("module %s added to mutex %d\n", ddp_get_module_name(module),
- mutex_id);
- value |= (1 << module_mutex_map[module].bit);
- DISP_REG_MASK(handle, DISP_REG_CONFIG_MUTEX_MOD(mutex_id), value, value);
- }
- }
- return 0;
- }
- int ddp_mutex_remove_module(int mutex_id, DISP_MODULE_ENUM module, void *handle)
- {
- int value = 0;
- if (module < DISP_MODULE_UNKNOWN) {
- if (module_mutex_map[module].bit != -1) {
- DDPDBG("module %s added to mutex %d\n", ddp_get_module_name(module),
- mutex_id);
- value |= (1 << module_mutex_map[module].bit);
- DISP_REG_MASK(handle, DISP_REG_CONFIG_MUTEX_MOD(mutex_id), 0, value);
- }
- }
- return 0;
- }
- int ddp_mutex_clear(int mutex_id, void *handle)
- {
- DDPDBG("mutex %d clear\n", mutex_id);
- DISP_REG_SET(handle, DISP_REG_CONFIG_MUTEX_MOD(mutex_id), 0);
- DISP_REG_SET(handle, DISP_REG_CONFIG_MUTEX_SOF(mutex_id), 0);
- /*reset mutex */
- ddp_mutex_reset(mutex_id, handle);
- return 0;
- }
- int ddp_mutex_enable(int mutex_id, DDP_SCENARIO_ENUM scenario, void *handle)
- {
- return ddp_mutex_enable_l(mutex_id, handle);
- }
- int ddp_mutex_disenable(int mutex_id, DDP_SCENARIO_ENUM scenario, void *handle)
- {
- DDPDBG("mutex %d disable\n", mutex_id);
- DISP_REG_SET(handle, DISP_REG_CONFIG_MUTEX_EN(mutex_id), 0);
- return 0;
- }
- int ddp_check_engine_status(int mutexID)
- {
- /* check engines' clock bit & enable bit & status bit before unlock mutex */
- /* should not needed, in comdq do? */
- int result = 0;
- return result;
- }
- int ddp_path_top_clock_on(void)
- {
- #ifdef ENABLE_CLK_MGR
- #ifdef CONFIG_MTK_CLKMGR
- enable_clock(MT_CG_DISP0_SMI_COMMON, "DDP");
- enable_clock(MT_CG_DISP0_SMI_LARB0, "DDP");
- /* enable_clock(MT_CG_DISP0_MUTEX_32K , "DDP"); */
- #else
- static int need_enable;
- if (need_enable) {
- ddp_clk_prepare_enable(DISP_MTCMOS_CLK);
- ddp_clk_prepare_enable(DISP0_SMI_COMMON);
- ddp_clk_prepare_enable(DISP0_SMI_LARB0);
- /* ddp_clk_prepare_enable(MT_CG_DISP0_MUTEX_32K); */
- } else {
- need_enable = 1;
- }
- #endif
- DDPMSG("ddp path top clock on CG:%08x\n", DISP_REG_GET(DISP_REG_CONFIG_MMSYS_CG_CON0));
- #endif
- return 0;
- }
- int ddp_path_top_clock_off(void)
- {
- #ifdef ENABLE_CLK_MGR
- DDPMSG("ddp path top clock off\n");
- #ifdef CONFIG_MTK_CLKMGR
- if (clk_is_force_on(MT_CG_DISP0_SMI_LARB0) || clk_is_force_on(MT_CG_DISP0_SMI_COMMON)) {
- DDPMSG("clear SMI_LARB0 & SMI_COMMON forced on\n");
- clk_clr_force_on(MT_CG_DISP0_SMI_LARB0);
- clk_clr_force_on(MT_CG_DISP0_SMI_COMMON);
- }
- #endif
- #ifdef CONFIG_MTK_CLKMGR
- /* disable_clock(MT_CG_DISP0_MUTEX_32K , "DDP"); */
- disable_clock(MT_CG_DISP0_SMI_LARB0, "DDP");
- disable_clock(MT_CG_DISP0_SMI_COMMON, "DDP");
- #else
- /*ddp_clk_disable_unprepare(DISP0_MUTEX_32K); */
- ddp_clk_disable_unprepare(DISP0_SMI_LARB0);
- ddp_clk_disable_unprepare(DISP0_SMI_COMMON);
- ddp_clk_disable_unprepare(DISP_MTCMOS_CLK);
- #endif
- #endif
- return 0;
- }
- int ddp_path_lp_top_clock_on(void)
- {
- #ifdef ENABLE_CLK_MGR
- #ifdef CONFIG_MTK_CLKMGR
- enable_clock(MT_CG_DISP0_SMI_COMMON, "DDP");
- enable_clock(MT_CG_DISP0_SMI_LARB0, "DDP");
- #else
- ddp_clk_enable(DISP_MTCMOS_CLK);
- ddp_clk_enable(DISP0_SMI_COMMON);
- ddp_clk_enable(DISP0_SMI_LARB0);
- #endif
- #endif
- return 0;
- }
- int ddp_path_lp_top_clock_off(void)
- {
- #ifdef ENABLE_CLK_MGR
- #ifdef CONFIG_MTK_CLKMGR
- disable_clock(MT_CG_DISP0_SMI_LARB0, "DDP");
- disable_clock(MT_CG_DISP0_SMI_COMMON, "DDP");
- #else
- ddp_clk_disable(DISP0_SMI_LARB0);
- ddp_clk_disable(DISP0_SMI_COMMON);
- ddp_clk_disable(DISP_MTCMOS_CLK);
- #endif
- #endif
- return 0;
- }
- /* should remove */
- int ddp_insert_config_allow_rec(void *handle)
- {
- int ret = 0;
- if (handle == NULL)
- ASSERT(0);
- if (primary_display_is_video_mode()) {
- if (gEnableMutexRisingEdge == 1)
- ret = cmdqRecWaitNoClear(handle, CMDQ_EVENT_DISP_RDMA0_EOF);
- else
- ret = cmdqRecWaitNoClear(handle, CMDQ_EVENT_MUTEX0_STREAM_EOF);
- } else {
- ret = cmdqRecWaitNoClear(handle, CMDQ_SYNC_TOKEN_STREAM_EOF);
- }
- return ret;
- }
- int ddp_insert_config_dirty_rec(void *handle)
- {
- int ret = 0;
- if (handle == NULL)
- ASSERT(0);
- if (primary_display_is_video_mode())
- /* TODO: modify this */
- {
- /* do nothing */
- } else {
- ret = cmdqRecSetEventToken(handle, CMDQ_SYNC_TOKEN_CONFIG_DIRTY);
- }
- return ret;
- }
- int disp_get_dst_module(DDP_SCENARIO_ENUM scenario)
- {
- return ddp_get_dst_module(scenario);
- }
|