| /*************************************************************************** |
| * __________ __ ___. |
| * Open \______ \ ____ ____ | | _\_ |__ _______ ___ |
| * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ / |
| * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < < |
| * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \ |
| * \/ \/ \/ \/ \/ |
| * $Id$ |
| * |
| * Copyright (C) 2002 by Linus Nielsen Feltzing |
| * |
| * This program is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU General Public License |
| * as published by the Free Software Foundation; either version 2 |
| * of the License, or (at your option) any later version. |
| * |
| * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY |
| * KIND, either express or implied. |
| * |
| ****************************************************************************/ |
| #include "lcd.h" |
| #include "sh7034.h" |
| #include "kernel.h" |
| #include "thread.h" |
| #include "debug.h" |
| #include "system.h" |
| #include "fmradio.h" |
| |
| #if CONFIG_TUNER |
| |
| /* Signals: |
| DI (Data In) - PB0 (doubles as data pin for the LCD) |
| CL (Clock) - PB1 (doubles as clock for the LCD) |
| CE (Chip Enable) - PB3 (also chip select for the LCD, but active low) |
| DO (Data Out) - PB4 |
| */ |
| |
| /* cute little functions */ |
| #define CE_LO and_b(~0x08, PBDRL_ADDR) |
| #define CE_HI or_b(0x08, PBDRL_ADDR) |
| #define CL_LO and_b(~0x02, PBDRL_ADDR) |
| #define CL_HI or_b(0x02, PBDRL_ADDR) |
| #define DO (PBDR & 0x10) |
| #define DI_LO and_b(~0x01, PBDRL_ADDR) |
| #define DI_HI or_b(0x01, PBDRL_ADDR) |
| |
| #define START or_b((0x08 | 0x02), PBDRL_ADDR) |
| |
| /* delay loop */ |
| #define DELAY do { int _x; for(_x=0;_x<10;_x++);} while (0) |
| |
| |
| int fmradio_read(int addr) |
| { |
| int i; |
| int data = 0; |
| |
| START; |
| |
| /* First address bit */ |
| CL_LO; |
| if(addr & 2) |
| DI_HI; |
| else |
| DI_LO; |
| DELAY; |
| CL_HI; |
| DELAY; |
| |
| /* Second address bit */ |
| CL_LO; |
| if(addr & 1) |
| DI_HI; |
| else |
| DI_LO; |
| DELAY; |
| CL_HI; |
| DELAY; |
| |
| for(i = 0; i < 21;i++) |
| { |
| CL_LO; |
| DELAY; |
| data <<= 1; |
| data |= (DO)?1:0; |
| CL_HI; |
| DELAY; |
| } |
| |
| CE_LO; |
| |
| return data; |
| } |
| |
| void fmradio_set(int addr, int data) |
| { |
| int i; |
| |
| /* Include the address in the data */ |
| data |= addr << 21; |
| |
| START; |
| |
| for(i = 0; i < 23;i++) |
| { |
| CL_LO; |
| DELAY; |
| if(data & (1 << 22)) |
| DI_HI; |
| else |
| DI_LO; |
| |
| data <<= 1; |
| CL_HI; |
| DELAY; |
| } |
| |
| CE_LO; |
| } |
| |
| #endif |