2021-02-22 13:38:31 +00:00
|
|
|
/*
|
|
|
|
* \brief I2C session client implementation
|
|
|
|
* \author Jean-Adrien Domage <jean-adrien.domage@gapfruit.com>
|
|
|
|
* \date 2021-02-25
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright (C) 2013-2021 Genode Labs GmbH
|
|
|
|
* Copyright (C) 2021 gapfruit AG
|
|
|
|
*
|
|
|
|
* This file is part of the Genode OS framework, which is distributed
|
|
|
|
* under the terms of the GNU Affero General Public License version 3.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _INCLUDE__I2C_SESSION__I2C_SESSION_H_
|
|
|
|
#define _INCLUDE__I2C_SESSION__I2C_SESSION_H_
|
|
|
|
|
|
|
|
#include <session/session.h>
|
|
|
|
#include <base/stdint.h>
|
2021-05-21 14:08:17 +00:00
|
|
|
#include <util/array.h>
|
2021-02-22 13:38:31 +00:00
|
|
|
|
|
|
|
namespace I2c {
|
|
|
|
using namespace Genode;
|
|
|
|
struct Session;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
struct I2c::Session : public Genode::Session
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* \noapi
|
|
|
|
*/
|
|
|
|
static char const *service_name() { return "I2c"; }
|
|
|
|
|
|
|
|
enum { CAP_QUOTA = 2 };
|
|
|
|
|
|
|
|
/**
|
2021-05-21 14:08:17 +00:00
|
|
|
* Exception thrown in case of a bus error
|
2021-02-22 13:38:31 +00:00
|
|
|
*
|
2021-05-21 14:08:17 +00:00
|
|
|
* This exception is thrown by the driver in case of a timeout, device missing
|
|
|
|
* acknowledgement and bus arbitration lost.
|
2021-02-22 13:38:31 +00:00
|
|
|
*/
|
|
|
|
class Bus_error : public Exception {};
|
|
|
|
|
2021-05-21 14:08:17 +00:00
|
|
|
using Byte_array = Array<uint8_t, 8>;
|
2021-02-22 13:38:31 +00:00
|
|
|
|
|
|
|
/**
|
2021-05-21 14:08:17 +00:00
|
|
|
* A message to an I2C slave is either a read or write of one or more bytes
|
2021-02-22 13:38:31 +00:00
|
|
|
*/
|
2021-05-21 14:08:17 +00:00
|
|
|
struct Message : Byte_array
|
|
|
|
{
|
|
|
|
enum Type { READ, WRITE };
|
|
|
|
|
|
|
|
Type type { READ };
|
|
|
|
|
|
|
|
Message() {}
|
|
|
|
|
|
|
|
template<typename ... ARGS>
|
|
|
|
Message(Type type, ARGS ... args)
|
|
|
|
: Byte_array(args...), type(type) {}
|
|
|
|
};
|
2021-02-22 13:38:31 +00:00
|
|
|
|
|
|
|
/**
|
2021-05-21 14:08:17 +00:00
|
|
|
* A transaction to an I2C slave consists of one, or several messages
|
2021-02-22 13:38:31 +00:00
|
|
|
*/
|
2021-05-21 14:08:17 +00:00
|
|
|
struct Transaction : Array<Message,2>
|
|
|
|
{
|
|
|
|
using Base = Array<Message,2>;
|
|
|
|
using Base::Base;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/***********************
|
|
|
|
** Session interface **
|
|
|
|
***********************/
|
2021-02-22 13:38:31 +00:00
|
|
|
|
|
|
|
/**
|
2021-05-21 14:08:17 +00:00
|
|
|
* Initiate a transaction on the bus
|
2021-02-22 13:38:31 +00:00
|
|
|
*
|
2021-05-21 14:08:17 +00:00
|
|
|
* \param transaction The transaction to be transmitted to the I2c host
|
2021-02-22 13:38:31 +00:00
|
|
|
*
|
|
|
|
* \throw I2c::Session::Bus_error An error occured while performing an operation on the bus
|
|
|
|
*/
|
2021-05-21 14:08:17 +00:00
|
|
|
virtual void transmit(Transaction & transaction) = 0;
|
2021-02-22 13:38:31 +00:00
|
|
|
|
2021-05-21 14:08:17 +00:00
|
|
|
GENODE_RPC_THROW(Rpc_transmit, void, transmit,
|
|
|
|
GENODE_TYPE_LIST(Bus_error), Transaction &);
|
|
|
|
|
|
|
|
GENODE_RPC_INTERFACE(Rpc_transmit);
|
2021-02-22 13:38:31 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* _INCLUDE__I2C_SESSION__I2C_SESSION_H_ */
|