changeset 131:384fbd61c252

src/cs/drivers/drv_app/r2d/lcds/c139: import from tcs211-c139
author Mychaela Falconia <falcon@freecalypso.org>
date Fri, 07 Oct 2016 22:04:02 +0000
parents a0c5d28798fe
children b8fc86826624
files src/cs/drivers/drv_app/r2d/lcds/c139/colors.h src/cs/drivers/drv_app/r2d/lcds/c139/r2d_task_i.c src/cs/drivers/drv_app/r2d/lcds/c139/r2d_task_init_i.c
diffstat 3 files changed, 147 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/cs/drivers/drv_app/r2d/lcds/c139/colors.h	Fri Oct 07 22:04:02 2016 +0000
@@ -0,0 +1,16 @@
+/*
+ * TI's BMI code does not seem to have an existing configuration for small
+ * color displays, only large color, large mono and small mono - hence in the
+ * present configuration we are telling TI's code that we have a mono display.
+ * But the real LCD on the C139 is 16-bit color.  Here we define the physical
+ * color values to which TI's black and white will be mapped.
+ *
+ * We are also pretending to be the 84x48 pix LCD on TI's C-Sample, hence we
+ * are displaying a 84x48 pix UI on a physical 96x64 pix LCD.  We center the
+ * virtual display in the physical one, and the border color is defined here
+ * as well.
+ */
+
+#define	LCD16_COLOR_BLACK	0x0000
+#define	LCD16_COLOR_WHITE	0xFFFF
+#define	LCD16_COLOR_BORDER	0x5555
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/cs/drivers/drv_app/r2d/lcds/c139/r2d_task_i.c	Fri Oct 07 22:04:02 2016 +0000
@@ -0,0 +1,80 @@
+#include "r2d/lcds/c139/colors.h"
+
+void c139_uwire_xmit(UINT16 cmd)
+{
+	* (volatile UINT16 *) TDR = cmd << 7;
+	* (volatile UINT16 *) CSR |= NB_BITS_WR_9 + CS_CMD + START ; // transmit command data
+	while (((* (volatile UINT16 *) CSR) & CSRB) != 0 ); // wait for end of WRITE
+	* (volatile UINT16 *) CSR &= ~CS_CMD; // clears Chip Select 	
+}
+
+void c139_lcd_ctrl_cmd(UINT8 cmd, UINT8 param)
+{
+	c139_uwire_xmit(cmd);
+	c139_uwire_xmit(param | 0x100);
+}
+
+void c139_set_lcd_addr_region(UINT8 xstart, UINT8 xend,
+				UINT8 ystart, UINT8 yend)
+{
+	c139_lcd_ctrl_cmd(0x10, xstart);
+	c139_lcd_ctrl_cmd(0x11, ystart);
+	c139_lcd_ctrl_cmd(0x12, xend);
+	c139_lcd_ctrl_cmd(0x13, yend);
+	c139_lcd_ctrl_cmd(0x14, xstart);
+	c139_lcd_ctrl_cmd(0x15, ystart);
+}
+
+void c139_lcd_send_pix(UINT16 pixval)
+{
+	c139_uwire_xmit((pixval >> 8) | 0x100);
+	c139_uwire_xmit((pixval & 0xFF) | 0x100);
+}
+
+void r2d_lcd_power_on(void)
+{
+}
+
+void r2d_lcd_power_off(void)
+{
+}
+
+static int get_pix_from_sw_fb(UINT32 *fb, UINT16 x, UINT16 y)
+{
+	UINT32 *p, mask;
+	UINT16 yword, ybit;
+
+	/* mirroring */
+	x = R2D_WIDTH - x;
+	y = R2D_HEIGHT - y;
+	yword = y >> 5;
+	ybit = y & 31;
+	p = fb + x * R2D_MWHEIGHT + yword;
+	mask = 1 << ybit;
+	if (*p & mask)
+		return(1);
+	else
+		return(0);
+}
+
+void r2d_refresh(void)
+{
+	UINT16 x, y;
+	UINT32 *fb;
+
+	fb = r2d_g_framebuffer->p_memory_words;
+
+	/* set the LCD up to refresh the 84x48 area */
+	c139_set_lcd_addr_region(6, 89, 8, 55);
+	/* send the pixels */
+	for (y = 0; y < R2D_HEIGHT; y++) {
+		for (x = 0; x < R2D_WIDTH; x++) {
+			if (get_pix_from_sw_fb(fb, x, y))
+				c139_lcd_send_pix(LCD16_COLOR_BLACK);
+			else
+				c139_lcd_send_pix(LCD16_COLOR_WHITE);
+		}
+	}
+
+	r2d_reinit_update_region();
+}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/cs/drivers/drv_app/r2d/lcds/c139/r2d_task_init_i.c	Fri Oct 07 22:04:02 2016 +0000
@@ -0,0 +1,51 @@
+#include "r2d/lcds/c139/colors.h"
+
+#define R2D_MB_PRIM_SIZE 2000
+
+extern void c139_lcd_ctrl_cmd(UINT8 cmd, UINT8 param);
+extern void c139_set_lcd_addr_region(UINT8 xstart, UINT8 xend,
+					UINT8 ystart, UINT8 yend);
+extern void c139_lcd_send_pix(UINT16 pixval);
+
+void uwire_init_lcd(void)
+{
+	* ( UINT16 *) CNTL_RST &= ~(0x04); // releases reset_out
+	* ( UINT16 *) CNTL_RST |= (0x04); // set reset_out to 0
+	rvf_delay(RVF_MS_TO_TICKS(5));    // waits for 5 ms
+	* ( UINT16 *) CNTL_RST &= ~(0x04); // releases reset_out
+
+	* (volatile UINT16 *) SR1 = CS0_FRQ_FINT_2;
+	* (volatile UINT16 *) SR3 = SR3_CLK_EN; // enables the uwire clock
+	* (volatile UINT16 *) CSR = INDEX_CS0; // selects CS0
+}
+
+static void r2d_refresh_task_init(void)
+{
+	UINT16 i;
+
+	uwire_init_lcd();
+	rvf_delay(RVF_MS_TO_TICKS(5));    // waits for 5 ms
+
+	/* LCD controller init */
+	c139_lcd_ctrl_cmd(0x3F, 0x01);
+	c139_lcd_ctrl_cmd(0x20, 0x03);
+	c139_lcd_ctrl_cmd(0x31, 0x03);
+
+	/* initial hw framebuffer clearing */
+	c139_set_lcd_addr_region(0, 95, 0, 63);
+	for (i = 0; i < 96 * 64; i++)
+		c139_lcd_send_pix(LCD16_COLOR_BORDER);
+}
+
+static void r2d_refresh_task_kill(void)
+{
+}
+
+static void r2d_dithering_init(void)
+{
+   R2D_MALLOC(r2d_mb_id,UINT32,sizeof(UINT32)*4,r2d_g_dithering_matrix);
+   r2d_g_dithering_matrix[0]=0;
+   r2d_g_dithering_matrix[1]=2;
+   r2d_g_dithering_matrix[2]=3;
+   r2d_g_dithering_matrix[3]=1;
+}