mirror of
https://github.com/riscv-software-src/opensbi.git
synced 2026-07-02 22:02:01 +01:00
lib: utils/mpxy: Add RPMI MPXY driver for logging service group
Add RPMI MPXY proxy driver for LOGGING service group so that S-mode can leverage LOGGING service group implemented by the platform microcontroller. Reviewed-by: Rahul Pathak <rahul.pathak@oss.qualcomm.com> Signed-off-by: Subrahmanya Lingappa <subrahmanya.lingappa@oss.qualcomm.com> Link: https://lore.kernel.org/r/20260619103424.990954-1-subrahmanya.lingappa@oss.qualcomm.com Signed-off-by: Anup Patel <anup@brainfault.org>
This commit is contained in:
committed by
Anup Patel
parent
cbf9f6734d
commit
262571217c
@@ -225,6 +225,7 @@ enum rpmi_servicegroup_id {
|
|||||||
RPMI_SRVGRP_DEVICE_POWER = 0x0009,
|
RPMI_SRVGRP_DEVICE_POWER = 0x0009,
|
||||||
RPMI_SRVGRP_PERFORMANCE = 0x0000A,
|
RPMI_SRVGRP_PERFORMANCE = 0x0000A,
|
||||||
RPMI_SRVGRP_MANAGEMENT_MODE = 0x000B,
|
RPMI_SRVGRP_MANAGEMENT_MODE = 0x000B,
|
||||||
|
RPMI_SRVGRP_LOGGING = 0x000E,
|
||||||
RPMI_SRVGRP_ID_MAX_COUNT,
|
RPMI_SRVGRP_ID_MAX_COUNT,
|
||||||
|
|
||||||
/* Reserved range for service groups */
|
/* Reserved range for service groups */
|
||||||
@@ -1045,4 +1046,22 @@ struct rpmi_mm_communicate_rsp {
|
|||||||
u32 mm_comm_retdata_size;
|
u32 mm_comm_retdata_size;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/** RPMI LOGGING ServiceGroup Service IDs */
|
||||||
|
enum rpmi_logging_service_id {
|
||||||
|
RPMI_LOGGING_SRV_ENABLE_NOTIFICATION = 0x01,
|
||||||
|
RPMI_LOGGING_SRV_LOG_DATA = 0x02,
|
||||||
|
RPMI_LOGGING_SRV_MAX_COUNT,
|
||||||
|
};
|
||||||
|
|
||||||
|
struct rpmi_logging_log_data_req {
|
||||||
|
u32 type;
|
||||||
|
u32 num_dwords;
|
||||||
|
#define MAX_LOGGING_DLEN ((RPMI_MSG_DATA_SIZE(RPMI_SLOT_SIZE_MIN) - (sizeof(u32) * 2)) / sizeof(u32))
|
||||||
|
u32 data[MAX_LOGGING_DLEN];
|
||||||
|
};
|
||||||
|
|
||||||
|
struct rpmi_logging_log_data_resp {
|
||||||
|
s32 status;
|
||||||
|
};
|
||||||
|
|
||||||
#endif /* !__RPMI_MSGPROT_H__ */
|
#endif /* !__RPMI_MSGPROT_H__ */
|
||||||
|
|||||||
@@ -18,6 +18,10 @@ config FDT_MPXY_RPMI_CLOCK
|
|||||||
bool "MPXY driver for RPMI clock service group"
|
bool "MPXY driver for RPMI clock service group"
|
||||||
default n
|
default n
|
||||||
|
|
||||||
|
config FDT_MPXY_RPMI_LOGGING
|
||||||
|
bool "MPXY driver for RPMI logging service group"
|
||||||
|
default n
|
||||||
|
|
||||||
config FDT_MPXY_RPMI_SYSMSI
|
config FDT_MPXY_RPMI_SYSMSI
|
||||||
bool "MPXY driver for RPMI system MSI service group"
|
bool "MPXY driver for RPMI system MSI service group"
|
||||||
default n
|
default n
|
||||||
|
|||||||
@@ -0,0 +1,51 @@
|
|||||||
|
/*
|
||||||
|
* SPDX-License-Identifier: BSD-2-Clause
|
||||||
|
*
|
||||||
|
* Copyright (c) 2026 Qualcomm, Inc
|
||||||
|
*
|
||||||
|
* Authors:
|
||||||
|
* Subrahmanya Lingappa <subrahmanya.lingappa@oss.qualcomm.com>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <sbi_utils/mpxy/fdt_mpxy_rpmi_mbox.h>
|
||||||
|
|
||||||
|
static struct mpxy_rpmi_service_data logging_services[] = {
|
||||||
|
[0] = {
|
||||||
|
.id = RPMI_MM_SRV_ENABLE_NOTIFICATION,
|
||||||
|
.min_tx_len = sizeof(struct rpmi_enable_notification_req),
|
||||||
|
.max_tx_len = sizeof(struct rpmi_enable_notification_req),
|
||||||
|
.min_rx_len = sizeof(struct rpmi_enable_notification_resp),
|
||||||
|
.max_rx_len = sizeof(struct rpmi_enable_notification_resp),
|
||||||
|
},
|
||||||
|
[1] = {
|
||||||
|
.id = RPMI_LOGGING_SRV_LOG_DATA,
|
||||||
|
.min_tx_len = sizeof(u32) * 2,
|
||||||
|
.max_tx_len = sizeof(struct rpmi_logging_log_data_req),
|
||||||
|
.min_rx_len = sizeof(struct rpmi_logging_log_data_resp),
|
||||||
|
.max_rx_len = sizeof(struct rpmi_logging_log_data_resp),
|
||||||
|
},
|
||||||
|
/*
|
||||||
|
* Keep a local terminator for safe lookup because only service ID 0x02
|
||||||
|
* is intentionally exposed by this MPXY service group handler.
|
||||||
|
*/
|
||||||
|
[2] = {
|
||||||
|
.id = RPMI_LOGGING_SRV_MAX_COUNT,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct mpxy_rpmi_mbox_data logging_data = {
|
||||||
|
.servicegrp_id = RPMI_SRVGRP_LOGGING,
|
||||||
|
.num_services = RPMI_LOGGING_SRV_MAX_COUNT,
|
||||||
|
.service_data = logging_services,
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct fdt_match logging_match[] = {
|
||||||
|
{ .compatible = "riscv,rpmi-mpxy-logging", .data = &logging_data },
|
||||||
|
{ },
|
||||||
|
};
|
||||||
|
|
||||||
|
const struct fdt_driver fdt_mpxy_rpmi_logging = {
|
||||||
|
.match_table = logging_match,
|
||||||
|
.init = mpxy_rpmi_mbox_init,
|
||||||
|
.experimental = true,
|
||||||
|
};
|
||||||
@@ -29,3 +29,6 @@ libsbiutils-objs-$(CONFIG_FDT_MPXY_RPMI_DEVICE_POWER) += mpxy/fdt_mpxy_rpmi_devi
|
|||||||
|
|
||||||
carray-fdt_mpxy_drivers-$(CONFIG_FDT_MPXY_RPMI_MM) += fdt_mpxy_rpmi_mm
|
carray-fdt_mpxy_drivers-$(CONFIG_FDT_MPXY_RPMI_MM) += fdt_mpxy_rpmi_mm
|
||||||
libsbiutils-objs-$(CONFIG_FDT_MPXY_RPMI_MM) += mpxy/fdt_mpxy_rpmi_mm.o
|
libsbiutils-objs-$(CONFIG_FDT_MPXY_RPMI_MM) += mpxy/fdt_mpxy_rpmi_mm.o
|
||||||
|
|
||||||
|
carray-fdt_mpxy_drivers-$(CONFIG_FDT_MPXY_RPMI_LOGGING) += fdt_mpxy_rpmi_logging
|
||||||
|
libsbiutils-objs-$(CONFIG_FDT_MPXY_RPMI_LOGGING) += mpxy/fdt_mpxy_rpmi_logging.o
|
||||||
|
|||||||
@@ -83,3 +83,4 @@ CONFIG_FDT_MPXY_RPMI_DEVICE_POWER=y
|
|||||||
CONFIG_FDT_MPXY_RPMI_PERFORMANCE=y
|
CONFIG_FDT_MPXY_RPMI_PERFORMANCE=y
|
||||||
CONFIG_FDT_MPXY_RPMI_SYSMSI=y
|
CONFIG_FDT_MPXY_RPMI_SYSMSI=y
|
||||||
CONFIG_FDT_MPXY_RPMI_MM=y
|
CONFIG_FDT_MPXY_RPMI_MM=y
|
||||||
|
CONFIG_FDT_MPXY_RPMI_LOGGING=y
|
||||||
|
|||||||
Reference in New Issue
Block a user