2015-04-21 17:21:11 +02:00
|
|
|
/*
|
|
|
|
* \brief Muen subject information API
|
|
|
|
* \author Reto Buerki
|
|
|
|
* \date 2015-04-21
|
|
|
|
*
|
|
|
|
* Defines functions to retrieve information about the execution environment of
|
|
|
|
* a subject running on the Muen Separation Kernel.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2017-02-20 13:23:52 +01:00
|
|
|
* Copyright (C) 2015-2017 Genode Labs GmbH
|
2015-04-21 17:21:11 +02: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.
|
2015-04-21 17:21:11 +02:00
|
|
|
*/
|
|
|
|
|
2015-07-02 16:25:51 +02:00
|
|
|
#ifndef _INCLUDE__SPEC__X86_64__MUEN__SINFO_H_
|
|
|
|
#define _INCLUDE__SPEC__X86_64__MUEN__SINFO_H_
|
2015-04-21 17:21:11 +02:00
|
|
|
|
|
|
|
#include <base/stdint.h>
|
|
|
|
|
2015-07-02 16:25:51 +02:00
|
|
|
struct subject_info_type;
|
2016-12-06 11:50:46 +01:00
|
|
|
struct scheduling_info_type;
|
2015-07-02 16:25:51 +02:00
|
|
|
|
2015-04-21 17:21:11 +02:00
|
|
|
namespace Genode
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Muen Subject Info class
|
|
|
|
*/
|
|
|
|
class Sinfo;
|
|
|
|
}
|
|
|
|
|
|
|
|
class Genode::Sinfo
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
enum Config {
|
2015-07-02 16:25:51 +02:00
|
|
|
PHYSICAL_BASE_ADDR = 0xe00000000,
|
2016-10-04 11:56:16 +02:00
|
|
|
SIZE = 0x9000,
|
2015-07-02 16:25:51 +02:00
|
|
|
MAX_NAME_LENGTH = 63,
|
2016-10-04 11:56:16 +02:00
|
|
|
HASH_LENGTH = 32,
|
2015-04-21 17:21:11 +02:00
|
|
|
};
|
|
|
|
|
2015-07-02 16:25:51 +02:00
|
|
|
Sinfo(const addr_t base_addr);
|
2015-04-21 17:21:11 +02:00
|
|
|
|
2016-10-04 11:56:16 +02:00
|
|
|
enum Content {
|
|
|
|
CONTENT_UNINITIALIZED,
|
|
|
|
CONTENT_FILL,
|
|
|
|
CONTENT_FILE,
|
|
|
|
};
|
|
|
|
|
2015-04-21 17:21:11 +02:00
|
|
|
/* Structure holding information about a memory region */
|
|
|
|
struct Memregion_info {
|
2016-10-04 11:56:16 +02:00
|
|
|
enum Content content;
|
2015-04-21 17:21:11 +02:00
|
|
|
char name[MAX_NAME_LENGTH + 1];
|
|
|
|
uint64_t address;
|
|
|
|
uint64_t size;
|
|
|
|
bool writable;
|
|
|
|
bool executable;
|
2016-10-04 11:56:16 +02:00
|
|
|
uint8_t hash[HASH_LENGTH];
|
|
|
|
uint16_t pattern;
|
2015-04-21 17:21:11 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
/* Structure holding information about a Muen channel */
|
|
|
|
struct Channel_info {
|
|
|
|
char name[MAX_NAME_LENGTH + 1];
|
|
|
|
uint64_t address;
|
|
|
|
uint64_t size;
|
|
|
|
uint8_t event_number;
|
|
|
|
uint8_t vector;
|
|
|
|
bool writable;
|
|
|
|
bool has_event;
|
|
|
|
bool has_vector;
|
|
|
|
};
|
|
|
|
|
2016-02-16 17:08:14 +01:00
|
|
|
/* Structure holding information about PCI devices */
|
|
|
|
struct Dev_info {
|
|
|
|
uint16_t sid;
|
|
|
|
uint16_t irte_start;
|
|
|
|
uint8_t irq_start;
|
|
|
|
uint8_t ir_count;
|
|
|
|
bool msi_capable;
|
|
|
|
};
|
|
|
|
|
2015-04-21 17:21:11 +02:00
|
|
|
/*
|
|
|
|
* Check Muen sinfo Magic.
|
|
|
|
*/
|
2015-07-02 16:25:51 +02:00
|
|
|
bool check_magic(void);
|
2015-04-21 17:21:11 +02:00
|
|
|
|
2016-10-25 19:18:24 +02:00
|
|
|
/*
|
|
|
|
* Return subject name.
|
|
|
|
*
|
|
|
|
* The function returns NULL if the subject name cannot be retrieved.
|
|
|
|
*/
|
|
|
|
const char * const get_subject_name(void);
|
|
|
|
|
2015-04-21 17:21:11 +02:00
|
|
|
/*
|
|
|
|
* Return information for a channel given by name.
|
|
|
|
*
|
|
|
|
* If no channel with given name exists, False is returned. The
|
|
|
|
* event_number and vector parameters are only valid if indicated by
|
|
|
|
* the has_[event|vector] struct members.
|
|
|
|
*/
|
2015-07-02 16:25:51 +02:00
|
|
|
bool get_channel_info(const char * const name,
|
2015-04-21 17:21:11 +02:00
|
|
|
struct Channel_info *channel);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Return information for a memory region given by name.
|
|
|
|
*
|
|
|
|
* If no memory region with given name exists, False is returned.
|
|
|
|
*/
|
2015-07-02 16:25:51 +02:00
|
|
|
bool get_memregion_info(const char * const name,
|
2015-04-21 17:21:11 +02:00
|
|
|
struct Memregion_info *memregion);
|
|
|
|
|
2016-02-16 17:08:14 +01:00
|
|
|
/*
|
|
|
|
* Return information for PCI device with given SID.
|
|
|
|
*
|
|
|
|
* The function returns false if no device information for the
|
|
|
|
* specified device exists.
|
|
|
|
*/
|
2015-07-02 16:25:51 +02:00
|
|
|
bool get_dev_info(const uint16_t sid, struct Dev_info *dev);
|
2016-02-16 17:08:14 +01:00
|
|
|
|
2015-04-21 17:21:11 +02:00
|
|
|
/*
|
|
|
|
* Channel callback.
|
|
|
|
*
|
|
|
|
* Used in the muen_for_each_channel function. The optional void data pointer
|
|
|
|
* can be used to pass additional data.
|
|
|
|
*/
|
|
|
|
typedef bool (*Channel_cb)(const struct Channel_info * const channel,
|
|
|
|
void *data);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Invoke given callback function for each available channel.
|
|
|
|
*
|
|
|
|
* Channel information and the optional data argument are passed to each
|
|
|
|
* invocation of the callback. If a callback invocation returns false,
|
|
|
|
* processing is aborted and false is returned to the caller.
|
|
|
|
*/
|
2015-07-02 16:25:51 +02:00
|
|
|
bool for_each_channel(Channel_cb func, void *data);
|
2015-04-21 17:21:11 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Memory region callback.
|
|
|
|
*
|
|
|
|
* Used in the muen_for_each_memregion function. The optional void data pointer
|
|
|
|
* can be used to pass additional data.
|
|
|
|
*/
|
|
|
|
typedef bool (*Memregion_cb)(const struct Memregion_info * const memregion,
|
|
|
|
void *data);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Invoke given callback function for each available memory region.
|
|
|
|
*
|
|
|
|
* Memory region information and the optional data argument are passed to each
|
|
|
|
* invocation of the callback. If a callback invocation returns false,
|
|
|
|
* processing is aborted and false is returned to the caller.
|
|
|
|
*/
|
2015-07-02 16:25:51 +02:00
|
|
|
bool for_each_memregion(Memregion_cb func, void *data);
|
2015-04-21 17:21:11 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Return TSC tick rate in kHz.
|
|
|
|
*
|
|
|
|
* The function returns 0 if the TSC tick rate cannot be retrieved.
|
|
|
|
*/
|
2015-07-02 16:25:51 +02:00
|
|
|
uint64_t get_tsc_khz(void);
|
2015-04-21 17:21:11 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Return start time of current minor frame in TSC ticks.
|
|
|
|
*/
|
2015-07-02 16:25:51 +02:00
|
|
|
uint64_t get_sched_start(void);
|
2015-04-21 17:21:11 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Return end time of current minor frame in TSC ticks.
|
|
|
|
*/
|
2015-07-02 16:25:51 +02:00
|
|
|
uint64_t get_sched_end(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Log sinfo status.
|
|
|
|
*/
|
|
|
|
void log_status();
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
subject_info_type * sinfo;
|
2016-12-06 11:50:46 +01:00
|
|
|
scheduling_info_type * sched_info;
|
2016-10-25 19:18:24 +02:00
|
|
|
char subject_name[MAX_NAME_LENGTH + 1];
|
|
|
|
bool subject_name_set = false;
|
2015-07-02 16:25:51 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Fill memregion struct with memory region info from resource given by
|
|
|
|
* index.
|
|
|
|
*/
|
|
|
|
void fill_memregion_data(uint8_t idx, struct Memregion_info *region);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Fill channel struct with channel information from resource given by
|
|
|
|
* index.
|
|
|
|
*/
|
|
|
|
void fill_channel_data(uint8_t idx, struct Channel_info *channel);
|
|
|
|
|
|
|
|
/* Fill dev struct with data from PCI device info given by index. */
|
|
|
|
void fill_dev_data(uint8_t idx, struct Dev_info *dev);
|
2015-04-21 17:21:11 +02:00
|
|
|
};
|
|
|
|
|
2015-07-02 16:25:51 +02:00
|
|
|
#endif /* _INCLUDE__SPEC__X86_64__MUEN__SINFO_H_ */
|