diff options
| author | Karl Kurbjun <kkurbjun@gmail.com> | 2009-04-28 05:20:31 +0000 |
|---|---|---|
| committer | Karl Kurbjun <kkurbjun@gmail.com> | 2009-04-28 05:20:31 +0000 |
| commit | bee99e496f816792014d02f4eca3a33d3ed8db2b (patch) | |
| tree | fe3096e9a2b057b7f49a4cf823d4592b0351f85c | |
| parent | 57ca7ccf36728fec7096931a064adc0b0e212ae0 (diff) | |
| download | rockbox-bee99e496f816792014d02f4eca3a33d3ed8db2b.zip rockbox-bee99e496f816792014d02f4eca3a33d3ed8db2b.tar.gz rockbox-bee99e496f816792014d02f4eca3a33d3ed8db2b.tar.bz2 rockbox-bee99e496f816792014d02f4eca3a33d3ed8db2b.tar.xz | |
M:Robe 500: Fix red, commit missing work, reduce lcd wakeup time.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@20819 a1c6a512-1295-4272-9138-f99709370657
| -rw-r--r-- | firmware/drivers/tsc2100.c | 60 | ||||
| -rw-r--r-- | firmware/target/arm/tms320dm320/mrobe-500/lcd-mr500.c | 5 |
2 files changed, 54 insertions, 11 deletions
diff --git a/firmware/drivers/tsc2100.c b/firmware/drivers/tsc2100.c index 88402fe..14b56b7 100644 --- a/firmware/drivers/tsc2100.c +++ b/firmware/drivers/tsc2100.c @@ -25,20 +25,64 @@ #include "spi.h" #include "tsc2100.h" -/* Read X, Y, Z1, Z2 touchscreen coordinates. */ -void tsc2100_read_values(short *x, short* y, short *z1, short *z2) +/* adc_data contains the last readings from the tsc2100 */ +static short adc_data[10]; + +void tsc2100_read_data(void) { int page = 0, address = 0; + unsigned int i; unsigned short command = 0x8000|(page << 11)|(address << 5); unsigned char out[] = {command >> 8, command & 0xff}; - unsigned char in[8]; + unsigned char *p_adc_data=(unsigned char *)&adc_data; + spi_block_transfer(SPI_target_TSC2100, - out, sizeof(out), in, sizeof(in)); + out, sizeof(out), (char *)adc_data, sizeof(adc_data)); + + for(i=0; i<sizeof(adc_data); i+=2) + adc_data[i>>1]=(short)(p_adc_data[i]<<8|p_adc_data[i+1]); +} + +/* Read X, Y, Z1, Z2 touchscreen coordinates. */ +void tsc2100_read_touch(short *x, short* y, short *z1, short *z2) +{ + *x = adc_data[0]; + *y = adc_data[1]; + *z1 = adc_data[2]; + *z2 = adc_data[3]; +} - *x = (in[0]<<8)|in[1]; - *y = (in[2]<<8)|in[3]; - *z1 = (in[4]<<8)|in[5]; - *z2 = (in[6]<<8)|in[7]; +void tsc2100_read_volt(short *bat1, short *bat2, short *aux) +{ + *bat1 = adc_data[5]; + *bat2 = adc_data[6]; + *aux = adc_data[7]; +} + +void tsc2100_set_mode(unsigned char scan_mode) +{ + short tsadc=(scan_mode<<TSADC_ADSCM_SHIFT)| /* mode */ + (0x3<<TSADC_RESOL_SHIFT)| /* 12 bit resolution */ + (0x2<<TSADC_ADCR_SHIFT )| /* 2 MHz internal clock */ + (0x2<<TSADC_PVSTC_SHIFT); + + if(scan_mode<6) + tsadc|=TSADC_PSTCM; + + tsc2100_writereg(TSADC_PAGE, TSADC_ADDRESS, tsadc); +} + +void tsc2100_adc_init(void) +{ + /* Set the TSC2100 to read touchscreen */ + tsc2100_set_mode(0x01); + + tsc2100_writereg(TSSTAT_PAGE, TSSTAT_ADDRESS, + (0x1<<TSSTAT_PINTDAV_SHIFT) /* Data available only */ + ); + + tsc2100_writereg(TSREF_PAGE, TSREF_ADDRESS, + TSREF_VREFM|TSREF_IREFV); } short tsc2100_readreg(int page, int address) diff --git a/firmware/target/arm/tms320dm320/mrobe-500/lcd-mr500.c b/firmware/target/arm/tms320dm320/mrobe-500/lcd-mr500.c index 20b830b..af5a650 100644 --- a/firmware/target/arm/tms320dm320/mrobe-500/lcd-mr500.c +++ b/firmware/target/arm/tms320dm320/mrobe-500/lcd-mr500.c @@ -84,9 +84,8 @@ void lcd_awake(void) sleep(2); IO_GIO_BITSET2=1<<4; - /* Wait long enough for a frame to be written - yes, it - * takes awhile. */ - sleep(HZ/5); + /* Wait long enough for a frame to be written */ + sleep(HZ/20); lcd_update(); lcd_activation_call_hook(); |