| /* SPDX-License-Identifier: GPL-2.0-only */ |
| |
| #ifndef __PSP_PLATFORM_ACCESS_H |
| #define __PSP_PLATFORM_ACCESS_H |
| |
| #include <linux/psp.h> |
| |
| enum psp_platform_access_msg { |
| PSP_CMD_NONE = 0x0, |
| PSP_I2C_REQ_BUS_CMD = 0x64, |
| PSP_DYNAMIC_BOOST_GET_NONCE, |
| PSP_DYNAMIC_BOOST_SET_UID, |
| PSP_DYNAMIC_BOOST_GET_PARAMETER, |
| PSP_DYNAMIC_BOOST_SET_PARAMETER, |
| }; |
| |
| struct psp_req_buffer_hdr { |
| u32 payload_size; |
| u32 status; |
| } __packed; |
| |
| struct psp_request { |
| struct psp_req_buffer_hdr header; |
| void *buf; |
| } __packed; |
| |
| /** |
| * psp_send_platform_access_msg() - Send a message to control platform features |
| * |
| * This function is intended to be used by drivers outside of ccp to communicate |
| * with the platform. |
| * |
| * Returns: |
| * 0: success |
| * -%EBUSY: mailbox in recovery or in use |
| * -%ENODEV: driver not bound with PSP device |
| * -%ETIMEDOUT: request timed out |
| * -%EIO: unknown error (see kernel log) |
| */ |
| int psp_send_platform_access_msg(enum psp_platform_access_msg, struct psp_request *req); |
| |
| /** |
| * psp_ring_platform_doorbell() - Ring platform doorbell |
| * |
| * This function is intended to be used by drivers outside of ccp to ring the |
| * platform doorbell with a message. |
| * |
| * Returns: |
| * 0: success |
| * -%EBUSY: mailbox in recovery or in use |
| * -%ENODEV: driver not bound with PSP device |
| * -%ETIMEDOUT: request timed out |
| * -%EIO: error will be stored in result argument |
| */ |
| int psp_ring_platform_doorbell(int msg, u32 *result); |
| |
| /** |
| * psp_check_platform_access_status() - Checks whether platform features is ready |
| * |
| * This function is intended to be used by drivers outside of ccp to determine |
| * if platform features has initialized. |
| * |
| * Returns: |
| * 0 platform features is ready |
| * -%ENODEV platform features is not ready or present |
| */ |
| int psp_check_platform_access_status(void); |
| |
| #endif /* __PSP_PLATFORM_ACCESS_H */ |