mirror of
https://github.com/genodelabs/genode.git
synced 2025-01-01 19:46:45 +00:00
parent
edb48873c1
commit
5bbcbc74bb
117
os/src/drivers/timer/hw/epit/platform_timer_base.h
Normal file
117
os/src/drivers/timer/hw/epit/platform_timer_base.h
Normal file
@ -0,0 +1,117 @@
|
|||||||
|
/*
|
||||||
|
* \brief Basic driver behind platform timer
|
||||||
|
* \author Stefan Kalkowski
|
||||||
|
* \date 2012-10-25
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2012 Genode Labs GmbH
|
||||||
|
*
|
||||||
|
* This file is part of the Genode OS framework, which is distributed
|
||||||
|
* under the terms of the GNU General Public License version 2.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _HW__EPIT__PLATFORM_TIMER_BASE_H_
|
||||||
|
#define _HW__EPIT__PLATFORM_TIMER_BASE_H_
|
||||||
|
|
||||||
|
/* Genode includes */
|
||||||
|
#include <io_mem_session/connection.h>
|
||||||
|
#include <util/mmio.h>
|
||||||
|
#include <irq_session/connection.h>
|
||||||
|
#include <drivers/board_base.h>
|
||||||
|
#include <drivers/timer/epit_base.h>
|
||||||
|
|
||||||
|
namespace Genode
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Epit timer
|
||||||
|
*/
|
||||||
|
class Epit : public Epit_base
|
||||||
|
{
|
||||||
|
private:
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Timer tics per microsecond
|
||||||
|
*/
|
||||||
|
static float tics_per_us() {
|
||||||
|
return (float)TICS_PER_MS / 1000.0; }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Microseconds per timer tic
|
||||||
|
*/
|
||||||
|
static float us_per_tic() { return 1.0 / tics_per_us(); }
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor
|
||||||
|
*
|
||||||
|
* \param base MMIO base
|
||||||
|
*/
|
||||||
|
Epit(addr_t const base) : Epit_base(base) { }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Count down 'value', raise IRQ output, wrap counter and continue
|
||||||
|
*/
|
||||||
|
void run_and_wrap(unsigned long value) {
|
||||||
|
start_one_shot(value); }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Maximum timeout value
|
||||||
|
*/
|
||||||
|
unsigned long max_value() {
|
||||||
|
return read<Lr>(); }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Translate timer tics to microseconds
|
||||||
|
*/
|
||||||
|
unsigned long tics_to_us(unsigned long const tics)
|
||||||
|
{
|
||||||
|
float const us = tics * us_per_tic();
|
||||||
|
return (unsigned long)us;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Translate microseconds to timer tics
|
||||||
|
*/
|
||||||
|
unsigned long us_to_tics(unsigned long const us)
|
||||||
|
{
|
||||||
|
float const tics = us * tics_per_us();
|
||||||
|
return (unsigned long)tics;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sample the timer counter and according wrapped status
|
||||||
|
*/
|
||||||
|
unsigned long value(bool & wrapped)
|
||||||
|
{
|
||||||
|
unsigned long v = read<Cnt>();
|
||||||
|
wrapped = (bool)read<Sr::Ocif>();
|
||||||
|
return wrapped ? read<Cnt>() : v;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Basic driver behind platform timer
|
||||||
|
*/
|
||||||
|
class Platform_timer_base : public Genode::Io_mem_connection,
|
||||||
|
public Genode::Epit
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
|
enum { IRQ = Genode::Board_base::EPIT_2_IRQ };
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor
|
||||||
|
*/
|
||||||
|
Platform_timer_base()
|
||||||
|
: Io_mem_connection(Genode::Board_base::EPIT_2_MMIO_BASE,
|
||||||
|
Genode::Board_base::EPIT_2_MMIO_SIZE),
|
||||||
|
Genode::Epit((Genode::addr_t)Genode::env()->rm_session()
|
||||||
|
->attach(dataspace()))
|
||||||
|
{ }
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif /* _HW__EPIT__PLATFORM_TIMER_BASE_H_ */
|
||||||
|
|
24
os/src/drivers/timer/hw/epit/target.mk
Normal file
24
os/src/drivers/timer/hw/epit/target.mk
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
#
|
||||||
|
# \brief Timer session server
|
||||||
|
# \author Stefan Kalkowski
|
||||||
|
# \date 2012-10-25
|
||||||
|
#
|
||||||
|
|
||||||
|
# set program name
|
||||||
|
TARGET = timer
|
||||||
|
|
||||||
|
# add C++ sources
|
||||||
|
SRC_CC += main.cc
|
||||||
|
|
||||||
|
# skip build if required specs not fullfilled
|
||||||
|
REQUIRES += hw epit
|
||||||
|
|
||||||
|
# add libraries
|
||||||
|
LIBS += cxx server env alarm
|
||||||
|
|
||||||
|
# add include paths
|
||||||
|
INC_DIR += $(PRG_DIR) $(PRG_DIR)/../ $(PRG_DIR)/../../nova/
|
||||||
|
|
||||||
|
# declare source paths
|
||||||
|
vpath main.cc $(PRG_DIR)/../..
|
||||||
|
|
Loading…
Reference in New Issue
Block a user