2011-07-09 17:14:05 +00:00
|
|
|
/***************************************************************************
|
|
|
|
* __________ __ ___.
|
|
|
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
|
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
|
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
|
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
|
|
* \/ \/ \/ \/ \/
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
* Copyright (C) 2011 by Amaury Pouly
|
|
|
|
*
|
|
|
|
* 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 "config.h"
|
|
|
|
#include "system.h"
|
|
|
|
#include "pinctrl-imx233.h"
|
2012-05-10 16:29:43 +00:00
|
|
|
#include "rds.h"
|
|
|
|
#include "si4700.h"
|
2011-07-09 17:14:05 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sansa Fuze+ fmradio uses the following pins:
|
2013-11-19 20:39:10 +00:00
|
|
|
* - B0P29 as CE (active high)
|
2011-07-09 17:14:05 +00:00
|
|
|
* - B1P24 as SDA
|
|
|
|
* - B1P22 as SCL
|
2012-05-10 16:29:43 +00:00
|
|
|
* - B2P27 as STC/RDS
|
2011-07-09 17:14:05 +00:00
|
|
|
*/
|
2012-05-10 16:29:43 +00:00
|
|
|
|
|
|
|
#ifdef HAVE_RDS_CAP
|
|
|
|
/* Low-level RDS Support */
|
|
|
|
static struct semaphore rds_sema;
|
|
|
|
static uint32_t rds_stack[DEFAULT_STACK_SIZE / sizeof(uint32_t)];
|
|
|
|
|
|
|
|
/* RDS GPIO interrupt handler */
|
2013-06-16 17:32:21 +00:00
|
|
|
static void stc_rds_callback(int bank, int pin, intptr_t user)
|
2012-05-10 16:29:43 +00:00
|
|
|
{
|
|
|
|
(void) bank;
|
|
|
|
(void) pin;
|
2013-06-16 17:32:21 +00:00
|
|
|
(void) user;
|
2012-05-10 16:29:43 +00:00
|
|
|
|
|
|
|
semaphore_release(&rds_sema);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Captures RDS data and processes it */
|
|
|
|
static void NORETURN_ATTR rds_thread(void)
|
|
|
|
{
|
|
|
|
uint16_t rds_data[4];
|
|
|
|
|
|
|
|
while(true)
|
|
|
|
{
|
|
|
|
semaphore_wait(&rds_sema, TIMEOUT_BLOCK);
|
|
|
|
if(si4700_rds_read_raw(rds_data) && rds_process(rds_data))
|
|
|
|
si4700_rds_set_event();
|
|
|
|
/* renable callback */
|
2013-06-16 17:32:21 +00:00
|
|
|
imx233_pinctrl_setup_irq(2, 27, true, true, false, &stc_rds_callback, 0);
|
2012-05-10 16:29:43 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* true after full radio power up, and false before powering down */
|
|
|
|
void si4700_rds_powerup(bool on)
|
|
|
|
{
|
|
|
|
if(on)
|
|
|
|
{
|
2013-06-16 17:18:56 +00:00
|
|
|
imx233_pinctrl_acquire(2, 27, "tuner stc/rds");
|
|
|
|
imx233_pinctrl_set_function(2, 27, PINCTRL_FUNCTION_GPIO);
|
|
|
|
imx233_pinctrl_enable_gpio(2, 27, false);
|
2012-05-10 16:29:43 +00:00
|
|
|
/* pin is set to 0 when an RDS packet has arrived */
|
2013-06-16 17:32:21 +00:00
|
|
|
imx233_pinctrl_setup_irq(2, 27, true, true, false, &stc_rds_callback, 0);
|
2012-05-10 16:29:43 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2013-06-16 17:32:21 +00:00
|
|
|
imx233_pinctrl_setup_irq(2, 27, false, false, false, NULL, 0);
|
2013-06-16 17:18:56 +00:00
|
|
|
imx233_pinctrl_release(2, 27, "tuner stc/rds");
|
2012-05-10 16:29:43 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* One-time RDS init at startup */
|
|
|
|
void si4700_rds_init(void)
|
|
|
|
{
|
|
|
|
semaphore_init(&rds_sema, 1, 0);
|
|
|
|
rds_init();
|
|
|
|
create_thread(rds_thread, rds_stack, sizeof(rds_stack), 0, "rds"
|
|
|
|
IF_PRIO(, PRIORITY_REALTIME) IF_COP(, CPU));
|
|
|
|
}
|
|
|
|
#endif /* HAVE_RDS_CAP */
|