2008-10-12 16:46:01 +00:00
|
|
|
/***************************************************************************
|
|
|
|
* __________ __ ___.
|
|
|
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
|
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
|
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
|
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
|
|
* \/ \/ \/ \/ \/
|
|
|
|
* $Id$
|
|
|
|
*
|
2008-11-26 16:46:12 +00:00
|
|
|
* Copyright (C) 2008 Rafaël Carré
|
2008-10-12 16:46:01 +00:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
#ifndef SYSTEM_TARGET_H
|
|
|
|
#define SYSTEM_TARGET_H
|
|
|
|
|
2017-01-21 13:04:43 +00:00
|
|
|
/* we need some system things initialized after the kernel init */
|
|
|
|
#define KDEV_INIT
|
|
|
|
|
2008-10-12 16:46:01 +00:00
|
|
|
#include "system-arm.h"
|
2009-07-05 01:17:25 +00:00
|
|
|
#include "mmu-arm.h"
|
2010-04-27 09:34:29 +00:00
|
|
|
#include "panic.h"
|
2008-10-12 16:46:01 +00:00
|
|
|
|
2008-12-04 20:04:31 +00:00
|
|
|
#include "clock-target.h" /* CPUFREQ_* are defined here */
|
2008-10-12 16:46:01 +00:00
|
|
|
|
2017-01-21 13:04:43 +00:00
|
|
|
void kernel_device_init(void);
|
|
|
|
|
2010-06-23 04:34:23 +00:00
|
|
|
#define STORAGE_WANTS_ALIGN
|
|
|
|
|
2010-04-27 10:11:52 +00:00
|
|
|
/* We can use a interrupt-based mechanism on the fuzev2 */
|
|
|
|
#define INCREASED_SCROLLWHEEL_POLLING \
|
|
|
|
(defined(HAVE_SCROLLWHEEL) && (CONFIG_CPU == AS3525))
|
|
|
|
|
|
|
|
#if INCREASED_SCROLLWHEEL_POLLING
|
2010-04-27 09:34:29 +00:00
|
|
|
/* let the timer interrupt twice as often for the scrollwheel polling */
|
|
|
|
#define KERNEL_TIMER_FREQ (TIMER_FREQ/2)
|
|
|
|
#else
|
|
|
|
#define KERNEL_TIMER_FREQ TIMER_FREQ
|
|
|
|
#endif
|
|
|
|
|
2010-05-19 18:13:06 +00:00
|
|
|
#define AS3525_UNCACHED_ADDR(a) ((typeof(a)) ((uintptr_t)(a) + 0x10000000))
|
2010-06-23 04:34:23 +00:00
|
|
|
#define AS3525_PHYSICAL_ADDR(a) \
|
2011-02-02 17:43:32 +00:00
|
|
|
((typeof(a)) ((((uintptr_t)(a)) & (MEMORYSIZE*0x100000)) \
|
2010-06-23 04:34:23 +00:00
|
|
|
? (((uintptr_t)(a)) - IRAM_ORIG) \
|
|
|
|
: ((uintptr_t)(a))))
|
2009-06-08 23:05:33 +00:00
|
|
|
|
2011-10-29 17:08:05 +00:00
|
|
|
#if defined(SANSA_FUZEV2) || defined(SANSA_CLIPPLUS) || defined(SANSA_CLIPZIP)
|
2010-07-22 13:47:09 +00:00
|
|
|
extern int amsv2_variant;
|
2010-07-19 15:29:28 +00:00
|
|
|
#endif
|
|
|
|
|
2010-04-06 18:32:47 +00:00
|
|
|
#ifdef SANSA_C200V2
|
|
|
|
/* 0: Backlight on A5, 1: Backlight on A7 */
|
|
|
|
extern int c200v2_variant;
|
2010-04-27 09:34:29 +00:00
|
|
|
/* c200v2 changes the timer interval often due to software pwm */
|
|
|
|
#define TIMER_PERIOD TIMER2_BGLOAD
|
|
|
|
#else
|
|
|
|
#define TIMER_PERIOD (KERNEL_TIMER_FREQ/HZ)
|
2010-04-06 18:32:47 +00:00
|
|
|
#endif
|
|
|
|
|
2010-06-18 20:04:16 +00:00
|
|
|
void udelay(unsigned usecs);
|
2010-06-19 02:34:56 +00:00
|
|
|
static inline void mdelay(unsigned msecs)
|
|
|
|
{
|
|
|
|
udelay(1000 * msecs);
|
|
|
|
}
|
2011-12-31 18:44:12 +00:00
|
|
|
|
|
|
|
void usb_insert_int(void);
|
|
|
|
void usb_remove_int(void);
|
|
|
|
|
2017-01-21 13:04:43 +00:00
|
|
|
#ifdef HAVE_ADJUSTABLE_CPU_FREQ
|
|
|
|
#define CPU_BOOST_LOCK_DEFINED
|
|
|
|
|
|
|
|
static inline bool cpu_boost_lock(void)
|
|
|
|
{
|
|
|
|
bool set_cpu_frequency__lock(void);
|
|
|
|
return set_cpu_frequency__lock();
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void cpu_boost_unlock(void)
|
|
|
|
{
|
|
|
|
void set_cpu_frequency__unlock(void);
|
|
|
|
set_cpu_frequency__unlock();
|
|
|
|
}
|
|
|
|
#endif /* HAVE_ADJUSTABLE_CPU_FREQ */
|
|
|
|
|
2017-10-30 20:29:51 +00:00
|
|
|
struct ams_sd_debug_info
|
|
|
|
{
|
|
|
|
unsigned long mci_nand;
|
|
|
|
unsigned long mci_sd;
|
|
|
|
};
|
|
|
|
|
|
|
|
void ams_sd_get_debug_info(struct ams_sd_debug_info *info);
|
|
|
|
|
|
|
|
|
2008-10-12 16:46:01 +00:00
|
|
|
#endif /* SYSTEM_TARGET_H */
|