annotate src/cs/drivers/drv_app/r2d/lcds/luna/r2d_task_i.c @ 650:7d6878435c85

R2D: Luna LCD driver implemented
author Mychaela Falconia <falcon@freecalypso.org>
date Thu, 07 May 2020 07:32:27 +0000
parents
children 8c0bd0b6447c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
650
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
1 #include "r2d/lcds/luna/r2d_luna_lcd.h"
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
2 #include "rvm/rvm_use_id_list.h"
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
3
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
4 void r2d_lcd_power_on(void)
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
5 {
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
6 }
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
7
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
8 void r2d_lcd_power_off(void)
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
9 {
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
10 }
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
11
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
12 void r2d_refresh(void)
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
13 {
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
14 UINT16 i,j;
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
15 UINT32 v;
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
16 UINT32 *p;
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
17 INT16 x1,x2,y1,y2,de,ds;
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
18
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
19 p=r2d_g_framebuffer->p_memory_words;
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
20
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
21 x1=(r2d_update_ul_x>>1)<<1; //0
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
22 x2=((r2d_update_br_x>>1)<<1)+1; //174;
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
23
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
24 ds=(x1>>1);
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
25 de=R2D_MWWIDTH-(x2>>1)-1; // WHY -1, is formula right ????
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
26
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
27 y1=r2d_update_ul_y; //0
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
28 y2=r2d_update_br_y; //219
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
29
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
30 /* set window area */
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
31 LCD_REG_WR(0x36, x2);
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
32 LCD_REG_WR(0x37, x1);
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
33 LCD_REG_WR(0x38, y2);
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
34 LCD_REG_WR(0x39, y1);
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
35 /* set current write address */
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
36 LCD_REG_WR(0x20, x1);
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
37 LCD_REG_WR(0x21, y1);
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
38 /* set up for GRAM write */
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
39 LCD_IR = 0x22;
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
40
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
41 p=p+y1*R2D_MWWIDTH;
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
42
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
43 for(i=y1;i<=y2;i++)
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
44 {
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
45 p+=ds;
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
46 for(j=(x1>>1);j<=(x2>>1);j++)
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
47 {
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
48 v=*p++;
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
49 v=~v;
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
50
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
51 /*white*/
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
52 /*v=0xffffffff*/
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
53 /*black*/
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
54 /*v=0x00000000*/
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
55
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
56 LCD_DR = v&0x0FFFF;
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
57 LCD_DR = v>>16;
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
58 }
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
59 p+=de;
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
60 }
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
61
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
62 r2d_check_and_send_event(r2d_g_framebuffer);
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
63 r2d_reinit_update_region();
7d6878435c85 R2D: Luna LCD driver implemented
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff changeset
64 }