From 28f6ae49ec1b1d3464add2941eb015bab56f8016 Mon Sep 17 00:00:00 2001 From: Dave Chapman Date: Sun, 28 Oct 2007 11:08:10 +0000 Subject: Initial work on a port to the Logik DAX 1GB MP3/DAB player. The bootloader build compiles and runs (but only displays some debugging info), and the LCD and ADC drivers are working. Two different bootloader builds are possible: 1) The default build is just a test application for uploading to the device via tcctool; 2) Adding -DTCCBOOT to EXTRA_DEFINES in the build directory Makefile will compile the bootloader so that it can be appended to the end of the original firmware and installed on the device, dual-booting. This commit also includes some work by Hein-Pieter van Braam on a port to the iAudio 7, but that doesn't build yet. A large part of these ports will be generic to all TCC77x devices - see the TelechipsInfo wiki page for some other devices with this CPU. NOTE: Compiling these builds requires an arm-elf-gcc with armv5 support - the current version of rockboxdev.sh compiles such a gcc. git-svn-id: svn://svn.rockbox.org/rockbox/trunk@15339 a1c6a512-1295-4272-9138-f99709370657 --- firmware/target/arm/tcc77x/adc-tcc77x.c | 71 +++++++++++++++++++++++++++++++++ 1 file changed, 71 insertions(+) create mode 100644 firmware/target/arm/tcc77x/adc-tcc77x.c (limited to 'firmware/target/arm/tcc77x/adc-tcc77x.c') diff --git a/firmware/target/arm/tcc77x/adc-tcc77x.c b/firmware/target/arm/tcc77x/adc-tcc77x.c new file mode 100644 index 0000000000..d6d97aaf84 --- /dev/null +++ b/firmware/target/arm/tcc77x/adc-tcc77x.c @@ -0,0 +1,71 @@ +/*************************************************************************** + * __________ __ ___. + * Open \______ \ ____ ____ | | _\_ |__ _______ ___ + * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ / + * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < < + * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \ + * \/ \/ \/ \/ \/ + * $Id$ + * + * Copyright (C) 2007 by Dave Chapman + * + * All files in this archive are subject to the GNU General Public License. + * See the file COPYING in the source tree root for full license agreement. + * + * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY + * KIND, either express or implied. + * + ****************************************************************************/ +#include "config.h" +#include "cpu.h" +#include "system.h" +#include "kernel.h" +#include "thread.h" +#include "string.h" +#include "adc.h" + +/* + TODO: We probably want to do this on the timer interrupt once we get + interrupts going - see the sh-adc.c implementation for an example which + looks like it should work well with the TCC77x. +*/ + +static unsigned short adcdata[8]; + +static void adc_do_read(void) +{ + int i; + uint32_t adc_status; + + PCLKCFG6 |= (1<<15); /* Enable ADC clock */ + + /* Start converting the first 4 channels */ + for (i = 0; i < 4; i++) + ADCCON = i; + + /* Wait for data to become stable */ + while ((ADCDATA & 0x1) == 0); + + /* Now read the values back */ + for (i=0;i < 4; i++) { + adc_status = ADCSTATUS; + adcdata[(adc_status >> 16) & 0x7] = adc_status & 0x3ff; + } + + PCLKCFG6 &= ~(1<<15); /* Disable ADC clock */ +} + +unsigned short adc_read(int channel) +{ + adc_do_read(); + + return adcdata[channel]; +} + +void adc_init(void) +{ + int i; + + ADCCON = (1<<4); /* Leave standby mode */ + ADCCFG |= 0x00000003; /* Single-mode, auto power-down */ +} -- cgit v1.2.3