1*c04cf9e1SMario Limonciello /* SPDX-License-Identifier: GPL-2.0-only */ 2*c04cf9e1SMario Limonciello /* 3*c04cf9e1SMario Limonciello * AMD Platform Security Processor (PSP) Dynamic Boost Control support 4*c04cf9e1SMario Limonciello * 5*c04cf9e1SMario Limonciello * Copyright (C) 2023 Advanced Micro Devices, Inc. 6*c04cf9e1SMario Limonciello * 7*c04cf9e1SMario Limonciello * Author: Mario Limonciello <mario.limonciello@amd.com> 8*c04cf9e1SMario Limonciello */ 9*c04cf9e1SMario Limonciello 10*c04cf9e1SMario Limonciello #ifndef __DBC_H__ 11*c04cf9e1SMario Limonciello #define __DBC_H__ 12*c04cf9e1SMario Limonciello 13*c04cf9e1SMario Limonciello #include <uapi/linux/psp-dbc.h> 14*c04cf9e1SMario Limonciello 15*c04cf9e1SMario Limonciello #include <linux/device.h> 16*c04cf9e1SMario Limonciello #include <linux/miscdevice.h> 17*c04cf9e1SMario Limonciello #include <linux/psp-platform-access.h> 18*c04cf9e1SMario Limonciello 19*c04cf9e1SMario Limonciello #include "psp-dev.h" 20*c04cf9e1SMario Limonciello 21*c04cf9e1SMario Limonciello struct psp_dbc_device { 22*c04cf9e1SMario Limonciello struct device *dev; 23*c04cf9e1SMario Limonciello 24*c04cf9e1SMario Limonciello union dbc_buffer *mbox; 25*c04cf9e1SMario Limonciello 26*c04cf9e1SMario Limonciello struct mutex ioctl_mutex; 27*c04cf9e1SMario Limonciello 28*c04cf9e1SMario Limonciello struct miscdevice char_dev; 29*c04cf9e1SMario Limonciello }; 30*c04cf9e1SMario Limonciello 31*c04cf9e1SMario Limonciello struct dbc_nonce { 32*c04cf9e1SMario Limonciello struct psp_req_buffer_hdr header; 33*c04cf9e1SMario Limonciello struct dbc_user_nonce user; 34*c04cf9e1SMario Limonciello } __packed; 35*c04cf9e1SMario Limonciello 36*c04cf9e1SMario Limonciello union dbc_buffer { 37*c04cf9e1SMario Limonciello struct psp_request req; 38*c04cf9e1SMario Limonciello struct dbc_nonce dbc_nonce; 39*c04cf9e1SMario Limonciello }; 40*c04cf9e1SMario Limonciello 41*c04cf9e1SMario Limonciello void dbc_dev_destroy(struct psp_device *psp); 42*c04cf9e1SMario Limonciello int dbc_dev_init(struct psp_device *psp); 43*c04cf9e1SMario Limonciello 44*c04cf9e1SMario Limonciello #endif /* __DBC_H */ 45