2012-01-09 13:29:03 +01:00
|
|
|
/*
|
2016-12-09 12:18:18 +01:00
|
|
|
* \brief Type-safe, fine-grained access to a continuous MMIO region
|
2012-01-09 13:29:03 +01:00
|
|
|
* \author Martin stein
|
|
|
|
* \date 2011-10-26
|
|
|
|
*/
|
|
|
|
|
2012-01-10 12:56:45 +01:00
|
|
|
/*
|
2017-02-20 13:23:52 +01:00
|
|
|
* Copyright (C) 2011-2017 Genode Labs GmbH
|
2012-01-10 12:56:45 +01:00
|
|
|
*
|
|
|
|
* This file is part of the Genode OS framework, which is distributed
|
2017-02-20 13:23:52 +01:00
|
|
|
* under the terms of the GNU Affero General Public License version 3.
|
2012-01-10 12:56:45 +01:00
|
|
|
*/
|
|
|
|
|
2012-07-10 10:23:05 +02:00
|
|
|
#ifndef _INCLUDE__UTIL__MMIO_H_
|
|
|
|
#define _INCLUDE__UTIL__MMIO_H_
|
2012-01-09 13:29:03 +01:00
|
|
|
|
2012-05-24 11:56:54 +02:00
|
|
|
/* Genode includes */
|
2016-12-09 12:18:18 +01:00
|
|
|
#include <util/register_set.h>
|
2012-01-09 13:29:03 +01:00
|
|
|
|
2016-12-09 12:18:18 +01:00
|
|
|
namespace Genode {
|
2015-03-04 21:12:14 +01:00
|
|
|
|
2016-12-09 12:18:18 +01:00
|
|
|
class Mmio_plain_access;
|
|
|
|
class Mmio;
|
|
|
|
}
|
2015-03-04 21:12:14 +01:00
|
|
|
|
|
|
|
/**
|
2016-12-09 12:18:18 +01:00
|
|
|
* Plain access implementation for MMIO
|
2015-03-04 21:12:14 +01:00
|
|
|
*/
|
2016-12-09 12:18:18 +01:00
|
|
|
class Genode::Mmio_plain_access
|
2012-01-09 13:29:03 +01:00
|
|
|
{
|
2016-12-09 12:18:18 +01:00
|
|
|
friend Register_set_plain_access;
|
2015-03-04 21:12:14 +01:00
|
|
|
|
2016-12-09 12:18:18 +01:00
|
|
|
private:
|
2012-01-09 13:29:03 +01:00
|
|
|
|
2017-03-06 13:56:33 +01:00
|
|
|
addr_t const _base;
|
2012-07-10 10:23:05 +02:00
|
|
|
|
2015-03-04 21:12:14 +01:00
|
|
|
/**
|
2016-12-09 12:18:18 +01:00
|
|
|
* Write '_ACCESS_T' typed 'value' to MMIO base + 'offset'
|
2015-03-04 21:12:14 +01:00
|
|
|
*/
|
2016-12-09 12:18:18 +01:00
|
|
|
template <typename ACCESS_T>
|
|
|
|
inline void _write(off_t const offset, ACCESS_T const value)
|
2015-03-04 21:12:14 +01:00
|
|
|
{
|
2017-03-06 13:56:33 +01:00
|
|
|
addr_t const dst = _base + offset;
|
2016-12-09 12:18:18 +01:00
|
|
|
*(ACCESS_T volatile *)dst = value;
|
2015-03-04 21:12:14 +01:00
|
|
|
}
|
2012-01-09 13:29:03 +01:00
|
|
|
|
2015-03-04 21:12:14 +01:00
|
|
|
/**
|
2016-12-09 12:18:18 +01:00
|
|
|
* Read '_ACCESS_T' typed from MMIO base + 'offset'
|
2015-03-04 21:12:14 +01:00
|
|
|
*/
|
2016-12-09 12:18:18 +01:00
|
|
|
template <typename ACCESS_T>
|
|
|
|
inline ACCESS_T _read(off_t const &offset) const
|
2015-03-04 21:12:14 +01:00
|
|
|
{
|
2017-03-06 13:56:33 +01:00
|
|
|
addr_t const dst = _base + offset;
|
2016-12-09 12:18:18 +01:00
|
|
|
ACCESS_T const value = *(ACCESS_T volatile *)dst;
|
|
|
|
return value;
|
2015-03-04 21:12:14 +01:00
|
|
|
}
|
2012-01-09 13:29:03 +01:00
|
|
|
|
2016-12-09 12:18:18 +01:00
|
|
|
public:
|
2012-07-03 13:06:29 +02:00
|
|
|
|
2015-03-04 21:12:14 +01:00
|
|
|
/**
|
2016-12-09 12:18:18 +01:00
|
|
|
* Constructor
|
2015-03-04 21:12:14 +01:00
|
|
|
*
|
2016-12-09 12:18:18 +01:00
|
|
|
* \param base base address of targeted MMIO region
|
2015-03-04 21:12:14 +01:00
|
|
|
*/
|
2017-03-06 13:56:33 +01:00
|
|
|
Mmio_plain_access(addr_t const base) : _base(base) { }
|
|
|
|
|
|
|
|
addr_t base() const { return _base; }
|
2016-12-09 12:18:18 +01:00
|
|
|
};
|
2015-03-04 21:12:14 +01:00
|
|
|
|
|
|
|
|
2016-12-09 12:18:18 +01:00
|
|
|
/**
|
|
|
|
* Type-safe, fine-grained access to a continuous MMIO region
|
|
|
|
*
|
|
|
|
* For further details refer to the documentation of the 'Register_set' class.
|
|
|
|
*/
|
|
|
|
struct Genode::Mmio : Mmio_plain_access, Register_set<Mmio_plain_access>
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Constructor
|
|
|
|
*
|
|
|
|
* \param base base address of targeted MMIO region
|
|
|
|
*/
|
|
|
|
Mmio(addr_t const base)
|
|
|
|
:
|
|
|
|
Mmio_plain_access(base),
|
|
|
|
Register_set(*static_cast<Mmio_plain_access *>(this)) { }
|
2015-03-04 21:12:14 +01:00
|
|
|
};
|
2012-01-09 13:29:03 +01:00
|
|
|
|
2012-07-10 10:23:05 +02:00
|
|
|
#endif /* _INCLUDE__UTIL__MMIO_H_ */
|