mirror of
https://github.com/edk2-porting/linux-next.git
synced 2024-12-27 14:43:58 +08:00
16b7b2ac01
Since we already moved to GENERIC_TIME, we should implement alternatives of old do_gettimeoffset routines to get sub-jiffies resolution from gettimeofday(). This patch includes: * MIPS clocksource support (based on works by Manish Lachwani). * remove unused gettimeoffset routines and related codes. * remove unised 64bit do_div64_32(). * simplify mips_hpt_init. (no argument needed, __init tag) * simplify c0_hpt_timer_init. (no need to write to c0_count) * remove some hpt_init routines. * mips_hpt_mask variable to specify bitmask of hpt value. * convert jmr3927_do_gettimeoffset to jmr3927_hpt_read. * convert ip27_do_gettimeoffset to ip27_hpt_read. * convert bcm1480_do_gettimeoffset to bcm1480_hpt_read. * simplify sb1250 hpt functions. (no need to subtract and shift) Signed-off-by: Atsushi Nemoto <anemo@mba.ocn.ne.jp> Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
75 lines
2.0 KiB
C
75 lines
2.0 KiB
C
/*
|
|
* Copyright (C) 2000, 2001, 2002, 2003 Broadcom Corporation
|
|
*
|
|
* 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 program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
*/
|
|
|
|
#ifndef _ASM_SIBYTE_SB1250_H
|
|
#define _ASM_SIBYTE_SB1250_H
|
|
|
|
/*
|
|
* yymmddpp: year, month, day, patch.
|
|
* should sync with Makefile EXTRAVERSION
|
|
*/
|
|
#define SIBYTE_RELEASE 0x02111403
|
|
|
|
#define SB1250_NR_IRQS 64
|
|
|
|
#define BCM1480_NR_IRQS 128
|
|
#define BCM1480_NR_IRQS_HALF 64
|
|
|
|
#define SB1250_DUART_MINOR_BASE 64
|
|
|
|
#ifndef __ASSEMBLY__
|
|
|
|
#include <asm/addrspace.h>
|
|
|
|
/* For revision/pass information */
|
|
#include <asm/sibyte/sb1250_scd.h>
|
|
#include <asm/sibyte/bcm1480_scd.h>
|
|
extern unsigned int sb1_pass;
|
|
extern unsigned int soc_pass;
|
|
extern unsigned int soc_type;
|
|
extern unsigned int periph_rev;
|
|
extern unsigned int zbbus_mhz;
|
|
|
|
extern void sb1250_hpt_setup(void);
|
|
extern void sb1250_time_init(void);
|
|
extern void sb1250_mask_irq(int cpu, int irq);
|
|
extern void sb1250_unmask_irq(int cpu, int irq);
|
|
extern void sb1250_smp_finish(void);
|
|
|
|
extern void bcm1480_hpt_setup(void);
|
|
extern void bcm1480_time_init(void);
|
|
extern void bcm1480_mask_irq(int cpu, int irq);
|
|
extern void bcm1480_unmask_irq(int cpu, int irq);
|
|
extern void bcm1480_smp_finish(void);
|
|
|
|
extern void prom_printf(char *fmt, ...);
|
|
|
|
#define AT_spin \
|
|
__asm__ __volatile__ ( \
|
|
".set noat\n" \
|
|
"li $at, 0\n" \
|
|
"1: beqz $at, 1b\n" \
|
|
".set at\n" \
|
|
)
|
|
|
|
#endif
|
|
|
|
#define IOADDR(a) ((volatile void __iomem *)(IO_BASE + (a)))
|
|
|
|
#endif
|