summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJonathan Gordon <rockbox@jdgordon.info>2008-10-29 06:11:33 +0000
committerJonathan Gordon <rockbox@jdgordon.info>2008-10-29 06:11:33 +0000
commit8f7f219dbabee320862cb7ed8616300d54f935cb (patch)
treecbe72682a4457a3d898ccd25855566426b5aa9b9
parent0a8446ad7dc5a659f59ac3d2964b9ae4f7a26899 (diff)
downloadrockbox-8f7f219dbabee320862cb7ed8616300d54f935cb.zip
rockbox-8f7f219dbabee320862cb7ed8616300d54f935cb.tar.gz
rockbox-8f7f219dbabee320862cb7ed8616300d54f935cb.tar.bz2
rockbox-8f7f219dbabee320862cb7ed8616300d54f935cb.tar.xz
FS#9511 - working lcd update (and lcd_update_rect() ) for the e200v2, working button light also
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@18914 a1c6a512-1295-4272-9138-f99709370657
-rw-r--r--firmware/target/arm/as3525/sansa-e200v2/backlight-e200v2.c6
-rw-r--r--firmware/target/arm/as3525/sansa-e200v2/lcd-e200v2.c17
2 files changed, 9 insertions, 14 deletions
diff --git a/firmware/target/arm/as3525/sansa-e200v2/backlight-e200v2.c b/firmware/target/arm/as3525/sansa-e200v2/backlight-e200v2.c
index fd2b65a..735b856 100644
--- a/firmware/target/arm/as3525/sansa-e200v2/backlight-e200v2.c
+++ b/firmware/target/arm/as3525/sansa-e200v2/backlight-e200v2.c
@@ -62,10 +62,12 @@ void _backlight_off(void)
void _buttonlight_on(void)
{
- /* TODO */
+ GPIOD_PIN(7) = (1<<7);
+ GPIOD_DIR |= (1<<7);
}
void _buttonlight_off(void)
{
- /* TODO */
+ GPIOD_PIN(7) = 0;
+ GPIOD_DIR |= (1<<7);
}
diff --git a/firmware/target/arm/as3525/sansa-e200v2/lcd-e200v2.c b/firmware/target/arm/as3525/sansa-e200v2/lcd-e200v2.c
index c4b300a..7a5c115 100644
--- a/firmware/target/arm/as3525/sansa-e200v2/lcd-e200v2.c
+++ b/firmware/target/arm/as3525/sansa-e200v2/lcd-e200v2.c
@@ -307,14 +307,6 @@ void lcd_init_device(void)
GPIOD_DIR |= (1<<7);
-#if 0
- /* TODO: This code is conditional on a variable in the OF init, we need to
- work out what it means */
-
- GPIOD_PIN(7) = (1<<7);
- GPIOD_DIR |= (1<<7);
-#endif
-
lcd_delay(1);
GPIOA_PIN(5) = (1<<5);
@@ -377,13 +369,14 @@ void lcd_update(void)
/* Set start position and window */
lcd_write_reg(R_HORIZ_RAM_ADDR_POS,
- ((y_offset + LCD_HEIGHT-1) << 8) | y_offset);
- lcd_write_reg(R_VERT_RAM_ADDR_POS, (LCD_WIDTH-1) << 8);
+ ((y_offset + LCD_WIDTH-1) << 8) | y_offset);
+ lcd_write_reg(R_VERT_RAM_ADDR_POS, (LCD_HEIGHT-1) << 8);
lcd_write_reg(R_RAM_ADDR_SET, y_offset);
lcd_write_cmd(R_WRITE_DATA_2_GRAM);
lcd_write_data((unsigned short *)lcd_framebuffer, LCD_WIDTH*LCD_HEIGHT);
+
} /* lcd_update */
@@ -414,8 +407,8 @@ void lcd_update_rect(int x, int y, int width, int height)
lcd_write_reg(R_ENTRY_MODE, R_ENTRY_MODE_HORZ);
/* Set start position and window */
lcd_write_reg(R_HORIZ_RAM_ADDR_POS,
- ((y_offset + LCD_HEIGHT-1) << 8) | y_offset);
- lcd_write_reg(R_VERT_RAM_ADDR_POS, ((x + width - 1) << 8) | x);
+ ((y_offset + LCD_WIDTH-1) << 8) | y_offset);
+ lcd_write_reg(R_VERT_RAM_ADDR_POS, ((y + height - 1) << 8) | y);
lcd_write_reg(R_RAM_ADDR_SET, (x << 8) | (y + y_offset));
lcd_write_cmd(R_WRITE_DATA_2_GRAM);