summaryrefslogtreecommitdiffstats
path: root/firmware
diff options
context:
space:
mode:
authorMichael Sevakis <jethead71@rockbox.org>2007-05-01 19:21:27 +0000
committerMichael Sevakis <jethead71@rockbox.org>2007-05-01 19:21:27 +0000
commit4e24bb9976d454616814c4831898022e8274f556 (patch)
treed3b6d3cd91790c6e6ab45c820b89f2b5237304f8 /firmware
parent34cb104289674fc66464d194f6aab65ee31722af (diff)
downloadrockbox-4e24bb9976d454616814c4831898022e8274f556.tar.gz
rockbox-4e24bb9976d454616814c4831898022e8274f556.zip
e200: Add register defines for the LCD driver IC.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@13300 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'firmware')
-rw-r--r--firmware/target/arm/sandisk/sansa-e200/lcd-e200.c139
1 files changed, 93 insertions, 46 deletions
diff --git a/firmware/target/arm/sandisk/sansa-e200/lcd-e200.c b/firmware/target/arm/sandisk/sansa-e200/lcd-e200.c
index 07bc72c3c1..8dc8ad95e9 100644
--- a/firmware/target/arm/sandisk/sansa-e200/lcd-e200.c
+++ b/firmware/target/arm/sandisk/sansa-e200/lcd-e200.c
@@ -50,6 +50,47 @@
#define LCD_REG_9 (*(volatile unsigned long *)(0xc2000024))
#define LCD_FB_BASE_REG (*(volatile unsigned long *)(0xc2000028))
+/* Taken from HD66789 datasheet and seems similar enough.
+ Definitely a Renesas chip though with a perfect register index
+ match but at least one bit seems to be set that that datasheet
+ doesn't show. It says T.B.D. on the regmap anyway. */
+#define R_START_OSC 0x00
+#define R_DRV_OUTPUT_CONTROL 0x01
+#define R_DRV_WAVEFORM_CONTROL 0x02
+#define R_ENTRY_MODE 0x03
+#define R_COMPARE_REG1 0x04
+#define R_COMPARE_REG2 0x05
+#define R_DISP_CONTROL1 0x07
+#define R_DISP_CONTROL2 0x08
+#define R_DISP_CONTROL3 0x09
+#define R_FRAME_CYCLE_CONTROL 0x0b
+#define R_EXT_DISP_INTF_CONTROL 0x0c
+#define R_POWER_CONTROL1 0x10
+#define R_POWER_CONTROL2 0x11
+#define R_POWER_CONTROL3 0x12
+#define R_POWER_CONTROL4 0x13
+#define R_RAM_ADDR_SET 0x21
+#define R_RAM_READ_DATA 0x21
+#define R_RAM_WRITE_DATA 0x22
+#define R_RAM_WRITE_DATA_MASK1 0x23
+#define R_RAM_WRITE_DATA_MASK2 0x24
+#define R_GAMMA_FINE_ADJ_POS1 0x30
+#define R_GAMMA_FINE_ADJ_POS2 0x31
+#define R_GAMMA_FINE_ADJ_POS3 0x32
+#define R_GAMMA_GRAD_ADJ_POS 0x33
+#define R_GAMMA_FINE_ADJ_NEG1 0x34
+#define R_GAMMA_FINE_ADJ_NEG2 0x35
+#define R_GAMMA_FINE_ADJ_NEG3 0x36
+#define R_GAMMA_GRAD_ADJ_NEG 0x37
+#define R_GAMMA_AMP_ADJ_POS 0x38
+#define R_GAMMA_AMP_ADJ_NEG 0x39
+#define R_GATE_SCAN_START_POS 0x40
+#define R_VERT_SCROLL_CONTROL 0x41
+#define R_1ST_SCR_DRIVE_POS 0x42
+#define R_2ND_SCR_DRIVE_POS 0x43
+#define R_HORIZ_RAM_ADDR_POS 0x44
+#define R_VERT_RAM_ADDR_POS 0x45
+
/* We don't know how to receive a DMA finished signal from the LCD controller
* To avoid problems with flickering, we double-buffer the framebuffer and turn
* off DMA while updates are taking place */
@@ -186,67 +227,73 @@ inline void lcd_init_device(void)
udelay(100000);
/* LCD init */
+
+ /* TODO: Eliminate some of this outside the bootloader since this
+ will already be setup and that will eliminate white-screen */
+
+ /* Pull RESET low, then high */
outl((inl(0x70000080) & ~(1 << 28)), 0x70000080);
udelay(10000);
outl((inl(0x70000080) | (1 << 28)), 0x70000080);
udelay(10000);
- lcd_write_reg(16, 0x4444);
- lcd_write_reg(17, 0x0001);
- lcd_write_reg(18, 0x0003);
- lcd_write_reg(19, 0x1119);
- lcd_write_reg(18, 0x0013);
+ lcd_write_reg(R_POWER_CONTROL1, 0x4444);
+ lcd_write_reg(R_POWER_CONTROL2, 0x0001);
+ lcd_write_reg(R_POWER_CONTROL3, 0x0003);
+ lcd_write_reg(R_POWER_CONTROL4, 0x1119);
+ lcd_write_reg(R_POWER_CONTROL3, 0x0013);
udelay(50000);
- lcd_write_reg(16, 0x4440);
- lcd_write_reg(19, 0x3119);
+ lcd_write_reg(R_POWER_CONTROL1, 0x4440);
+ lcd_write_reg(R_POWER_CONTROL4, 0x3119);
udelay(150000);
- lcd_write_reg(1, 0x101b);
- lcd_write_reg(2, 0x0700);
- lcd_write_reg(3, 0x6020);
- lcd_write_reg(4, 0x0000);
- lcd_write_reg(5, 0x0000);
- lcd_write_reg(8, 0x0102);
- lcd_write_reg(9, 0x0000);
- lcd_write_reg(11, 0x4400);
- lcd_write_reg(12, 0x0110);
-
- lcd_write_reg(64, 0x0000);
- lcd_write_reg(65, 0x0000);
- lcd_write_reg(66, (219 << 8)); /* Screen resolution? */
- lcd_write_reg(67, 0x0000);
- lcd_write_reg(68, (175 << 8));
- lcd_write_reg(69, (219 << 8));
-
- lcd_write_reg(48, 0x0000);
- lcd_write_reg(49, 0x0704);
- lcd_write_reg(50, 0x0107);
- lcd_write_reg(51, 0x0704);
- lcd_write_reg(52, 0x0107);
- lcd_write_reg(53, 0x0002);
- lcd_write_reg(54, 0x0707);
- lcd_write_reg(55, 0x0503);
- lcd_write_reg(56, 0x0000);
- lcd_write_reg(57, 0x0000);
-
- lcd_write_reg(33, 175);
-
- lcd_write_reg(12, 0x0110);
-
- lcd_write_reg(16, 0x4740);
-
- lcd_write_reg(7, 0x0045);
+ lcd_write_reg(R_DRV_OUTPUT_CONTROL, 0x101b);
+ lcd_write_reg(R_DRV_WAVEFORM_CONTROL, 0x0700);
+ lcd_write_reg(R_ENTRY_MODE, 0x6020);
+ lcd_write_reg(R_COMPARE_REG1, 0x0000);
+ lcd_write_reg(R_COMPARE_REG2, 0x0000);
+ lcd_write_reg(R_DISP_CONTROL2, 0x0102);
+ lcd_write_reg(R_DISP_CONTROL3, 0x0000);
+ lcd_write_reg(R_FRAME_CYCLE_CONTROL, 0x4400);
+ lcd_write_reg(R_EXT_DISP_INTF_CONTROL, 0x0110);
+
+ lcd_write_reg(R_GATE_SCAN_START_POS, 0x0000);
+ lcd_write_reg(R_VERT_SCROLL_CONTROL, 0x0000);
+ lcd_write_reg(R_1ST_SCR_DRIVE_POS, (219 << 8));
+ lcd_write_reg(R_2ND_SCR_DRIVE_POS, 0x0000);
+ lcd_write_reg(R_HORIZ_RAM_ADDR_POS, (175 << 8));
+ lcd_write_reg(R_VERT_RAM_ADDR_POS, (219 << 8));
+
+ lcd_write_reg(R_GAMMA_FINE_ADJ_POS1, 0x0000);
+ lcd_write_reg(R_GAMMA_FINE_ADJ_POS2, 0x0704);
+ lcd_write_reg(R_GAMMA_FINE_ADJ_POS3, 0x0107);
+ lcd_write_reg(R_GAMMA_GRAD_ADJ_POS, 0x0704);
+ lcd_write_reg(R_GAMMA_FINE_ADJ_NEG1, 0x0107);
+ lcd_write_reg(R_GAMMA_FINE_ADJ_NEG2, 0x0002);
+ lcd_write_reg(R_GAMMA_FINE_ADJ_NEG3, 0x0707);
+ lcd_write_reg(R_GAMMA_GRAD_ADJ_NEG, 0x0503);
+ lcd_write_reg(R_GAMMA_AMP_ADJ_POS, 0x0000);
+ lcd_write_reg(R_GAMMA_AMP_ADJ_NEG, 0x0000);
+
+ lcd_write_reg(R_RAM_ADDR_SET, 175);
+
+ lcd_write_reg(R_EXT_DISP_INTF_CONTROL, 0x0110);
+
+ lcd_write_reg(R_POWER_CONTROL1, 0x4740);
+
+ lcd_write_reg(R_DISP_CONTROL1, 0x0045);
udelay(50000);
- lcd_write_reg(7, 0x0065);
- lcd_write_reg(7, 0x0067);
+ lcd_write_reg(R_DISP_CONTROL1, 0x0065);
+ lcd_write_reg(R_DISP_CONTROL1, 0x0067);
udelay(50000);
- lcd_write_reg(7, 0x0077);
- lcd_send_msg(0x70, 34);
+ lcd_write_reg(R_DISP_CONTROL1, 0x0077);
+
+ lcd_send_msg(0x70, R_RAM_WRITE_DATA);
}
void lcd_enable(bool on)