da8xx-fb.c 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Porting to u-boot:
  4. *
  5. * (C) Copyright 2011
  6. * Stefano Babic, DENX Software Engineering, sbabic@denx.de.
  7. *
  8. * Copyright (C) 2008-2009 MontaVista Software Inc.
  9. * Copyright (C) 2008-2009 Texas Instruments Inc
  10. *
  11. * Based on the LCD driver for TI Avalanche processors written by
  12. * Ajay Singh and Shalom Hai.
  13. */
  14. #include <common.h>
  15. #include <memalign.h>
  16. #include <video_fb.h>
  17. #include <linux/list.h>
  18. #include <linux/fb.h>
  19. #include <linux/errno.h>
  20. #include <asm/io.h>
  21. #include <asm/arch/hardware.h>
  22. #include "videomodes.h"
  23. #include "da8xx-fb.h"
  24. #if !defined(DA8XX_LCD_CNTL_BASE)
  25. #define DA8XX_LCD_CNTL_BASE DAVINCI_LCD_CNTL_BASE
  26. #endif
  27. #define DRIVER_NAME "da8xx_lcdc"
  28. #define LCD_VERSION_1 1
  29. #define LCD_VERSION_2 2
  30. /* LCD Status Register */
  31. #define LCD_END_OF_FRAME1 (1 << 9)
  32. #define LCD_END_OF_FRAME0 (1 << 8)
  33. #define LCD_PL_LOAD_DONE (1 << 6)
  34. #define LCD_FIFO_UNDERFLOW (1 << 5)
  35. #define LCD_SYNC_LOST (1 << 2)
  36. /* LCD DMA Control Register */
  37. #define LCD_DMA_BURST_SIZE(x) ((x) << 4)
  38. #define LCD_DMA_BURST_1 0x0
  39. #define LCD_DMA_BURST_2 0x1
  40. #define LCD_DMA_BURST_4 0x2
  41. #define LCD_DMA_BURST_8 0x3
  42. #define LCD_DMA_BURST_16 0x4
  43. #define LCD_V1_END_OF_FRAME_INT_ENA (1 << 2)
  44. #define LCD_V2_END_OF_FRAME0_INT_ENA (1 << 8)
  45. #define LCD_V2_END_OF_FRAME1_INT_ENA (1 << 9)
  46. #define LCD_DUAL_FRAME_BUFFER_ENABLE (1 << 0)
  47. #define LCD_V2_TFT_24BPP_MODE (1 << 25)
  48. #define LCD_V2_TFT_24BPP_UNPACK (1 << 26)
  49. /* LCD Control Register */
  50. #define LCD_CLK_DIVISOR(x) ((x) << 8)
  51. #define LCD_RASTER_MODE 0x01
  52. /* LCD Raster Control Register */
  53. #define LCD_PALETTE_LOAD_MODE(x) ((x) << 20)
  54. #define PALETTE_AND_DATA 0x00
  55. #define PALETTE_ONLY 0x01
  56. #define DATA_ONLY 0x02
  57. #define LCD_MONO_8BIT_MODE (1 << 9)
  58. #define LCD_RASTER_ORDER (1 << 8)
  59. #define LCD_TFT_MODE (1 << 7)
  60. #define LCD_V1_UNDERFLOW_INT_ENA (1 << 6)
  61. #define LCD_V2_UNDERFLOW_INT_ENA (1 << 5)
  62. #define LCD_V1_PL_INT_ENA (1 << 4)
  63. #define LCD_V2_PL_INT_ENA (1 << 6)
  64. #define LCD_MONOCHROME_MODE (1 << 1)
  65. #define LCD_RASTER_ENABLE (1 << 0)
  66. #define LCD_TFT_ALT_ENABLE (1 << 23)
  67. #define LCD_STN_565_ENABLE (1 << 24)
  68. #define LCD_V2_DMA_CLK_EN (1 << 2)
  69. #define LCD_V2_LIDD_CLK_EN (1 << 1)
  70. #define LCD_V2_CORE_CLK_EN (1 << 0)
  71. #define LCD_V2_LPP_B10 26
  72. #define LCD_V2_TFT_24BPP_MODE (1 << 25)
  73. #define LCD_V2_TFT_24BPP_UNPACK (1 << 26)
  74. /* LCD Raster Timing 2 Register */
  75. #define LCD_AC_BIAS_TRANSITIONS_PER_INT(x) ((x) << 16)
  76. #define LCD_AC_BIAS_FREQUENCY(x) ((x) << 8)
  77. #define LCD_SYNC_CTRL (1 << 25)
  78. #define LCD_SYNC_EDGE (1 << 24)
  79. #define LCD_INVERT_PIXEL_CLOCK (1 << 22)
  80. #define LCD_INVERT_LINE_CLOCK (1 << 21)
  81. #define LCD_INVERT_FRAME_CLOCK (1 << 20)
  82. /* Clock registers available only on Version 2 */
  83. #define LCD_CLK_MAIN_RESET (1 << 3)
  84. /* LCD Block */
  85. struct da8xx_lcd_regs {
  86. u32 revid;
  87. u32 ctrl;
  88. u32 stat;
  89. u32 lidd_ctrl;
  90. u32 lidd_cs0_conf;
  91. u32 lidd_cs0_addr;
  92. u32 lidd_cs0_data;
  93. u32 lidd_cs1_conf;
  94. u32 lidd_cs1_addr;
  95. u32 lidd_cs1_data;
  96. u32 raster_ctrl;
  97. u32 raster_timing_0;
  98. u32 raster_timing_1;
  99. u32 raster_timing_2;
  100. u32 raster_subpanel;
  101. u32 reserved;
  102. u32 dma_ctrl;
  103. u32 dma_frm_buf_base_addr_0;
  104. u32 dma_frm_buf_ceiling_addr_0;
  105. u32 dma_frm_buf_base_addr_1;
  106. u32 dma_frm_buf_ceiling_addr_1;
  107. u32 resv1;
  108. u32 raw_stat;
  109. u32 masked_stat;
  110. u32 int_ena_set;
  111. u32 int_ena_clr;
  112. u32 end_of_int_ind;
  113. /* Clock registers available only on Version 2 */
  114. u32 clk_ena;
  115. u32 clk_reset;
  116. };
  117. #define LCD_NUM_BUFFERS 1
  118. #define WSI_TIMEOUT 50
  119. #define PALETTE_SIZE 256
  120. #define LEFT_MARGIN 64
  121. #define RIGHT_MARGIN 64
  122. #define UPPER_MARGIN 32
  123. #define LOWER_MARGIN 32
  124. #define WAIT_FOR_FRAME_DONE true
  125. #define NO_WAIT_FOR_FRAME_DONE false
  126. #define calc_fbsize() (panel.plnSizeX * panel.plnSizeY * panel.gdfBytesPP)
  127. static struct da8xx_lcd_regs *da8xx_fb_reg_base;
  128. DECLARE_GLOBAL_DATA_PTR;
  129. /* graphics setup */
  130. static GraphicDevice gpanel;
  131. static const struct da8xx_panel *lcd_panel;
  132. static struct fb_info *da8xx_fb_info;
  133. static int bits_x_pixel;
  134. static unsigned int lcd_revision;
  135. const struct lcd_ctrl_config *da8xx_lcd_cfg;
  136. static inline unsigned int lcdc_read(u32 *addr)
  137. {
  138. return (unsigned int)readl(addr);
  139. }
  140. static inline void lcdc_write(unsigned int val, u32 *addr)
  141. {
  142. writel(val, addr);
  143. }
  144. struct da8xx_fb_par {
  145. u32 p_palette_base;
  146. unsigned char *v_palette_base;
  147. dma_addr_t vram_phys;
  148. unsigned long vram_size;
  149. void *vram_virt;
  150. unsigned int dma_start;
  151. unsigned int dma_end;
  152. struct clk *lcdc_clk;
  153. int irq;
  154. unsigned short pseudo_palette[16];
  155. unsigned int palette_sz;
  156. unsigned int pxl_clk;
  157. int blank;
  158. int vsync_flag;
  159. int vsync_timeout;
  160. };
  161. /* Variable Screen Information */
  162. static struct fb_var_screeninfo da8xx_fb_var = {
  163. .xoffset = 0,
  164. .yoffset = 0,
  165. .transp = {0, 0, 0},
  166. .nonstd = 0,
  167. .activate = 0,
  168. .height = -1,
  169. .width = -1,
  170. .pixclock = 46666, /* 46us - AUO display */
  171. .accel_flags = 0,
  172. .left_margin = LEFT_MARGIN,
  173. .right_margin = RIGHT_MARGIN,
  174. .upper_margin = UPPER_MARGIN,
  175. .lower_margin = LOWER_MARGIN,
  176. .sync = 0,
  177. .vmode = FB_VMODE_NONINTERLACED
  178. };
  179. static struct fb_fix_screeninfo da8xx_fb_fix = {
  180. .id = "DA8xx FB Drv",
  181. .type = FB_TYPE_PACKED_PIXELS,
  182. .type_aux = 0,
  183. .visual = FB_VISUAL_PSEUDOCOLOR,
  184. .xpanstep = 0,
  185. .ypanstep = 1,
  186. .ywrapstep = 0,
  187. .accel = FB_ACCEL_NONE
  188. };
  189. /* Enable the Raster Engine of the LCD Controller */
  190. static inline void lcd_enable_raster(void)
  191. {
  192. u32 reg;
  193. /* Put LCDC in reset for several cycles */
  194. if (lcd_revision == LCD_VERSION_2)
  195. lcdc_write(LCD_CLK_MAIN_RESET,
  196. &da8xx_fb_reg_base->clk_reset);
  197. udelay(1000);
  198. /* Bring LCDC out of reset */
  199. if (lcd_revision == LCD_VERSION_2)
  200. lcdc_write(0,
  201. &da8xx_fb_reg_base->clk_reset);
  202. udelay(1000);
  203. reg = lcdc_read(&da8xx_fb_reg_base->raster_ctrl);
  204. if (!(reg & LCD_RASTER_ENABLE))
  205. lcdc_write(reg | LCD_RASTER_ENABLE,
  206. &da8xx_fb_reg_base->raster_ctrl);
  207. }
  208. /* Disable the Raster Engine of the LCD Controller */
  209. static inline void lcd_disable_raster(bool wait_for_frame_done)
  210. {
  211. u32 reg;
  212. u32 loop_cnt = 0;
  213. u32 stat;
  214. u32 i = 0;
  215. if (wait_for_frame_done)
  216. loop_cnt = 5000;
  217. reg = lcdc_read(&da8xx_fb_reg_base->raster_ctrl);
  218. if (reg & LCD_RASTER_ENABLE)
  219. lcdc_write(reg & ~LCD_RASTER_ENABLE,
  220. &da8xx_fb_reg_base->raster_ctrl);
  221. /* Wait for the current frame to complete */
  222. do {
  223. if (lcd_revision == LCD_VERSION_1)
  224. stat = lcdc_read(&da8xx_fb_reg_base->stat);
  225. else
  226. stat = lcdc_read(&da8xx_fb_reg_base->raw_stat);
  227. mdelay(1);
  228. } while (!(stat & 0x01) && (i++ < loop_cnt));
  229. if (lcd_revision == LCD_VERSION_1)
  230. lcdc_write(stat, &da8xx_fb_reg_base->stat);
  231. else
  232. lcdc_write(stat, &da8xx_fb_reg_base->raw_stat);
  233. if ((loop_cnt != 0) && (i >= loop_cnt)) {
  234. printf("LCD Controller timed out\n");
  235. return;
  236. }
  237. }
  238. static void lcd_blit(int load_mode, struct da8xx_fb_par *par)
  239. {
  240. u32 start;
  241. u32 end;
  242. u32 reg_ras;
  243. u32 reg_dma;
  244. u32 reg_int;
  245. /* init reg to clear PLM (loading mode) fields */
  246. reg_ras = lcdc_read(&da8xx_fb_reg_base->raster_ctrl);
  247. reg_ras &= ~(3 << 20);
  248. reg_dma = lcdc_read(&da8xx_fb_reg_base->dma_ctrl);
  249. if (load_mode == LOAD_DATA) {
  250. start = par->dma_start;
  251. end = par->dma_end;
  252. reg_ras |= LCD_PALETTE_LOAD_MODE(DATA_ONLY);
  253. if (lcd_revision == LCD_VERSION_1) {
  254. reg_dma |= LCD_V1_END_OF_FRAME_INT_ENA;
  255. } else {
  256. reg_int = lcdc_read(&da8xx_fb_reg_base->int_ena_set) |
  257. LCD_V2_END_OF_FRAME0_INT_ENA |
  258. LCD_V2_END_OF_FRAME1_INT_ENA |
  259. LCD_V2_UNDERFLOW_INT_ENA | LCD_SYNC_LOST;
  260. lcdc_write(reg_int, &da8xx_fb_reg_base->int_ena_set);
  261. }
  262. #if (LCD_NUM_BUFFERS == 2)
  263. reg_dma |= LCD_DUAL_FRAME_BUFFER_ENABLE;
  264. lcdc_write(start, &da8xx_fb_reg_base->dma_frm_buf_base_addr_0);
  265. lcdc_write(end, &da8xx_fb_reg_base->dma_frm_buf_ceiling_addr_0);
  266. lcdc_write(start, &da8xx_fb_reg_base->dma_frm_buf_base_addr_1);
  267. lcdc_write(end, &da8xx_fb_reg_base->dma_frm_buf_ceiling_addr_1);
  268. #else
  269. reg_dma &= ~LCD_DUAL_FRAME_BUFFER_ENABLE;
  270. lcdc_write(start, &da8xx_fb_reg_base->dma_frm_buf_base_addr_0);
  271. lcdc_write(end, &da8xx_fb_reg_base->dma_frm_buf_ceiling_addr_0);
  272. lcdc_write(0, &da8xx_fb_reg_base->dma_frm_buf_base_addr_1);
  273. lcdc_write(0, &da8xx_fb_reg_base->dma_frm_buf_ceiling_addr_1);
  274. #endif
  275. } else if (load_mode == LOAD_PALETTE) {
  276. start = par->p_palette_base;
  277. end = start + par->palette_sz - 1;
  278. reg_ras |= LCD_PALETTE_LOAD_MODE(PALETTE_ONLY);
  279. if (lcd_revision == LCD_VERSION_1) {
  280. reg_ras |= LCD_V1_PL_INT_ENA;
  281. } else {
  282. reg_int = lcdc_read(&da8xx_fb_reg_base->int_ena_set) |
  283. LCD_V2_PL_INT_ENA;
  284. lcdc_write(reg_int, &da8xx_fb_reg_base->int_ena_set);
  285. }
  286. lcdc_write(start, &da8xx_fb_reg_base->dma_frm_buf_base_addr_0);
  287. lcdc_write(end, &da8xx_fb_reg_base->dma_frm_buf_ceiling_addr_0);
  288. }
  289. lcdc_write(reg_dma, &da8xx_fb_reg_base->dma_ctrl);
  290. lcdc_write(reg_ras, &da8xx_fb_reg_base->raster_ctrl);
  291. /*
  292. * The Raster enable bit must be set after all other control fields are
  293. * set.
  294. */
  295. lcd_enable_raster();
  296. }
  297. /* Configure the Burst Size of DMA */
  298. static int lcd_cfg_dma(int burst_size)
  299. {
  300. u32 reg;
  301. reg = lcdc_read(&da8xx_fb_reg_base->dma_ctrl) & 0x00000001;
  302. switch (burst_size) {
  303. case 1:
  304. reg |= LCD_DMA_BURST_SIZE(LCD_DMA_BURST_1);
  305. break;
  306. case 2:
  307. reg |= LCD_DMA_BURST_SIZE(LCD_DMA_BURST_2);
  308. break;
  309. case 4:
  310. reg |= LCD_DMA_BURST_SIZE(LCD_DMA_BURST_4);
  311. break;
  312. case 8:
  313. reg |= LCD_DMA_BURST_SIZE(LCD_DMA_BURST_8);
  314. break;
  315. case 16:
  316. reg |= LCD_DMA_BURST_SIZE(LCD_DMA_BURST_16);
  317. break;
  318. default:
  319. return -EINVAL;
  320. }
  321. lcdc_write(reg, &da8xx_fb_reg_base->dma_ctrl);
  322. return 0;
  323. }
  324. static void lcd_cfg_ac_bias(int period, int transitions_per_int)
  325. {
  326. u32 reg;
  327. /* Set the AC Bias Period and Number of Transitions per Interrupt */
  328. reg = lcdc_read(&da8xx_fb_reg_base->raster_timing_2) & 0xFFF00000;
  329. reg |= LCD_AC_BIAS_FREQUENCY(period) |
  330. LCD_AC_BIAS_TRANSITIONS_PER_INT(transitions_per_int);
  331. lcdc_write(reg, &da8xx_fb_reg_base->raster_timing_2);
  332. }
  333. static void lcd_cfg_horizontal_sync(int back_porch, int pulse_width,
  334. int front_porch)
  335. {
  336. u32 reg;
  337. reg = lcdc_read(&da8xx_fb_reg_base->raster_timing_0) & 0xf;
  338. reg |= ((back_porch & 0xff) << 24)
  339. | ((front_porch & 0xff) << 16)
  340. | ((pulse_width & 0x3f) << 10);
  341. lcdc_write(reg, &da8xx_fb_reg_base->raster_timing_0);
  342. }
  343. static void lcd_cfg_vertical_sync(int back_porch, int pulse_width,
  344. int front_porch)
  345. {
  346. u32 reg;
  347. reg = lcdc_read(&da8xx_fb_reg_base->raster_timing_1) & 0x3ff;
  348. reg |= ((back_porch & 0xff) << 24)
  349. | ((front_porch & 0xff) << 16)
  350. | ((pulse_width & 0x3f) << 10);
  351. lcdc_write(reg, &da8xx_fb_reg_base->raster_timing_1);
  352. }
  353. static int lcd_cfg_display(const struct lcd_ctrl_config *cfg)
  354. {
  355. u32 reg;
  356. u32 reg_int;
  357. reg = lcdc_read(&da8xx_fb_reg_base->raster_ctrl) & ~(LCD_TFT_MODE |
  358. LCD_MONO_8BIT_MODE |
  359. LCD_MONOCHROME_MODE);
  360. switch (cfg->p_disp_panel->panel_shade) {
  361. case MONOCHROME:
  362. reg |= LCD_MONOCHROME_MODE;
  363. if (cfg->mono_8bit_mode)
  364. reg |= LCD_MONO_8BIT_MODE;
  365. break;
  366. case COLOR_ACTIVE:
  367. reg |= LCD_TFT_MODE;
  368. if (cfg->tft_alt_mode)
  369. reg |= LCD_TFT_ALT_ENABLE;
  370. break;
  371. case COLOR_PASSIVE:
  372. if (cfg->stn_565_mode)
  373. reg |= LCD_STN_565_ENABLE;
  374. break;
  375. default:
  376. return -EINVAL;
  377. }
  378. /* enable additional interrupts here */
  379. if (lcd_revision == LCD_VERSION_1) {
  380. reg |= LCD_V1_UNDERFLOW_INT_ENA;
  381. } else {
  382. reg_int = lcdc_read(&da8xx_fb_reg_base->int_ena_set) |
  383. LCD_V2_UNDERFLOW_INT_ENA;
  384. lcdc_write(reg_int, &da8xx_fb_reg_base->int_ena_set);
  385. }
  386. lcdc_write(reg, &da8xx_fb_reg_base->raster_ctrl);
  387. reg = lcdc_read(&da8xx_fb_reg_base->raster_timing_2);
  388. if (cfg->sync_ctrl)
  389. reg |= LCD_SYNC_CTRL;
  390. else
  391. reg &= ~LCD_SYNC_CTRL;
  392. if (cfg->sync_edge)
  393. reg |= LCD_SYNC_EDGE;
  394. else
  395. reg &= ~LCD_SYNC_EDGE;
  396. if (cfg->invert_line_clock)
  397. reg |= LCD_INVERT_LINE_CLOCK;
  398. else
  399. reg &= ~LCD_INVERT_LINE_CLOCK;
  400. if (cfg->invert_frm_clock)
  401. reg |= LCD_INVERT_FRAME_CLOCK;
  402. else
  403. reg &= ~LCD_INVERT_FRAME_CLOCK;
  404. lcdc_write(reg, &da8xx_fb_reg_base->raster_timing_2);
  405. return 0;
  406. }
  407. static int lcd_cfg_frame_buffer(struct da8xx_fb_par *par, u32 width, u32 height,
  408. u32 bpp, u32 raster_order)
  409. {
  410. u32 reg;
  411. /* Set the Panel Width */
  412. /* Pixels per line = (PPL + 1)*16 */
  413. if (lcd_revision == LCD_VERSION_1) {
  414. /*
  415. * 0x3F in bits 4..9 gives max horizontal resolution = 1024
  416. * pixels
  417. */
  418. width &= 0x3f0;
  419. } else {
  420. /*
  421. * 0x7F in bits 4..10 gives max horizontal resolution = 2048
  422. * pixels.
  423. */
  424. width &= 0x7f0;
  425. }
  426. reg = lcdc_read(&da8xx_fb_reg_base->raster_timing_0);
  427. reg &= 0xfffffc00;
  428. if (lcd_revision == LCD_VERSION_1) {
  429. reg |= ((width >> 4) - 1) << 4;
  430. } else {
  431. width = (width >> 4) - 1;
  432. reg |= ((width & 0x3f) << 4) | ((width & 0x40) >> 3);
  433. }
  434. lcdc_write(reg, &da8xx_fb_reg_base->raster_timing_0);
  435. /* Set the Panel Height */
  436. /* Set bits 9:0 of Lines Per Pixel */
  437. reg = lcdc_read(&da8xx_fb_reg_base->raster_timing_1);
  438. reg = ((height - 1) & 0x3ff) | (reg & 0xfffffc00);
  439. lcdc_write(reg, &da8xx_fb_reg_base->raster_timing_1);
  440. /* Set bit 10 of Lines Per Pixel */
  441. if (lcd_revision == LCD_VERSION_2) {
  442. reg = lcdc_read(&da8xx_fb_reg_base->raster_timing_2);
  443. reg |= ((height - 1) & 0x400) << 16;
  444. lcdc_write(reg, &da8xx_fb_reg_base->raster_timing_2);
  445. }
  446. /* Set the Raster Order of the Frame Buffer */
  447. reg = lcdc_read(&da8xx_fb_reg_base->raster_ctrl) & ~(1 << 8);
  448. if (raster_order)
  449. reg |= LCD_RASTER_ORDER;
  450. if (bpp == 24)
  451. reg |= (LCD_TFT_MODE | LCD_V2_TFT_24BPP_MODE);
  452. else if (bpp == 32)
  453. reg |= (LCD_TFT_MODE | LCD_V2_TFT_24BPP_MODE
  454. | LCD_V2_TFT_24BPP_UNPACK);
  455. lcdc_write(reg, &da8xx_fb_reg_base->raster_ctrl);
  456. switch (bpp) {
  457. case 1:
  458. case 2:
  459. case 4:
  460. case 16:
  461. case 24:
  462. case 32:
  463. par->palette_sz = 16 * 2;
  464. break;
  465. case 8:
  466. par->palette_sz = 256 * 2;
  467. break;
  468. default:
  469. return -EINVAL;
  470. }
  471. return 0;
  472. }
  473. static int fb_setcolreg(unsigned regno, unsigned red, unsigned green,
  474. unsigned blue, unsigned transp,
  475. struct fb_info *info)
  476. {
  477. struct da8xx_fb_par *par = info->par;
  478. unsigned short *palette = (unsigned short *) par->v_palette_base;
  479. u_short pal;
  480. int update_hw = 0;
  481. if (regno > 255)
  482. return 1;
  483. if (info->fix.visual == FB_VISUAL_DIRECTCOLOR)
  484. return 1;
  485. if (info->var.bits_per_pixel == 8) {
  486. red >>= 4;
  487. green >>= 8;
  488. blue >>= 12;
  489. pal = (red & 0x0f00);
  490. pal |= (green & 0x00f0);
  491. pal |= (blue & 0x000f);
  492. if (palette[regno] != pal) {
  493. update_hw = 1;
  494. palette[regno] = pal;
  495. }
  496. } else if ((info->var.bits_per_pixel == 16) && regno < 16) {
  497. red >>= (16 - info->var.red.length);
  498. red <<= info->var.red.offset;
  499. green >>= (16 - info->var.green.length);
  500. green <<= info->var.green.offset;
  501. blue >>= (16 - info->var.blue.length);
  502. blue <<= info->var.blue.offset;
  503. par->pseudo_palette[regno] = red | green | blue;
  504. if (palette[0] != 0x4000) {
  505. update_hw = 1;
  506. palette[0] = 0x4000;
  507. }
  508. } else if (((info->var.bits_per_pixel == 32) && regno < 32) ||
  509. ((info->var.bits_per_pixel == 24) && regno < 24)) {
  510. red >>= (24 - info->var.red.length);
  511. red <<= info->var.red.offset;
  512. green >>= (24 - info->var.green.length);
  513. green <<= info->var.green.offset;
  514. blue >>= (24 - info->var.blue.length);
  515. blue <<= info->var.blue.offset;
  516. par->pseudo_palette[regno] = red | green | blue;
  517. if (palette[0] != 0x4000) {
  518. update_hw = 1;
  519. palette[0] = 0x4000;
  520. }
  521. }
  522. /* Update the palette in the h/w as needed. */
  523. if (update_hw)
  524. lcd_blit(LOAD_PALETTE, par);
  525. return 0;
  526. }
  527. static void lcd_reset(struct da8xx_fb_par *par)
  528. {
  529. /* Disable the Raster if previously Enabled */
  530. lcd_disable_raster(NO_WAIT_FOR_FRAME_DONE);
  531. /* DMA has to be disabled */
  532. lcdc_write(0, &da8xx_fb_reg_base->dma_ctrl);
  533. lcdc_write(0, &da8xx_fb_reg_base->raster_ctrl);
  534. if (lcd_revision == LCD_VERSION_2) {
  535. lcdc_write(0, &da8xx_fb_reg_base->int_ena_set);
  536. /* Write 1 to reset */
  537. lcdc_write(LCD_CLK_MAIN_RESET, &da8xx_fb_reg_base->clk_reset);
  538. lcdc_write(0, &da8xx_fb_reg_base->clk_reset);
  539. }
  540. }
  541. static void lcd_calc_clk_divider(struct da8xx_fb_par *par)
  542. {
  543. unsigned int lcd_clk, div;
  544. /* Get clock from sysclk2 */
  545. lcd_clk = clk_get(2);
  546. div = lcd_clk / par->pxl_clk;
  547. debug("LCD Clock: %d Divider: %d PixClk: %d\n",
  548. lcd_clk, div, par->pxl_clk);
  549. /* Configure the LCD clock divisor. */
  550. lcdc_write(LCD_CLK_DIVISOR(div) |
  551. (LCD_RASTER_MODE & 0x1), &da8xx_fb_reg_base->ctrl);
  552. if (lcd_revision == LCD_VERSION_2)
  553. lcdc_write(LCD_V2_DMA_CLK_EN | LCD_V2_LIDD_CLK_EN |
  554. LCD_V2_CORE_CLK_EN,
  555. &da8xx_fb_reg_base->clk_ena);
  556. }
  557. static int lcd_init(struct da8xx_fb_par *par, const struct lcd_ctrl_config *cfg,
  558. const struct da8xx_panel *panel)
  559. {
  560. u32 bpp;
  561. int ret = 0;
  562. lcd_reset(par);
  563. /* Calculate the divider */
  564. lcd_calc_clk_divider(par);
  565. if (panel->invert_pxl_clk)
  566. lcdc_write((lcdc_read(&da8xx_fb_reg_base->raster_timing_2) |
  567. LCD_INVERT_PIXEL_CLOCK),
  568. &da8xx_fb_reg_base->raster_timing_2);
  569. else
  570. lcdc_write((lcdc_read(&da8xx_fb_reg_base->raster_timing_2) &
  571. ~LCD_INVERT_PIXEL_CLOCK),
  572. &da8xx_fb_reg_base->raster_timing_2);
  573. /* Configure the DMA burst size. */
  574. ret = lcd_cfg_dma(cfg->dma_burst_sz);
  575. if (ret < 0)
  576. return ret;
  577. /* Configure the AC bias properties. */
  578. lcd_cfg_ac_bias(cfg->ac_bias, cfg->ac_bias_intrpt);
  579. /* Configure the vertical and horizontal sync properties. */
  580. lcd_cfg_vertical_sync(panel->vbp, panel->vsw, panel->vfp);
  581. lcd_cfg_horizontal_sync(panel->hbp, panel->hsw, panel->hfp);
  582. /* Configure for display */
  583. ret = lcd_cfg_display(cfg);
  584. if (ret < 0)
  585. return ret;
  586. if ((QVGA != cfg->p_disp_panel->panel_type) &&
  587. (WVGA != cfg->p_disp_panel->panel_type))
  588. return -EINVAL;
  589. if (cfg->bpp <= cfg->p_disp_panel->max_bpp &&
  590. cfg->bpp >= cfg->p_disp_panel->min_bpp)
  591. bpp = cfg->bpp;
  592. else
  593. bpp = cfg->p_disp_panel->max_bpp;
  594. if (bpp == 12)
  595. bpp = 16;
  596. ret = lcd_cfg_frame_buffer(par, (unsigned int)panel->width,
  597. (unsigned int)panel->height, bpp,
  598. cfg->raster_order);
  599. if (ret < 0)
  600. return ret;
  601. /* Configure FDD */
  602. lcdc_write((lcdc_read(&da8xx_fb_reg_base->raster_ctrl) & 0xfff00fff) |
  603. (cfg->fdd << 12), &da8xx_fb_reg_base->raster_ctrl);
  604. return 0;
  605. }
  606. static void lcdc_dma_start(void)
  607. {
  608. struct da8xx_fb_par *par = da8xx_fb_info->par;
  609. lcdc_write(par->dma_start,
  610. &da8xx_fb_reg_base->dma_frm_buf_base_addr_0);
  611. lcdc_write(par->dma_end,
  612. &da8xx_fb_reg_base->dma_frm_buf_ceiling_addr_0);
  613. lcdc_write(0,
  614. &da8xx_fb_reg_base->dma_frm_buf_base_addr_1);
  615. lcdc_write(0,
  616. &da8xx_fb_reg_base->dma_frm_buf_ceiling_addr_1);
  617. }
  618. static u32 lcdc_irq_handler_rev01(void)
  619. {
  620. struct da8xx_fb_par *par = da8xx_fb_info->par;
  621. u32 stat = lcdc_read(&da8xx_fb_reg_base->stat);
  622. u32 reg_ras;
  623. if ((stat & LCD_SYNC_LOST) && (stat & LCD_FIFO_UNDERFLOW)) {
  624. debug("LCD_SYNC_LOST\n");
  625. lcd_disable_raster(NO_WAIT_FOR_FRAME_DONE);
  626. lcdc_write(stat, &da8xx_fb_reg_base->stat);
  627. lcd_enable_raster();
  628. return LCD_SYNC_LOST;
  629. } else if (stat & LCD_PL_LOAD_DONE) {
  630. debug("LCD_PL_LOAD_DONE\n");
  631. /*
  632. * Must disable raster before changing state of any control bit.
  633. * And also must be disabled before clearing the PL loading
  634. * interrupt via the following write to the status register. If
  635. * this is done after then one gets multiple PL done interrupts.
  636. */
  637. lcd_disable_raster(NO_WAIT_FOR_FRAME_DONE);
  638. lcdc_write(stat, &da8xx_fb_reg_base->stat);
  639. /* Disable PL completion interrupt */
  640. reg_ras = lcdc_read(&da8xx_fb_reg_base->raster_ctrl);
  641. reg_ras &= ~LCD_V1_PL_INT_ENA;
  642. lcdc_write(reg_ras, &da8xx_fb_reg_base->raster_ctrl);
  643. /* Setup and start data loading mode */
  644. lcd_blit(LOAD_DATA, par);
  645. return LCD_PL_LOAD_DONE;
  646. } else {
  647. lcdc_write(stat, &da8xx_fb_reg_base->stat);
  648. if (stat & LCD_END_OF_FRAME0)
  649. debug("LCD_END_OF_FRAME0\n");
  650. lcdc_write(par->dma_start,
  651. &da8xx_fb_reg_base->dma_frm_buf_base_addr_0);
  652. lcdc_write(par->dma_end,
  653. &da8xx_fb_reg_base->dma_frm_buf_ceiling_addr_0);
  654. par->vsync_flag = 1;
  655. return LCD_END_OF_FRAME0;
  656. }
  657. return stat;
  658. }
  659. static u32 lcdc_irq_handler_rev02(void)
  660. {
  661. struct da8xx_fb_par *par = da8xx_fb_info->par;
  662. u32 stat = lcdc_read(&da8xx_fb_reg_base->masked_stat);
  663. u32 reg_int;
  664. if ((stat & LCD_SYNC_LOST) && (stat & LCD_FIFO_UNDERFLOW)) {
  665. debug("LCD_SYNC_LOST\n");
  666. lcd_disable_raster(NO_WAIT_FOR_FRAME_DONE);
  667. lcdc_write(stat, &da8xx_fb_reg_base->masked_stat);
  668. lcd_enable_raster();
  669. lcdc_write(0, &da8xx_fb_reg_base->end_of_int_ind);
  670. return LCD_SYNC_LOST;
  671. } else if (stat & LCD_PL_LOAD_DONE) {
  672. debug("LCD_PL_LOAD_DONE\n");
  673. /*
  674. * Must disable raster before changing state of any control bit.
  675. * And also must be disabled before clearing the PL loading
  676. * interrupt via the following write to the status register. If
  677. * this is done after then one gets multiple PL done interrupts.
  678. */
  679. lcd_disable_raster(NO_WAIT_FOR_FRAME_DONE);
  680. lcdc_write(stat, &da8xx_fb_reg_base->masked_stat);
  681. /* Disable PL completion interrupt */
  682. reg_int = lcdc_read(&da8xx_fb_reg_base->int_ena_clr) |
  683. (LCD_V2_PL_INT_ENA);
  684. lcdc_write(reg_int, &da8xx_fb_reg_base->int_ena_clr);
  685. /* Setup and start data loading mode */
  686. lcd_blit(LOAD_DATA, par);
  687. lcdc_write(0, &da8xx_fb_reg_base->end_of_int_ind);
  688. return LCD_PL_LOAD_DONE;
  689. } else {
  690. lcdc_write(stat, &da8xx_fb_reg_base->masked_stat);
  691. if (stat & LCD_END_OF_FRAME0)
  692. debug("LCD_END_OF_FRAME0\n");
  693. lcdc_write(par->dma_start,
  694. &da8xx_fb_reg_base->dma_frm_buf_base_addr_0);
  695. lcdc_write(par->dma_end,
  696. &da8xx_fb_reg_base->dma_frm_buf_ceiling_addr_0);
  697. par->vsync_flag = 1;
  698. lcdc_write(0, &da8xx_fb_reg_base->end_of_int_ind);
  699. return LCD_END_OF_FRAME0;
  700. }
  701. lcdc_write(0, &da8xx_fb_reg_base->end_of_int_ind);
  702. return stat;
  703. }
  704. static u32 lcdc_irq_handler(void)
  705. {
  706. if (lcd_revision == LCD_VERSION_1)
  707. return lcdc_irq_handler_rev01();
  708. else
  709. return lcdc_irq_handler_rev02();
  710. }
  711. static u32 wait_for_event(u32 event)
  712. {
  713. u32 timeout = 50000;
  714. u32 ret;
  715. do {
  716. ret = lcdc_irq_handler();
  717. udelay(1000);
  718. --timeout;
  719. } while (!(ret & event) && timeout);
  720. if (!(ret & event)) {
  721. printf("%s: event %d not hit\n", __func__, event);
  722. return -1;
  723. }
  724. return 0;
  725. }
  726. void *video_hw_init(void)
  727. {
  728. struct da8xx_fb_par *par;
  729. u32 size;
  730. u32 rev;
  731. char *p;
  732. if (!lcd_panel) {
  733. printf("Display not initialized\n");
  734. return NULL;
  735. }
  736. gpanel.winSizeX = lcd_panel->width;
  737. gpanel.winSizeY = lcd_panel->height;
  738. gpanel.plnSizeX = lcd_panel->width;
  739. gpanel.plnSizeY = lcd_panel->height;
  740. switch (bits_x_pixel) {
  741. case 32:
  742. gpanel.gdfBytesPP = 4;
  743. gpanel.gdfIndex = GDF_32BIT_X888RGB;
  744. break;
  745. case 24:
  746. gpanel.gdfBytesPP = 4;
  747. gpanel.gdfIndex = GDF_32BIT_X888RGB;
  748. break;
  749. case 16:
  750. gpanel.gdfBytesPP = 2;
  751. gpanel.gdfIndex = GDF_16BIT_565RGB;
  752. break;
  753. default:
  754. gpanel.gdfBytesPP = 1;
  755. gpanel.gdfIndex = GDF__8BIT_INDEX;
  756. break;
  757. }
  758. da8xx_fb_reg_base = (struct da8xx_lcd_regs *)DA8XX_LCD_CNTL_BASE;
  759. /* Determine LCD IP Version */
  760. rev = lcdc_read(&da8xx_fb_reg_base->revid);
  761. switch (rev) {
  762. case 0x4C100102:
  763. lcd_revision = LCD_VERSION_1;
  764. break;
  765. case 0x4F200800:
  766. case 0x4F201000:
  767. lcd_revision = LCD_VERSION_2;
  768. break;
  769. default:
  770. printf("Unknown PID Reg value 0x%x, defaulting to LCD revision 1\n",
  771. rev);
  772. lcd_revision = LCD_VERSION_1;
  773. break;
  774. }
  775. debug("rev: 0x%x Resolution: %dx%d %d\n", rev,
  776. gpanel.winSizeX,
  777. gpanel.winSizeY,
  778. da8xx_lcd_cfg->bpp);
  779. size = sizeof(struct fb_info) + sizeof(struct da8xx_fb_par);
  780. da8xx_fb_info = malloc_cache_aligned(size);
  781. debug("da8xx_fb_info at %x\n", (unsigned int)da8xx_fb_info);
  782. if (!da8xx_fb_info) {
  783. printf("Memory allocation failed for fb_info\n");
  784. return NULL;
  785. }
  786. memset(da8xx_fb_info, 0, size);
  787. p = (char *)da8xx_fb_info;
  788. da8xx_fb_info->par = p + sizeof(struct fb_info);
  789. debug("da8xx_par at %x\n", (unsigned int)da8xx_fb_info->par);
  790. par = da8xx_fb_info->par;
  791. par->pxl_clk = lcd_panel->pxl_clk;
  792. if (lcd_init(par, da8xx_lcd_cfg, lcd_panel) < 0) {
  793. printf("lcd_init failed\n");
  794. goto err_release_fb;
  795. }
  796. /* allocate frame buffer */
  797. par->vram_size = lcd_panel->width * lcd_panel->height *
  798. da8xx_lcd_cfg->bpp;
  799. par->vram_size = par->vram_size * LCD_NUM_BUFFERS / 8;
  800. par->vram_virt = malloc_cache_aligned(par->vram_size);
  801. par->vram_phys = (dma_addr_t) par->vram_virt;
  802. debug("Requesting 0x%x bytes for framebuffer at 0x%x\n",
  803. (unsigned int)par->vram_size,
  804. (unsigned int)par->vram_virt);
  805. if (!par->vram_virt) {
  806. printf("GLCD: malloc for frame buffer failed\n");
  807. goto err_release_fb;
  808. }
  809. gd->fb_base = (int)par->vram_virt;
  810. gpanel.frameAdrs = (unsigned int)par->vram_virt;
  811. da8xx_fb_info->screen_base = (char *) par->vram_virt;
  812. da8xx_fb_fix.smem_start = gpanel.frameAdrs;
  813. da8xx_fb_fix.smem_len = par->vram_size;
  814. da8xx_fb_fix.line_length = (lcd_panel->width * da8xx_lcd_cfg->bpp) / 8;
  815. par->dma_start = par->vram_phys;
  816. par->dma_end = par->dma_start + lcd_panel->height *
  817. da8xx_fb_fix.line_length - 1;
  818. /* allocate palette buffer */
  819. par->v_palette_base = malloc_cache_aligned(PALETTE_SIZE);
  820. if (!par->v_palette_base) {
  821. printf("GLCD: malloc for palette buffer failed\n");
  822. goto err_release_fb_mem;
  823. }
  824. memset(par->v_palette_base, 0, PALETTE_SIZE);
  825. par->p_palette_base = (unsigned int)par->v_palette_base;
  826. /* Initialize par */
  827. da8xx_fb_info->var.bits_per_pixel = da8xx_lcd_cfg->bpp;
  828. da8xx_fb_var.xres = lcd_panel->width;
  829. da8xx_fb_var.xres_virtual = lcd_panel->width;
  830. da8xx_fb_var.yres = lcd_panel->height;
  831. da8xx_fb_var.yres_virtual = lcd_panel->height * LCD_NUM_BUFFERS;
  832. da8xx_fb_var.grayscale =
  833. da8xx_lcd_cfg->p_disp_panel->panel_shade == MONOCHROME ? 1 : 0;
  834. da8xx_fb_var.bits_per_pixel = da8xx_lcd_cfg->bpp;
  835. da8xx_fb_var.hsync_len = lcd_panel->hsw;
  836. da8xx_fb_var.vsync_len = lcd_panel->vsw;
  837. /* Initialize fbinfo */
  838. da8xx_fb_info->flags = FBINFO_FLAG_DEFAULT;
  839. da8xx_fb_info->fix = da8xx_fb_fix;
  840. da8xx_fb_info->var = da8xx_fb_var;
  841. da8xx_fb_info->pseudo_palette = par->pseudo_palette;
  842. da8xx_fb_info->fix.visual = (da8xx_fb_info->var.bits_per_pixel <= 8) ?
  843. FB_VISUAL_PSEUDOCOLOR : FB_VISUAL_TRUECOLOR;
  844. /* Clear interrupt */
  845. memset((void *)par->vram_virt, 0, par->vram_size);
  846. lcd_disable_raster(NO_WAIT_FOR_FRAME_DONE);
  847. if (lcd_revision == LCD_VERSION_1)
  848. lcdc_write(0xFFFF, &da8xx_fb_reg_base->stat);
  849. else
  850. lcdc_write(0xFFFF, &da8xx_fb_reg_base->masked_stat);
  851. debug("Palette at 0x%x size %d\n", par->p_palette_base,
  852. par->palette_sz);
  853. lcdc_dma_start();
  854. /* Load a default palette */
  855. fb_setcolreg(0, 0, 0, 0, 0xffff, da8xx_fb_info);
  856. /* Check that the palette is loaded */
  857. wait_for_event(LCD_PL_LOAD_DONE);
  858. /* Wait until DMA is working */
  859. wait_for_event(LCD_END_OF_FRAME0);
  860. return (void *)&gpanel;
  861. err_release_fb_mem:
  862. free(par->vram_virt);
  863. err_release_fb:
  864. free(da8xx_fb_info);
  865. return NULL;
  866. }
  867. void da8xx_video_init(const struct da8xx_panel *panel,
  868. const struct lcd_ctrl_config *lcd_cfg, int bits_pixel)
  869. {
  870. lcd_panel = panel;
  871. da8xx_lcd_cfg = lcd_cfg;
  872. bits_x_pixel = bits_pixel;
  873. }