162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * AMD Platform Security Processor (PSP) Dynamic Boost Control support 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright (C) 2023 Advanced Micro Devices, Inc. 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * Author: Mario Limonciello <mario.limonciello@amd.com> 862306a36Sopenharmony_ci */ 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci#ifndef __DBC_H__ 1162306a36Sopenharmony_ci#define __DBC_H__ 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_ci#include <uapi/linux/psp-dbc.h> 1462306a36Sopenharmony_ci 1562306a36Sopenharmony_ci#include <linux/device.h> 1662306a36Sopenharmony_ci#include <linux/miscdevice.h> 1762306a36Sopenharmony_ci#include <linux/psp-platform-access.h> 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_ci#include "psp-dev.h" 2062306a36Sopenharmony_ci 2162306a36Sopenharmony_cistruct psp_dbc_device { 2262306a36Sopenharmony_ci struct device *dev; 2362306a36Sopenharmony_ci 2462306a36Sopenharmony_ci union dbc_buffer *mbox; 2562306a36Sopenharmony_ci 2662306a36Sopenharmony_ci struct mutex ioctl_mutex; 2762306a36Sopenharmony_ci 2862306a36Sopenharmony_ci struct miscdevice char_dev; 2962306a36Sopenharmony_ci}; 3062306a36Sopenharmony_ci 3162306a36Sopenharmony_cistruct dbc_nonce { 3262306a36Sopenharmony_ci struct psp_req_buffer_hdr header; 3362306a36Sopenharmony_ci struct dbc_user_nonce user; 3462306a36Sopenharmony_ci} __packed; 3562306a36Sopenharmony_ci 3662306a36Sopenharmony_cistruct dbc_set_uid { 3762306a36Sopenharmony_ci struct psp_req_buffer_hdr header; 3862306a36Sopenharmony_ci struct dbc_user_setuid user; 3962306a36Sopenharmony_ci} __packed; 4062306a36Sopenharmony_ci 4162306a36Sopenharmony_cistruct dbc_param { 4262306a36Sopenharmony_ci struct psp_req_buffer_hdr header; 4362306a36Sopenharmony_ci struct dbc_user_param user; 4462306a36Sopenharmony_ci} __packed; 4562306a36Sopenharmony_ci 4662306a36Sopenharmony_ciunion dbc_buffer { 4762306a36Sopenharmony_ci struct psp_request req; 4862306a36Sopenharmony_ci struct dbc_nonce dbc_nonce; 4962306a36Sopenharmony_ci struct dbc_set_uid dbc_set_uid; 5062306a36Sopenharmony_ci struct dbc_param dbc_param; 5162306a36Sopenharmony_ci}; 5262306a36Sopenharmony_ci 5362306a36Sopenharmony_civoid dbc_dev_destroy(struct psp_device *psp); 5462306a36Sopenharmony_ciint dbc_dev_init(struct psp_device *psp); 5562306a36Sopenharmony_ci 5662306a36Sopenharmony_ci#endif /* __DBC_H */ 57