Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 355819
b: refs/heads/master
c: b8e2434
h: refs/heads/master
i:
  355817: 5f8943c
  355815: 2f67883
v: v3
  • Loading branch information
Mark Rutland committed Jan 31, 2013
1 parent e5acd5d commit e81c9e9
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 37 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: ef01c1d1483d214357f183949bc6173f29906a87
refs/heads/master: b8e243431fa11f542a0fd94e939543bcb7d236ee
58 changes: 22 additions & 36 deletions trunk/arch/arm/kernel/arch_timer.c
Original file line number Diff line number Diff line change
Expand Up @@ -272,51 +272,37 @@ static int arch_timer_available(void)
return 0;
}

static u32 notrace arch_counter_get_cntpct32(void)
/*
* Some external users of arch_timer_read_counter (e.g. sched_clock) may try to
* call it before it has been initialised. Rather than incur a performance
* penalty checking for initialisation, provide a default implementation that
* won't lead to time appearing to jump backwards.
*/
static u64 arch_timer_read_zero(void)
{
cycle_t cnt = arch_counter_get_cntpct();

/*
* The sched_clock infrastructure only knows about counters
* with at most 32bits. Forget about the upper 24 bits for the
* time being...
*/
return (u32)cnt;
return 0;
}

static u32 notrace arch_counter_get_cntvct32(void)
{
cycle_t cnt = arch_counter_get_cntvct();
u64 (*arch_timer_read_counter)(void) = arch_timer_read_zero;

/*
* The sched_clock infrastructure only knows about counters
* with at most 32bits. Forget about the upper 24 bits for the
* time being...
*/
return (u32)cnt;
static u32 arch_timer_read_counter32(void)
{
return arch_timer_read_counter();
}

static cycle_t arch_counter_read(struct clocksource *cs)
{
/*
* Always use the physical counter for the clocksource.
* CNTHCTL.PL1PCTEN must be set to 1.
*/
return arch_counter_get_cntpct();
return arch_timer_read_counter();
}

static unsigned long arch_timer_read_current_timer(void)
{
return arch_counter_get_cntpct();
return arch_timer_read_counter();
}

static cycle_t arch_counter_read_cc(const struct cyclecounter *cc)
{
/*
* Always use the physical counter for the clocksource.
* CNTHCTL.PL1PCTEN must be set to 1.
*/
return arch_counter_get_cntpct();
return arch_timer_read_counter();
}

static struct clocksource clocksource_counter = {
Expand Down Expand Up @@ -484,23 +470,23 @@ int __init arch_timer_of_register(void)
}
}

if (arch_timer_use_virtual)
arch_timer_read_counter = arch_counter_get_cntvct;
else
arch_timer_read_counter = arch_counter_get_cntpct;

return arch_timer_register();
}

int __init arch_timer_sched_clock_init(void)
{
u32 (*cnt32)(void);
int err;

err = arch_timer_available();
if (err)
return err;

if (arch_timer_use_virtual)
cnt32 = arch_counter_get_cntvct32;
else
cnt32 = arch_counter_get_cntpct32;

setup_sched_clock(cnt32, 32, arch_timer_rate);
setup_sched_clock(arch_timer_read_counter32,
32, arch_timer_rate);
return 0;
}

0 comments on commit e81c9e9

Please sign in to comment.