[Blackfin] arch: actually implement get_cycles function

Signed-off-by: Mike Frysinger <vapier.adi@gmail.com>
Signed-off-by: Bryan Wu <cooloney@kernel.org>
This commit is contained in:
Mike Frysinger 2008-04-24 05:07:29 +08:00 committed by Bryan Wu
parent 8cab0288c6
commit 764cb81cdc
2 changed files with 13 additions and 9 deletions

View File

@ -12,6 +12,7 @@
#include <linux/profile.h>
#include <linux/interrupt.h>
#include <linux/time.h>
#include <linux/timex.h>
#include <linux/irq.h>
#include <linux/clocksource.h>
#include <linux/clockchips.h>
@ -35,9 +36,7 @@ static inline unsigned long long cycles_2_ns(cycle_t cyc)
static cycle_t read_cycles(void)
{
unsigned long tmp, tmp2;
asm("%0 = cycles; %1 = cycles2;" : "=d"(tmp), "=d"(tmp2));
return tmp | ((cycle_t)tmp2 << 32);
return get_cycles();
}
unsigned long long sched_clock(void)

View File

@ -1,18 +1,23 @@
/* blackfin architecture timex specifications: Lineo Inc. 2001
/*
* asm-blackfin/timex.h: cpu cycles!
*
* Based on: include/asm-m68knommu/timex.h
* Copyright 2004-2008 Analog Devices Inc.
*
* Licensed under the GPL-2 or later.
*/
#ifndef _ASMBLACKFIN_TIMEX_H
#define _ASMBLACKFIN_TIMEX_H
#ifndef _ASM_BLACKFIN_TIMEX_H
#define _ASM_BLACKFIN_TIMEX_H
#define CLOCK_TICK_RATE 1000000 /* Underlying HZ */
typedef unsigned long cycles_t;
typedef unsigned long long cycles_t;
static inline cycles_t get_cycles(void)
{
return 0;
unsigned long tmp, tmp2;
__asm__("%0 = cycles; %1 = cycles2;" : "=d"(tmp), "=d"(tmp2));
return tmp | ((cycles_t)tmp2 << 32);
}
#endif