1.下面介绍一下tft和slcd的descriptor operation的区别和代码的实现机制:
这里我使用的是slcd,但只用了FRM0,没有使用FRM1,所以需要disable掉FRM1,在调试中我并没有disable掉FRM1,而且也没有像上图中指定:CMD->FRM0->FRM1->CMD->。。。导致屏幕显示白色的雪花。
disableFRM1的代码为:
framedesc1->cmd = (LCDC_CMD_EOFINT & ~LCDC_CMD_FRM_EN) | (bypes_per_panel / 4);
注意:因为在该驱动中只使用了FRM0,所以机制为:CMD->FRM0->CMD->FRM0。。。注意代码的实现。
2.在frame buffer驱动初始化之前需要对lcd的dma进行初始化:
void jzfb_hal_slcd_restart(struct jzfb_hal *hal)
{
unsigned int tmp;
tmp = hal_reg_read(hal, SLCDC_CTRL);
tmp |= SLCDC_CTRL_DMA_START | SLCDC_CTRL_DMA_MODE;
hal_reg_write(hal, SLCDC_CTRL, tmp);
}