mirror of
				https://github.com/Rockbox/rockbox.git
				synced 2025-10-24 23:47:38 -04:00 
			
		
		
		
	git-svn-id: svn://svn.rockbox.org/rockbox/trunk@11612 a1c6a512-1295-4272-9138-f99709370657
		
			
				
	
	
		
			174 lines
		
	
	
	
		
			4.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			174 lines
		
	
	
	
		
			4.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /***************************************************************************
 | |
|  *             __________               __   ___.
 | |
|  *   Open      \______   \ ____   ____ |  | _\_ |__   _______  ___
 | |
|  *   Source     |       _//  _ \_/ ___\|  |/ /| __ \ /  _ \  \/  /
 | |
|  *   Jukebox    |    |   (  <_> )  \___|    < | \_\ (  <_> > <  <
 | |
|  *   Firmware   |____|_  /\____/ \___  >__|_ \|___  /\____/__/\_ \
 | |
|  *                     \/            \/     \/    \/            \/
 | |
|  * $Id$
 | |
|  *
 | |
|  * Copyright (C) 2002 by Alan Korr & Nick Robinson
 | |
|  *
 | |
|  * 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 <stdlib.h>
 | |
| #include "button.h"
 | |
| #include "config.h"
 | |
| #include "cpu.h"
 | |
| #include "system.h"
 | |
| #include "kernel.h"
 | |
| #include "backlight.h"
 | |
| #include "adc.h"
 | |
| #include "lcd.h"
 | |
| #include "serial.h"
 | |
| 
 | |
| 
 | |
| #if CONFIG_CPU == SH7034
 | |
| 
 | |
| /* FIX: this doesn't work on iRiver or iPod yet */
 | |
| /* iFP7xx has no remote */
 | |
| 
 | |
| #if !defined(HAVE_FMADC) /* Recorder FM/V2 has no remote control pin */ \
 | |
|  && !defined(HAVE_MMC)   /* MMC takes serial port 1, so don't mess with it */
 | |
| 
 | |
| /* Received byte identifiers */
 | |
| #define PLAY  0xC1
 | |
| #define STOP  0xC2
 | |
| #define PREV  0xC4
 | |
| #define NEXT  0xC8
 | |
| #define VOLUP 0xD0
 | |
| #define VOLDN 0xE0
 | |
| 
 | |
| void serial_setup (void) 
 | |
| {
 | |
|     /* Set PB10 function to serial Rx */
 | |
|     PBCR1 = (PBCR1 & 0xffcf) | 0x0020;
 | |
|     
 | |
|     SMR1 = 0x00;
 | |
|     SCR1 = 0;
 | |
|     BRR1 = (FREQ/(32*9600))-1;
 | |
|     and_b(0, &SSR1); /* The status bits must be read before they are cleared,
 | |
|                         so we do an AND operation */
 | |
| 
 | |
|     /* Let the hardware settle. The serial port needs to wait "at least
 | |
|        the interval required to transmit or receive one bit" before it
 | |
|        can be used. */
 | |
|     sleep(1);
 | |
| 
 | |
|     SCR1 = 0x10; /* Enable the receiver, no interrupt */
 | |
| }
 | |
| 
 | |
| /* This function returns the received remote control code only if it is
 | |
|    received without errors before or after the reception.
 | |
|    It therefore returns the received code on the second call after the
 | |
|    code has been received. */
 | |
| int remote_control_rx(void)
 | |
| {
 | |
|     static int last_valid_button = BUTTON_NONE;
 | |
|     static int last_was_error = false;
 | |
|     int btn;
 | |
|     int ret = BUTTON_NONE;
 | |
|     
 | |
|     /* Errors? Just clear'em. The receiver stops if we don't */
 | |
|     if(SSR1 & (SCI_ORER | SCI_FER | SCI_PER)) {
 | |
|         and_b(~(SCI_ORER | SCI_FER | SCI_PER), &SSR1);
 | |
|         last_valid_button = BUTTON_NONE;
 | |
|         last_was_error = true;
 | |
|         return BUTTON_NONE;
 | |
|     }
 | |
| 
 | |
|     if(SSR1 & SCI_RDRF) {
 | |
|         /* Read byte and clear the Rx Full bit */
 | |
|         btn = RDR1;
 | |
|         and_b(~SCI_RDRF, &SSR1);
 | |
| 
 | |
|         if(last_was_error)
 | |
|         {
 | |
|             last_valid_button = BUTTON_NONE;
 | |
|             ret = BUTTON_NONE;
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|             switch (btn)
 | |
|             {
 | |
|                 case STOP:
 | |
|                     last_valid_button = BUTTON_RC_STOP;
 | |
|                     break;
 | |
| 
 | |
|                 case PLAY:
 | |
|                     last_valid_button = BUTTON_RC_PLAY;
 | |
|                     break;
 | |
| 
 | |
|                 case VOLUP:
 | |
|                     last_valid_button = BUTTON_RC_VOL_UP;
 | |
|                     break;
 | |
| 
 | |
|                 case VOLDN:
 | |
|                     last_valid_button = BUTTON_RC_VOL_DOWN;
 | |
|                     break;
 | |
| 
 | |
|                 case PREV:
 | |
|                     last_valid_button = BUTTON_RC_LEFT;
 | |
|                     break;
 | |
| 
 | |
|                 case NEXT:
 | |
|                     last_valid_button = BUTTON_RC_RIGHT;
 | |
|                     break;
 | |
| 
 | |
|                 default:
 | |
|                     last_valid_button = BUTTON_NONE;
 | |
|                     break;
 | |
|             }
 | |
|         }
 | |
|     }
 | |
|     else
 | |
|     {
 | |
|         /* This means that a valid remote control character was received
 | |
|            the last time we were called, with no receiver errors either before
 | |
|            or after. Then we can assume that there really is a remote control
 | |
|            attached, and return the button code. */
 | |
|         ret = last_valid_button;
 | |
|         last_valid_button = BUTTON_NONE;
 | |
|     }
 | |
|     
 | |
|     last_was_error = false;
 | |
| 
 | |
|     return ret;
 | |
| }
 | |
| 
 | |
| #endif /* !HAVE_FMADC && !HAVE_MMC */
 | |
| #elif defined(CPU_COLDFIRE) && defined(HAVE_SERIAL)
 | |
| 
 | |
| void serial_tx(const unsigned char *buf)
 | |
| {
 | |
|     while(*buf) {
 | |
|         while(!(USR0 & 0x04))
 | |
|         {
 | |
|         };
 | |
|         UTB0 = *buf++;
 | |
|     }
 | |
| }
 | |
| 
 | |
| void serial_setup (void) 
 | |
| {
 | |
|     UCR0 = 0x30; /* Reset transmitter */
 | |
|     UCSR0 = 0xdd; /* Timer mode */
 | |
| 
 | |
|     UCR0 = 0x10;  /* Reset pointer */
 | |
|     UMR0 = 0x13; /* No parity, 8 bits */
 | |
|     UMR0 = 0x07; /* 1 stop bit */
 | |
| 
 | |
|     UCR0 = 0x04; /* Tx enable */
 | |
| }
 | |
| 
 | |
| #else /* Other targets */
 | |
| void serial_setup (void) 
 | |
| {
 | |
|     /* a dummy */
 | |
| }
 | |
| #endif
 |