2013-04-16 18:45:17 +04:00
|
|
|
/*
|
|
|
|
* libqos fw_cfg support
|
|
|
|
*
|
|
|
|
* Copyright IBM, Corp. 2012-2013
|
|
|
|
*
|
|
|
|
* Authors:
|
|
|
|
* Anthony Liguori <aliguori@us.ibm.com>
|
|
|
|
*
|
|
|
|
* This work is licensed under the terms of the GNU GPL, version 2 or later.
|
|
|
|
* See the COPYING file in the top-level directory.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef LIBQOS_FW_CFG_H
|
|
|
|
#define LIBQOS_FW_CFG_H
|
|
|
|
|
2017-09-11 20:19:57 +03:00
|
|
|
#include "libqtest.h"
|
2013-04-16 18:45:17 +04:00
|
|
|
|
|
|
|
typedef struct QFWCFG QFWCFG;
|
|
|
|
|
|
|
|
struct QFWCFG
|
|
|
|
{
|
2013-06-26 17:52:15 +04:00
|
|
|
uint64_t base;
|
2017-09-11 20:19:57 +03:00
|
|
|
QTestState *qts;
|
2013-04-16 18:45:17 +04:00
|
|
|
void (*select)(QFWCFG *fw_cfg, uint16_t key);
|
|
|
|
void (*read)(QFWCFG *fw_cfg, void *data, size_t len);
|
|
|
|
};
|
|
|
|
|
|
|
|
void qfw_cfg_select(QFWCFG *fw_cfg, uint16_t key);
|
|
|
|
void qfw_cfg_read_data(QFWCFG *fw_cfg, void *data, size_t len);
|
|
|
|
void qfw_cfg_get(QFWCFG *fw_cfg, uint16_t key, void *data, size_t len);
|
|
|
|
uint16_t qfw_cfg_get_u16(QFWCFG *fw_cfg, uint16_t key);
|
|
|
|
uint32_t qfw_cfg_get_u32(QFWCFG *fw_cfg, uint16_t key);
|
|
|
|
uint64_t qfw_cfg_get_u64(QFWCFG *fw_cfg, uint16_t key);
|
|
|
|
|
2017-09-11 20:19:57 +03:00
|
|
|
QFWCFG *mm_fw_cfg_init(QTestState *qts, uint64_t base);
|
|
|
|
QFWCFG *io_fw_cfg_init(QTestState *qts, uint16_t base);
|
2013-06-26 17:52:22 +04:00
|
|
|
|
2017-09-11 20:19:57 +03:00
|
|
|
static inline QFWCFG *pc_fw_cfg_init(QTestState *qts)
|
2013-06-26 17:52:22 +04:00
|
|
|
{
|
2017-09-11 20:19:57 +03:00
|
|
|
return io_fw_cfg_init(qts, 0x510);
|
2013-06-26 17:52:22 +04:00
|
|
|
}
|
2013-06-26 17:52:15 +04:00
|
|
|
|
2013-04-16 18:45:17 +04:00
|
|
|
#endif
|