blob: 36db724708b42218c7503e76ec4515cc0b0b434f [file] [log] [blame] [edit]
/* SPDX-License-Identifier: GPL-2.0 */
/*
* Copyright (C) 2017-2018, Intel Corporation
*/
#ifndef __STRATIX10_SMC_H
#define __STRATIX10_SMC_H
#include <linux/arm-smccc.h>
#include <linux/bitops.h>
/**
* This file defines the Secure Monitor Call (SMC) message protocol used for
* service layer driver in normal world (EL1) to communicate with secure
* monitor software in Secure Monitor Exception Level 3 (EL3).
*
* This file is shared with secure firmware (FW) which is out of kernel tree.
*
* An ARM SMC instruction takes a function identifier and up to 6 64-bit
* register values as arguments, and can return up to 4 64-bit register
* value. The operation of the secure monitor is determined by the parameter
* values passed in through registers.
*
* EL1 and EL3 communicates pointer as physical address rather than the
* virtual address.
*
* Functions specified by ARM SMC Calling convention:
*
* FAST call executes atomic operations, returns when the requested operation
* has completed.
* STD call starts a operation which can be preempted by a non-secure
* interrupt. The call can return before the requested operation has
* completed.
*
* a0..a7 is used as register names in the descriptions below, on arm32
* that translates to r0..r7 and on arm64 to w0..w7.
*/
/**
* @func_num: function ID
*/
#define INTEL_SIP_SMC_STD_CALL_VAL(func_num) \
ARM_SMCCC_CALL_VAL(ARM_SMCCC_STD_CALL, ARM_SMCCC_SMC_64, \
ARM_SMCCC_OWNER_SIP, (func_num))
#define INTEL_SIP_SMC_FAST_CALL_VAL(func_num) \
ARM_SMCCC_CALL_VAL(ARM_SMCCC_FAST_CALL, ARM_SMCCC_SMC_64, \
ARM_SMCCC_OWNER_SIP, (func_num))
/**
* Return values in INTEL_SIP_SMC_* call
*
* INTEL_SIP_SMC_RETURN_UNKNOWN_FUNCTION:
* Secure monitor software doesn't recognize the request.
*
* INTEL_SIP_SMC_STATUS_OK:
* Secure monitor software accepts the service client's request.
*
* INTEL_SIP_SMC_STATUS_BUSY:
* Secure monitor software is still processing service client's request.
*
* INTEL_SIP_SMC_STATUS_REJECTED:
* Secure monitor software reject the service client's request.
*
* INTEL_SIP_SMC_STATUS_NO_RESPONSE:
* Secure monitor software doesn't recieve any response for the
* service client's request yet.
*
* INTEL_SIP_SMC_STATUS_ERROR:
* There is error during the process of service request.
*
* INTEL_SIP_SMC_RSU_ERROR:
* There is error during the process of remote status update request.
*
* INTEL_SIP_SMC_STATUS_NOT_SUPPORTED:
* Secure monitor software doesn't support the request
*/
#define INTEL_SIP_SMC_RETURN_UNKNOWN_FUNCTION 0xFFFFFFFF
#define INTEL_SIP_SMC_STATUS_OK 0x0
#define INTEL_SIP_SMC_STATUS_BUSY 0x1
#define INTEL_SIP_SMC_STATUS_REJECTED 0x2
#define INTEL_SIP_SMC_STATUS_NO_RESPONSE 0x3
#define INTEL_SIP_SMC_STATUS_ERROR 0x4
#define INTEL_SIP_SMC_RSU_ERROR 0x7
#define INTEL_SIP_SMC_STATUS_NOT_SUPPORTED 0x8
/**
* Request INTEL_SIP_SMC_FPGA_CONFIG_START
*
* Sync call used by service driver at EL1 to request the FPGA in EL3 to
* be prepare to receive a new configuration.
*
* Call register usage:
* a0: INTEL_SIP_SMC_FPGA_CONFIG_START.
* a1: flag for full or partial configuration. 0 for full and 1 for partial
* configuration.
* a2-7: not used.
*
* Return status:
* a0: INTEL_SIP_SMC_STATUS_OK, or INTEL_SIP_SMC_STATUS_ERROR.
* a1-3: not used.
*/
#define INTEL_SIP_SMC_FUNCID_FPGA_CONFIG_START 1
#define INTEL_SIP_SMC_FPGA_CONFIG_START \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FPGA_CONFIG_START)
/**
* Request INTEL_SIP_SMC_FPGA_CONFIG_WRITE
*
* Async call used by service driver at EL1 to provide FPGA configuration data
* to secure world.
*
* Call register usage:
* a0: INTEL_SIP_SMC_FPGA_CONFIG_WRITE.
* a1: 64bit physical address of the configuration data memory block
* a2: Size of configuration data block.
* a3-7: not used.
*
* Return status:
* a0: INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_BUSY or
* INTEL_SIP_SMC_STATUS_ERROR.
* a1: 64bit physical address of 1st completed memory block if any completed
* block, otherwise zero value.
* a2: 64bit physical address of 2nd completed memory block if any completed
* block, otherwise zero value.
* a3: 64bit physical address of 3rd completed memory block if any completed
* block, otherwise zero value.
*/
#define INTEL_SIP_SMC_FUNCID_FPGA_CONFIG_WRITE 2
#define INTEL_SIP_SMC_FPGA_CONFIG_WRITE \
INTEL_SIP_SMC_STD_CALL_VAL(INTEL_SIP_SMC_FUNCID_FPGA_CONFIG_WRITE)
/**
* Request INTEL_SIP_SMC_FPGA_CONFIG_COMPLETED_WRITE
*
* Sync call used by service driver at EL1 to track the completed write
* transactions. This request is called after INTEL_SIP_SMC_FPGA_CONFIG_WRITE
* call returns INTEL_SIP_SMC_STATUS_BUSY.
*
* Call register usage:
* a0: INTEL_SIP_SMC_FPGA_CONFIG_COMPLETED_WRITE.
* a1-7: not used.
*
* Return status:
* a0: INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_FPGA_BUSY or
* INTEL_SIP_SMC_STATUS_ERROR.
* a1: 64bit physical address of 1st completed memory block.
* a2: 64bit physical address of 2nd completed memory block if
* any completed block, otherwise zero value.
* a3: 64bit physical address of 3rd completed memory block if
* any completed block, otherwise zero value.
*/
#define INTEL_SIP_SMC_FUNCID_FPGA_CONFIG_COMPLETED_WRITE 3
#define INTEL_SIP_SMC_FPGA_CONFIG_COMPLETED_WRITE \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FPGA_CONFIG_COMPLETED_WRITE)
/**
* Request INTEL_SIP_SMC_FPGA_CONFIG_ISDONE
*
* Sync call used by service driver at EL1 to inform secure world that all
* data are sent, to check whether or not the secure world had completed
* the FPGA configuration process.
*
* Call register usage:
* a0: INTEL_SIP_SMC_FPGA_CONFIG_ISDONE.
* a1-7: not used.
*
* Return status:
* a0: INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_BUSY or
* INTEL_SIP_SMC_STATUS_ERROR.
* a1-3: not used.
*/
#define INTEL_SIP_SMC_FUNCID_FPGA_CONFIG_ISDONE 4
#define INTEL_SIP_SMC_FPGA_CONFIG_ISDONE \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FPGA_CONFIG_ISDONE)
/**
* Request INTEL_SIP_SMC_FPGA_CONFIG_GET_MEM
*
* Sync call used by service driver at EL1 to query the physical address of
* memory block reserved by secure monitor software.
*
* Call register usage:
* a0:INTEL_SIP_SMC_FPGA_CONFIG_GET_MEM.
* a1-7: not used.
*
* Return status:
* a0: INTEL_SIP_SMC_STATUS_OK or INTEL_SIP_SMC_STATUS_ERROR.
* a1: start of physical address of reserved memory block.
* a2: size of reserved memory block.
* a3: not used.
*/
#define INTEL_SIP_SMC_FUNCID_FPGA_CONFIG_GET_MEM 5
#define INTEL_SIP_SMC_FPGA_CONFIG_GET_MEM \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FPGA_CONFIG_GET_MEM)
/**
* Request INTEL_SIP_SMC_FPGA_CONFIG_LOOPBACK
*
* For SMC loop-back mode only, used for internal integration, debugging
* or troubleshooting.
*
* Call register usage:
* a0: INTEL_SIP_SMC_FPGA_CONFIG_LOOPBACK.
* a1-7: not used.
*
* Return status:
* a0: INTEL_SIP_SMC_STATUS_OK or INTEL_SIP_SMC_STATUS_ERROR.
* a1-3: not used.
*/
#define INTEL_SIP_SMC_FUNCID_FPGA_CONFIG_LOOPBACK 6
#define INTEL_SIP_SMC_FPGA_CONFIG_LOOPBACK \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FPGA_CONFIG_LOOPBACK)
/**
* Request INTEL_SIP_SMC_REG_READ
*
* Read a protected register at EL3
*
* Call register usage:
* a0: INTEL_SIP_SMC_REG_READ.
* a1: register address.
* a2-7: not used.
*
* Return status:
* a0: INTEL_SIP_SMC_STATUS_OK or INTEL_SIP_SMC_REG_ERROR.
* a1: value in the register
* a2-3: not used.
*/
#define INTEL_SIP_SMC_FUNCID_REG_READ 7
#define INTEL_SIP_SMC_REG_READ \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_REG_READ)
/**
* Request INTEL_SIP_SMC_REG_WRITE
*
* Write a protected register at EL3
*
* Call register usage:
* a0: INTEL_SIP_SMC_REG_WRITE.
* a1: register address
* a2: value to program into register.
* a3-7: not used.
*
* Return status:
* a0: INTEL_SIP_SMC_STATUS_OK or INTEL_SIP_SMC_REG_ERROR.
* a1-3: not used.
*/
#define INTEL_SIP_SMC_FUNCID_REG_WRITE 8
#define INTEL_SIP_SMC_REG_WRITE \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_REG_WRITE)
/**
* Request INTEL_SIP_SMC_FUNCID_REG_UPDATE
*
* Update one or more bits in a protected register at EL3 using a
* read-modify-write operation.
*
* Call register usage:
* a0: INTEL_SIP_SMC_REG_UPDATE.
* a1: register address
* a2: write Mask.
* a3: value to write.
* a4-7: not used.
*
* Return status:
* a0: INTEL_SIP_SMC_STATUS_OK or INTEL_SIP_SMC_REG_ERROR.
* a1-3: Not used.
*/
#define INTEL_SIP_SMC_FUNCID_REG_UPDATE 9
#define INTEL_SIP_SMC_REG_UPDATE \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_REG_UPDATE)
/**
* Request INTEL_SIP_SMC_RSU_STATUS
*
* Request remote status update boot log, call is synchronous.
*
* Call register usage:
* a0 INTEL_SIP_SMC_RSU_STATUS
* a1-7 not used
*
* Return status
* a0: Current Image
* a1: Last Failing Image
* a2: Version | State
* a3: Error details | Error location
*
* Or
*
* a0: INTEL_SIP_SMC_RSU_ERROR
*/
#define INTEL_SIP_SMC_FUNCID_RSU_STATUS 11
#define INTEL_SIP_SMC_RSU_STATUS \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_RSU_STATUS)
/**
* Request INTEL_SIP_SMC_RSU_UPDATE
*
* Request to set the offset of the bitstream to boot after reboot, call
* is synchronous.
*
* Call register usage:
* a0 INTEL_SIP_SMC_RSU_UPDATE
* a1 64bit physical address of the configuration data memory in flash
* a2-7 not used
*
* Return status
* a0 INTEL_SIP_SMC_STATUS_OK
*/
#define INTEL_SIP_SMC_FUNCID_RSU_UPDATE 12
#define INTEL_SIP_SMC_RSU_UPDATE \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_RSU_UPDATE)
/**
* Request INTEL_SIP_SMC_ECC_DBE
*
* Sync call used by service driver at EL1 to alert EL3 that a Double
* Bit ECC error has occurred.
*
* Call register usage:
* a0 INTEL_SIP_SMC_ECC_DBE
* a1 SysManager Double Bit Error value
* a2-7 not used
*
* Return status
* a0 INTEL_SIP_SMC_STATUS_OK
*/
#define INTEL_SIP_SMC_FUNCID_ECC_DBE 13
#define INTEL_SIP_SMC_ECC_DBE \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_ECC_DBE)
/**
* Request INTEL_SIP_SMC_RSU_NOTIFY
*
* Sync call used by service driver at EL1 to report hard processor
* system execution stage to firmware
*
* Call register usage:
* a0 INTEL_SIP_SMC_RSU_NOTIFY
* a1 32bit value representing hard processor system execution stage
* a2-7 not used
*
* Return status
* a0 INTEL_SIP_SMC_STATUS_OK
*/
#define INTEL_SIP_SMC_FUNCID_RSU_NOTIFY 14
#define INTEL_SIP_SMC_RSU_NOTIFY \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_RSU_NOTIFY)
/**
* Request INTEL_SIP_SMC_RSU_RETRY_COUNTER
*
* Sync call used by service driver at EL1 to query RSU retry counter
*
* Call register usage:
* a0 INTEL_SIP_SMC_RSU_RETRY_COUNTER
* a1-7 not used
*
* Return status
* a0 INTEL_SIP_SMC_STATUS_OK
* a1 the retry counter
*
* Or
*
* a0 INTEL_SIP_SMC_RSU_ERROR
*/
#define INTEL_SIP_SMC_FUNCID_RSU_RETRY_COUNTER 15
#define INTEL_SIP_SMC_RSU_RETRY_COUNTER \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_RSU_RETRY_COUNTER)
/**
* Request INTEL_SIP_SMC_RSU_DCMF_VERSION
*
* Sync call used by service driver at EL1 to query DCMF (Decision
* Configuration Management Firmware) version from FW
*
* Call register usage:
* a0 INTEL_SIP_SMC_RSU_DCMF_VERSION
* a1-7 not used
*
* Return status
* a0 INTEL_SIP_SMC_STATUS_OK
* a1 dcmf1 | dcmf0
* a2 dcmf3 | dcmf2
*
* Or
*
* a0 INTEL_SIP_SMC_RSU_ERROR
*/
#define INTEL_SIP_SMC_FUNCID_RSU_DCMF_VERSION 16
#define INTEL_SIP_SMC_RSU_DCMF_VERSION \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_RSU_DCMF_VERSION)
/**
* Request INTEL_SIP_SMC_RSU_MAX_RETRY
*
* Sync call used by service driver at EL1 to query max retry value from FW
*
* Call register usage:
* a0 INTEL_SIP_SMC_RSU_MAX_RETRY
* a1-7 not used
*
* Return status
* a0 INTEL_SIP_SMC_STATUS_OK
* a1 max retry value
*
* Or
* a0 INTEL_SIP_SMC_RSU_ERROR
*/
#define INTEL_SIP_SMC_FUNCID_RSU_MAX_RETRY 18
#define INTEL_SIP_SMC_RSU_MAX_RETRY \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_RSU_MAX_RETRY)
/**
* Request INTEL_SIP_SMC_RSU_DCMF_STATUS
*
* Sync call used by service driver at EL1 to query DCMF status from FW
*
* Call register usage:
* a0 INTEL_SIP_SMC_RSU_DCMF_STATUS
* a1-7 not used
*
* Return status
* a0 INTEL_SIP_SMC_STATUS_OK
* a1 dcmf3 | dcmf2 | dcmf1 | dcmf0
*
* Or
*
* a0 INTEL_SIP_SMC_RSU_ERROR
*/
#define INTEL_SIP_SMC_FUNCID_RSU_DCMF_STATUS 20
#define INTEL_SIP_SMC_RSU_DCMF_STATUS \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_RSU_DCMF_STATUS)
/**
* Request INTEL_SIP_SMC_SERVICE_COMPLETED
* Sync call to check if the secure world have completed service request
* or not.
*
* Call register usage:
* a0: INTEL_SIP_SMC_SERVICE_COMPLETED
* a1: this register is optional. If used, it is the physical address for
* secure firmware to put output data
* a2: this register is optional. If used, it is the size of output data
* a3: this register is optional. Set to 0x00004F4E for asynchronous mode
* a4-a7: not used
*
* Return status:
* a0: INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_ERROR,
* INTEL_SIP_SMC_REJECTED or INTEL_SIP_SMC_STATUS_BUSY
* a1: mailbox error if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2: physical address containing the process info
* for FCS certificate -- the data contains the certificate status
* for FCS cryption -- the data contains the actual data size FW processes
* a3: output data size
*/
#define INTEL_SIP_SMC_FUNCID_SERVICE_COMPLETED 30
#define INTEL_SIP_SMC_SERVICE_COMPLETED \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_SERVICE_COMPLETED)
/**
* Request INTEL_SIP_SMC_FIRMWARE_VERSION
*
* Sync call used to query the version of running firmware
*
* Call register usage:
* a0 INTEL_SIP_SMC_FIRMWARE_VERSION
* a1-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK or INTEL_SIP_SMC_STATUS_ERROR
* a1 running firmware version
* SMC call protocol for Mailbox, starting FUNCID from 60
*
* Call register usage:
* a0 INTEL_SIP_SMC_MBOX_SEND_CMD
* a1 mailbox command code
* a2 physical address that contain mailbox command data (not include header)
* a3 mailbox command data size in word
* a4 set to 0 for CASUAL, set to 1 for URGENT
* a5 physical address for secure firmware to put response data
* (not include header)
* a6 maximum size in word of physical address to store response data
* a7 not used
*
* Return status
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_REJECTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox error code
* a2 response data length in word
* a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_FIRMWARE_VERSION 31
#define INTEL_SIP_SMC_FIRMWARE_VERSION \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FIRMWARE_VERSION)
#define INTEL_SIP_SMC_FUNCID_MBOX_SEND_CMD 60
#define INTEL_SIP_SMC_MBOX_SEND_CMD \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_MBOX_SEND_CMD)
/**
* Request INTEL_SIP_SMC_SVC_VERSION
*
* Sync call used to query the SIP SMC API Version
*
* Call register usage:
* a0 INTEL_SIP_SMC_SVC_VERSION
* a1-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK
* a1 Major
* a2 Minor
*/
#define INTEL_SIP_SMC_SVC_FUNCID_VERSION 512
#define INTEL_SIP_SMC_SVC_VERSION \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_SVC_FUNCID_VERSION)
/**
* SMC call protocol for FPGA Crypto Service (FCS)
* FUNCID starts from 90
*/
/**
* Request INTEL_SIP_SMC_FCS_RANDOM_NUMBER
*
* Sync call used to query the random number generated by the firmware
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_RANDOM_NUMBER
* a1 the physical address for firmware to write generated random data
* a2-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_FCS_ERROR or
* INTEL_SIP_SMC_FCS_REJECTED
* a1 mailbox error
* a2 the physical address of generated random number
* a3 size
*/
#define INTEL_SIP_SMC_FUNCID_FCS_RANDOM_NUMBER 90
#define INTEL_SIP_SMC_FCS_RANDOM_NUMBER \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_RANDOM_NUMBER)
/**
* Request INTEL_SIP_SMC_FCS_CRYPTION
* Async call for data encryption and HMAC signature generation, or for
* data decryption and HMAC verification.
*
* Call INTEL_SIP_SMC_SERVICE_COMPLETED to get the output encrypted or
* decrypted data
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_CRYPTION
* a1 cryption mode (1 for encryption and 0 for decryption)
* a2 physical address which stores to be encrypted or decrypted data
* a3 input data size
* a4 physical address which will hold the encrypted or decrypted output data
* a5 output data size
* a6-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_ERROR or
* INTEL_SIP_SMC_STATUS_REJECTED
* a1-3 not used
*/
#define INTEL_SIP_SMC_FUNCID_FCS_CRYPTION 91
#define INTEL_SIP_SMC_FCS_CRYPTION \
INTEL_SIP_SMC_STD_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_CRYPTION)
/**
* Request INTEL_SIP_SMC_FCS_SERVICE_REQUEST
* Async call for authentication service of HPS software
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_SERVICE_REQUEST
* a1 the physical address of data block
* a2 size of data block
* a3-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_ERROR or
* INTEL_SIP_SMC_REJECTED
* a1-a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_FCS_SERVICE_REQUEST 92
#define INTEL_SIP_SMC_FCS_SERVICE_REQUEST \
INTEL_SIP_SMC_STD_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_SERVICE_REQUEST)
/**
* Request INTEL_SIP_SMC_FUNCID_FCS_SEND_CERTIFICATE
* Async call to send a signed certificate
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_SEND_CERTIFICATE
* a1 the physical address of CERTIFICATE block
* a2 size of data block
* a3-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK or INTEL_SIP_SMC_REJECTED
* a1-a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_FCS_SEND_CERTIFICATE 93
#define INTEL_SIP_SMC_FCS_SEND_CERTIFICATE \
INTEL_SIP_SMC_STD_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_SEND_CERTIFICATE)
/**
* Request INTEL_SIP_SMC_FCS_GET_PROVISION_DATA
* Sync call to dump all the fuses and key hashes
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_GET_PROVISION_DATA
* a1-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_ERROR or
* INTEL_SIP_SMC_STATUS_REJECTED
* a1-a3 not used
*
*/
#define INTEL_SIP_SMC_FUNCID_FCS_GET_PROVISION_DATA 94
#define INTEL_SIP_SMC_FCS_GET_PROVISION_DATA \
INTEL_SIP_SMC_STD_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_GET_PROVISION_DATA)
/**
* Request INTEL_SIP_SMC_FCS_COUNTER_SET_PREAUTHORIZED
* Sync call to update counter value w/o signed certificate
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_COUNTER_SET_PREAUTHORIZED
* a1 counter type
* a2 counter value
* a3 test bit
* a3-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK or INTEL_SIP_SMC_STATUS_ERROR
* a1-a4 not used
*/
#define INTEL_SIP_SMC_FUNCID_FCS_COUNTER_SET_PREAUTHORIZED 95
#define INTEL_SIP_SMC_FCS_COUNTER_SET_PREAUTHORIZED \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_COUNTER_SET_PREAUTHORIZED)
/**
* Request INTEL_SIP_SMC_FCS_PSGSIGMA_TEARDOWN
* Sync call to tear down all previous black key provision sessions and to
* delete keys assicated with those sessions
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_PSGSIGMA_TEARDOWN
* a1 the session ID
* a2-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_ERROR or
* INTEL_SIP_SMC_STATUS_REJECTED
* a1 mailbox error if a0 is INTEL_SIP_SMC_STATUS_ERROR,
* not used if a0 is INTEL_SIP_SMC_STATUS_OK or
* INTEL_SIP_SMC_STATUS_REJECTED
* a2-a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_FCS_PSGSIGMA_TEARDOWN 100
#define INTEL_SIP_SMC_FCS_PSGSIGMA_TEARDOWN \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_PSGSIGMA_TEARDOWN)
/**
* Request INTEL_SIP_SMC_FCS_CHIP_ID
* Sync call to get the device ID
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_CHIP_ID
* a1-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_ERROR or
* INTEL_SIP_SMC_STATUS_REJECTED
* a1 mailbox error if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2 retrieved chipID value low 32 bits
* a3 retrieved chipID value high 32 bits
*/
#define INTEL_SIP_SMC_FUNCID_FCS_CHIP_ID 101
#define INTEL_SIP_SMC_FCS_CHIP_ID \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_CHIP_ID)
/**
* Request INTEL_SIP_SMC_FCS_ATTESTATION_SUBKEY
* Sync call to the device attestation subkey
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_ATTESTATION_SUBKEY
* a1 physical address of subkey command data
* a2 subkey command data size
* a3 physical address of to be filled subkey response data
* a4 subkey response data size
* a5-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, or INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox error if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2 physical address of the filled subkey response data
* a3 size of the filled subkey response dat
*/
#define INTEL_SIP_SMC_FUNCID_FCS_ATTESTATION_SUBKEY 102
#define INTEL_SIP_SMC_FCS_ATTESTATION_SUBKEY \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_ATTESTATION_SUBKEY)
/**
* Request INTEL_SIP_SMC_FCS_ATTESTATION_MEASUREMENTS
* Async call to get device attestation measurements
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_ATTESTATION_MEASUREMENTS
* a1 physical address of measurement command data
* a2 measurement command data size
* a3 physical address of to be filled measurement response data
* a4 measurement response data size
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, or INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox error if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2 physical address of the filled subkey measurement data
* a3 size of the filled subkey measurement data
*/
#define INTEL_SIP_SMC_FUNCID_FCS_ATTESTATION_MEASUREMENTS 103
#define INTEL_SIP_SMC_FCS_ATTESTATION_MEASUREMENTS \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_ATTESTATION_MEASUREMENTS)
/**
* Request INTEL_SIP_SMC_FCS_GET_ATTESTATION_CERTIFICATE
* Sync call to get device attestation certificate
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_GET_ATTESTATION_CERTIFICATE
* a1 the type of certificate request
* a2 the physical address which holds certificate response data
* a3 the size of the certificate response data
* a4-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox error if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2 physical address of the requested certificate
* a3 sized of the requested certificate
*/
#define INTEL_SIP_SMC_FUNCID_FCS_GET_ATTESTATION_CERTIFICATE 104
#define INTEL_SIP_SMC_FCS_GET_ATTESTATION_CERTIFICATE \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_GET_ATTESTATION_CERTIFICATE)
/**
* Request INTEL_SIP_SMC_FCS_CREATE_CERTIFICATE_ON_RELOAD
* Sync call to specify what certificate is to be generated
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_CREATE_CERTIFICATE_ON_RELOAD
* a1 the type of certificat request
* a2-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox error if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2-a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_FCS_CREATE_CERTIFICATE_ON_RELOAD 105
#define INTEL_SIP_SMC_FCS_CREATE_CERTIFICATE_ON_RELOAD \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_CREATE_CERTIFICATE_ON_RELOAD)
/**
* Request INTEL_SIP_SMC_FCS_GET_ROM_PATCH_SHA384
*
* Sync call used to dump the SHA384 hash of the rom patch
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_GET_ROM_PATCH_SHA384
* a1 the physical address for firmware to write generated SHA384 data
* a2-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_FCS_ERROR or
* INTEL_SIP_SMC_FCS_REJECTED
* a1 mailbox error
* a2 the physical address of the SHA384 checksum
* a3 size of the SHA384 checksum
*/
#define INTEL_SIP_SMC_FUNCID_FCS_GET_ROM_PATCH_SHA384 64
#define INTEL_SIP_SMC_FCS_GET_ROM_PATCH_SHA384 \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_GET_ROM_PATCH_SHA384)
/**
* Request INTEL_SIP_SMC_FCS_OPEN_CRYPTO_SERVICE_SESSION
* Sync call to open and establish a crypto service session with firmware
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_OPEN_CRYPTO_SERVICE_SESSION
* a1-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox error if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2 session ID
* a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_FCS_OPEN_CRYPTO_SERVICE_SESSION 110
#define INTEL_SIP_SMC_FCS_OPEN_CRYPTO_SERVICE_SESSION \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_OPEN_CRYPTO_SERVICE_SESSION)
/**
* Request INTEL_SIP_SMC_FCS_CLOSE_CRYPTO_SERVICE_SESSION
* Sync call to close a service session
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_CLOSE_CRYPTO_SERVICE_SESSION
* a1 session ID
* a2-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox error if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2-a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_FCS_CLOSE_CRYPTO_SERVICE_SESSION 111
#define INTEL_SIP_SMC_FCS_CLOSE_CRYPTO_SERVICE_SESSION \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_CLOSE_CRYPTO_SERVICE_SESSION)
/**
* Request INTEL_SIP_SMC_FCS_IMPORT_CRYPTO_SERVICE_KEY
* Async call to import crypto service key to the device
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_IMPORT_CRYPTO_SERVICE_KEY
* a1 physical address of the service key object with header
* a3 size of the service key object
* a4-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_ERROR or
* INTEL_SIP_SMC_STATUS_REJECTED
* a1-3 not used
*/
#define INTEL_SIP_SMC_FUNCID_FCS_IMPORT_CRYPTO_SERVICE_KEY 112
#define INTEL_SIP_SMC_FCS_IMPORT_CRYPTO_SERVICE_KEY \
INTEL_SIP_SMC_STD_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_IMPORT_CRYPTO_SERVICE_KEY)
/**
* Request INTEL_SIP_SMC_FCS_EXPORT_CRYPTO_SERVICE_KEY
* Sync call to export crypto service key from the device
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_EXPORT_CRYPTO_SERVICE_KEY
* a1 session ID
* a2 key UID
* a3 physical address of the exported service key object
* a4 size of the exported service key object, max is (88 words + 3 header words)
* a5-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox and status errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* 31:24 -- reserved
* 23:16 -- import/export/removal status error
* 15:11 -- reserved
* 10:0 -- mailbox error
* a2 physical address of the exported service key object
* a3 size of the exported service key object
*/
#define INTEL_SIP_SMC_FUNCID_FCS_EXPORT_CRYPTO_SERVICE_KEY 113
#define INTEL_SIP_SMC_FCS_EXPORT_CRYPTO_SERVICE_KEY \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_EXPORT_CRYPTO_SERVICE_KEY)
/**
* Request INTEL_SIP_SMC_FCS_REMOVE_CRYPTO_SERVICE_KEY
* Sync call to remove the crypto service kers from the device
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_REMOVE_CRYPTO_SERVICE_KEY
* a1 session ID
* a2 key UID
* a3-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox and status errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* 31:24 -- reserved
* 23:16 -- import/export/removal status error
* 15:11 -- reserved
* 10:0 -- mailbox error
* a2-a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_FCS_REMOVE_CRYPTO_SERVICE_KEY 114
#define INTEL_SIP_SMC_FCS_REMOVE_CRYPTO_SERVICE_KEY \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_REMOVE_CRYPTO_SERVICE_KEY)
/**
* Request INTEL_SIP_SMC_FCS_GET_CRYPTO_SERVICE_KEY_INFO
* Sync call to query the crypto service keys on the device
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_GET_CRYPTO_SERVICE_KEY_INFO
* a1 session ID
* a2 key UID
* a3 physical address of the reponse data
* a4 max size of the response data (36 words with header)
* a3-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox and status errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* 31:24 -- reserved
* 23:16 -- import/export/removal status error
* 15:11 -- reserved
* 10:0 -- mailbox error
* a2 physical address of the reponse data
* a3 size of the response data
*/
#define INTEL_SIP_SMC_FUNCID_FCS_GET_CRYPTO_SERVICE_KEY_INFO 115
#define INTEL_SIP_SMC_FCS_GET_CRYPTO_SERVICE_KEY_INFO \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_GET_CRYPTO_SERVICE_KEY_INFO)
/**
* Request INTEL_SIP_SMC_FCS_AES_CRYPTO_INIT
* Sync call to initialize AES crypto operation
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_AES_CRYPTO_INIT
* a1 session ID
* a2 context ID
* a3 key UID
* a4 physical address of AES crypto parameter data (include block mode,
* encrypt/decrypt, IV fields
* a5 size of of AES crypto parameter data
* a6-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2-a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_FCS_AES_CRYPTO_INIT 116
#define INTEL_SIP_SMC_FCS_AES_CRYPTO_INIT \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_AES_CRYPTO_INIT)
/**
* Request INTEL_SIP_SMC_FCS_AES_CRYPTO_UPDATE
* Sync call to decrypt/encrypt a data block
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_AES_CRYPTO_UPDATE
* a1 session ID
* a2 context ID
* a3 physical address of source
* a4 size of source
* a5 physical address of destination
* a6 size of destination
* a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1-a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_FCS_AES_CRYPTO_UPDATE 117
#define INTEL_SIP_SMC_FCS_AES_CRYPTO_UPDATE \
INTEL_SIP_SMC_STD_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_AES_CRYPTO_UPDATE)
/**
* Request INTEL_SIP_SMC_FCS_AES_CRYPTO_FINALIZE
* Sync call to decrypt/encrypt a data block
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_AES_CRYPTO_FINALIZE
* a1 session ID
* a2 context ID
* a3 physical address of source
* a4 size of source
* a5 physical address of destation
* a6 size of destation
* a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1-a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_FCS_AES_CRYPTO_FINALIZE 118
#define INTEL_SIP_SMC_FCS_AES_CRYPTO_FINALIZE \
INTEL_SIP_SMC_STD_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_AES_CRYPTO_FINALIZE)
/**
* Request INTEL_SIP_SMC_FCS_GET_DIGEST_INIT
* Sync call to request the SHA-2 hash digest on a blob
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_GET_DIGEST_INIT
* a1 session ID
* a2 context ID
* a3 key UID
* a4 size of crypto parameter data
* a5 the crypto parameter
* 3:0 SHA opeation mode
* 7:4 digist size
* 63:8 not used
* a6-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2-a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_FCS_GET_DIGEST_INIT 119
#define INTEL_SIP_SMC_FCS_GET_DIGEST_INIT \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_GET_DIGEST_INIT)
/**
* Request INTEL_SIP_SMC_FCS_GET_DIGEST_UPDATE
* Sync call to request the SHA-2 hash digest on a blob
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_GET_DIGEST_UPDATE
* a1 session ID
* a2 context ID
* a3 physical address of source
* a4 size of source
* a5 physical address of destination
* a6 size of destination
* a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2 physical address of response data
* a3 size of response data
*/
#define INTEL_SIP_SMC_FUNCID_FCS_GET_DIGEST_UPDATE 120
#define INTEL_SIP_SMC_FCS_GET_DIGEST_UPDATE \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_GET_DIGEST_UPDATE)
/**
* Request INTEL_SIP_SMC_FCS_GET_DIGEST_FINALIZE
* Sync call to request the SHA-2 hash digest on a blob
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_GET_DIGEST_FINALIZE
* a1 session ID
* a2 context ID
* a3 physical address of source
* a4 size of source
* a5 physical address of destation
* a6 size of destation
* a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2 physical address of response data
* a3 size of response data
*/
#define INTEL_SIP_SMC_FUNCID_FCS_GET_DIGEST_FINALIZE 121
#define INTEL_SIP_SMC_FCS_GET_DIGEST_FINALIZE \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_GET_DIGEST_FINALIZE)
/**
* Request INTEL_SIP_SMC_FCS_MAC_VERIFY_INIT
* Sync call to check the integrity and authenticity of a blob by comparing
* the calculated MAC with tagged MAC
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_MAC_VERIFY_INIT
* a1 session ID
* a2 context ID
* a3 key UID
* a4 size of crypto parameter data
* a5 crypto parameter data
* 3:0 not used
* 7:4 digist size
* 63:8 not used
* a6-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2 physical address of response data
* a3 size of response data
*/
#define INTEL_SIP_SMC_FUNCID_FCS_MAC_VERIFY_INIT 122
#define INTEL_SIP_SMC_FCS_MAC_VERIFY_INIT \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_MAC_VERIFY_INIT)
/**
* Request INTEL_SIP_SMC_FCS_MAC_VERIFY_UPDATE
* Sync call to check the integrity and authenticity of a blob by comparing
* the calculated MAC with tagged MAC
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_MAC_VERIFY_UPDATE
* a1 session ID
* a2 context ID
* a3 physical address of source
* a4 size of source
* a5 physical address of destination
* a6 size of destination
* a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2 physical address of response data
* a3 size of response data
*/
#define INTEL_SIP_SMC_FUNCID_FCS_MAC_VERIFY_UPDATE 123
#define INTEL_SIP_SMC_FCS_MAC_VERIFY_UPDATE \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_MAC_VERIFY_UPDATE)
/**
* Request INTEL_SIP_SMC_FCS_MAC_VERIFY_FINALIZE
* Sync call to check the integrity and authenticity of a blob by comparing
* the calculated MAC with tagged MAC
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_MAC_VERIFY_FINALIZE
* a1 session ID
* a2 context ID
* a3 physical address of source
* a4 size of source
* a5 physical address of destation
* a6 size of destation
* a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2 physical address of response data
* a3 size of response data
*/
#define INTEL_SIP_SMC_FUNCID_FCS_MAC_VERIFY_FINALIZE 124
#define INTEL_SIP_SMC_FCS_MAC_VERIFY_FINALIZE \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_MAC_VERIFY_FINALIZE)
/**
* Request INTEL_SIP_SMC_FCS_ECDSA_HASH_SIGNING_INIT
* Sync call to sends digital signature signing request on a data blob
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_ECDSA_HASH_SIGNING_INIT
* a1 session ID
* a2 context ID
* a3 key UID
* a4 size of crypto parameter data
* a5 size of crypto parameter data
* 3:0 ECC algoritim
* 63:4 not used
* a6-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2-a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_FCS_ECDSA_HASH_SIGNING_INIT 125
#define INTEL_SIP_SMC_FCS_ECDSA_HASH_SIGNING_INIT \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_ECDSA_HASH_SIGNING_INIT)
/**
* Request INTEL_SIP_SMC_FCS_ECDSA_HASH_SIGNING_FINALIZE
* Sync call to sends digital signature signing request on a data blob
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_ECDSA_HASH_SIGNING_FINALIZE
* a1 session ID
* a2 context ID
* a3 physical address of source
* a4 size of source
* a5 physical address of destation
* a6 size of destation
* a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2 physical address of response data
* a3 size of response data
*/
#define INTEL_SIP_SMC_FUNCID_ECDSA_HASH_SIGNING_FINALIZE 127
#define INTEL_SIP_SMC_FCS_ECDSA_HASH_SIGNING_FINALIZE \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_ECDSA_HASH_SIGNING_FINALIZE)
/**
* Request INTEL_SIP_SMC_FCS_ECDSA_SHA2_DATA_SIGNING_INIT
* Sync call to digital signature signing request on a data blob
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_ECDSA_SHA2_DATA_SIGNING_INIT
* a1 session ID
* a2 context ID
* a3 key UID
* a4 size of crypto parameter data
* a5 crypto parameter data
* 3:0 ECC algorithm
* 63:4 not used
* a6-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2-a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_ECDSA_SHA2_DATA_SIGNING_INIT 128
#define INTEL_SIP_SMC_FCS_ECDSA_SHA2_DATA_SIGNING_INIT \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_ECDSA_SHA2_DATA_SIGNING_INIT)
/**
* Request INTEL_SIP_SMC_FCS_ECDSA_SHA2_DATA_SIGNING_UPDATE
* Sync call to digital signature signing request on a data blob
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_ECDSA_SHA2_DATA_SIGNING_UPDATE
* a1 session ID
* a2 context ID
* a3 physical address of source
* a4 size of source
* a5 physical address of destination
* a6 size of destination
* a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2 physical address of response data
* a3 size of response data
*/
#define INTEL_SIP_SMC_FUNCID_ECDSA_SHA2_DATA_SIGNING_UPDATE 129
#define INTEL_SIP_SMC_FCS_ECDSA_SHA2_DATA_SIGNING_UPDATE \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_ECDSA_SHA2_DATA_SIGNING_UPDATE)
/**
* Request INTEL_SIP_SMC_FCS_ECDSA_SHA2_DATA_SIGNING_FINALIZE
* Sync call to digital signature signing request on a data blob
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_ECDSA_SHA2_DATA_SIGNING_FINALIZE
* a1 session ID
* a2 context ID
* a3 physical address of source
* a4 size of source
* a5 physical address of destation
* a6 size of destation
* a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2 physical address of response data
* a3 size of response data
*/
#define INTEL_SIP_SMC_FUNCID_ECDSA_SHA2_DATA_SIGNING_FINALIZE 130
#define INTEL_SIP_SMC_FCS_ECDSA_SHA2_DATA_SIGNING_FINALIZE \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_ECDSA_SHA2_DATA_SIGNING_FINALIZE)
/**
* Request INTEL_SIP_SMC_FCS_ECDSA_HASH_SIGNATURE_VERIFY_INIT
* Sync call to sends digital signature verify request with precalculated hash
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_ECDSA_HASH_SIGNATURE_VERIFY_INIT
* a1 session ID
* a2 context ID
* a3 key UID
* a4 size of crypto parameter data
* a5 crypto parameter data
* 3:0 ECC algorithm
* 63:4 not used
* a6-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2-a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_ECDSA_HASH_SIGNATURE_VERIFY_INIT 131
#define INTEL_SIP_SMC_FCS_ECDSA_HASH_SIGNATURE_VERIFY_INIT \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_ECDSA_HASH_SIGNATURE_VERIFY_INIT)
/**
* Request INTEL_SIP_SMC_FCS_ECDSA_HASH_SIGNATURE_VERIFY_FINALIZE
* Sync call to sends digital signature verify request with precalculated hash
*
* a0 INTEL_SIP_SMC_FCS_ECDSA_HASH_SIGNATURE_VERIFY_FINALIZE
* a1 session ID
* a2 context ID
* a3 physical address of source
* a4 size of source
* a5 physical address of destation
* a6 size of destation
* a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2 physical address of response data
* a3 size of response data
*/
#define INTEL_SIP_SMC_FUNCID_FCS_ECDSA_HASH_SIGNATURE_VERIFY_FINALIZE 133
#define INTEL_SIP_SMC_FCS_ECDSA_HASH_SIGNATURE_VERIFY_FINALIZE \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_ECDSA_HASH_SIGNATURE_VERIFY_FINALIZE)
/**
* Request INTEL_SIP_SMC_FCS_ECDSA_SHA2_DATA_SIGNATURE_VERIFY_INIT
* Sync call to send digital signature verify request
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_ECDSA_SHA2_DATA_SIGNATURE_VERIFY_INIT
* a1 session ID
* a2 context ID
* a3 key UID
* a4 size of crypto parameter data
* a5 crypto parameter data
* 3:0 ECC algorithm
* 63:4 not used
* a6-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2-a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_FCS_ECDSA_SHA2_DATA_SIGNATURE_VERIFY_INIT 134
#define INTEL_SIP_SMC_FCS_ECDSA_SHA2_DATA_SIGNATURE_VERIFY_INIT \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_ECDSA_SHA2_DATA_SIGNATURE_VERIFY_INIT)
/**
* Request INTEL_SIP_SMC_FCS_ECDSA_SHA2_DATA_SIGNATURE_VERIFY_UPDATE
* Sync call to send digital signature verify request
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_ECDSA_SHA2_DATA_SIGNATURE_VERIFY_UPDATE
* a1 session ID
* a2 context ID
* a3 physical address of source (contain user data)
* a4 size of source
* a5 physical address of destination
* a6 size of destination
* a7 size of user data
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2 physical address of response data
* a3 size of response data
*/
#define INTEL_SIP_SMC_FUNCID_FCS_ECDSA_SHA2_DATA_SIGNATURE_VERIFY_UPDATE 135
#define INTEL_SIP_SMC_FCS_ECDSA_SHA2_DATA_SIGNATURE_VERIFY_UPDATE \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_ECDSA_SHA2_DATA_SIGNATURE_VERIFY_UPDATE)
/**
* Request INTEL_SIP_SMC_FCS_ECDSA_SHA2_DATA_SIGNATURE_VERIFY_FINALIZE
* Sync call to send digital signature verify request
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_ECDSA_SHA2_DATA_SIGNATURE_VERIFY_FINALIZE
* a1 session ID
* a2 context ID
* a3 physical address of source
* a4 size of source
* a5 physical address of destation
* a6 size of destation
* a7 size of user data
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2 physical address of response data
* a3 size of response data
*/
#define INTEL_SIP_SMC_FUNCID_FCS_ECDSA_SHA2_DATA_SIGNATURE_VERIFY_FINALIZE 136
#define INTEL_SIP_SMC_FCS_ECDSA_SHA2_DATA_SIGNATURE_VERIFY_FINALIZE \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_ECDSA_SHA2_DATA_SIGNATURE_VERIFY_FINALIZE)
/**
* Request INTEL_SIP_SMC_FCS_ECDSA_GET_PUBLIC_KEY_INIT
* Sync call to send the request to get the public key
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_ECDSA_GET_PUBLIC_KEY_INIT
* a1 session ID
* a2 context ID
* a3 key UID
* a4 size of crypto parameter data
* a5 crypto parameter data
* 3:0 EE algorithm
* 63:4 not used
* a6-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2-a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_FCS_ECDSA_GET_PUBLIC_KEY_INIT 137
#define INTEL_SIP_SMC_FCS_ECDSA_GET_PUBLIC_KEY_INIT \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_ECDSA_GET_PUBLIC_KEY_INIT)
/**
* Request INTEL_SIP_SMC_FCS_ECDSA_GET_PUBLIC_KEY_FINALIZE
* Sync call to send the request to get the public key
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_ECDSA_GET_PUBLIC_KEY_FINALIZE
* a1 session ID
* a2 context ID
* a3 physical address of response data
* a4 size of response data
* a5-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2 physical address of response data
* a3 size of response data
*/
#define INTEL_SIP_SMC_FUNCID_FCS_FCS_ECDSA_GET_PUBLIC_KEY_FINALIZE 139
#define INTEL_SIP_SMC_FCS_ECDSA_GET_PUBLIC_KEY_FINALIZE \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_FCS_ECDSA_GET_PUBLIC_KEY_FINALIZE)
/**
* Request INTEL_SIP_SMC_FCS_ECDH_INIT
* Sync call to send the request on generating a share secret on
* Diffie-Hellman key exchange
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_ECDH_INIT
* a1 session ID
* a2 context ID
* a3 key UID
* a4 size of crypto parameter data
* a5 crypto parameter data
* 3:0 ECC algorithm
* 63:4 not used
* a6-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2-a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_FCS_ECDH_INIT 140
#define INTEL_SIP_SMC_FCS_ECDH_INIT \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_ECDH_INIT)
/**
* Request INTEL_SIP_SMC_FCS_ECDH_FINALIZE
* Sync call to send the request on generating a share secret on
* Diffie-Hellman key exchange
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_ECDH_FINALIZE
* a1 session ID
* a2 context ID
* a3 physical address of source
* a4 size of source
* a5 physical address of destation
* a6 size of destation
* a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2 physical address of response data
* a3 size of response data
*/
#define INTEL_SIP_SMC_FUNCID_FCS_ECDH_FINALIZE 142
#define INTEL_SIP_SMC_FCS_ECDH_FINALIZE \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_ECDH_FINALIZE)
/**
* Request INTEL_SIP_SMC_FCS_RANDOM_NUMBER_EXT
*
* Async call used to query the random number generated by the firmware,
* the maxim random number is 4080 bytes.
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_RANDOM_NUMBER_EXT
* a1 session ID
* a2 context ID
* a3 size of the requested random data
* a4-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1-a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_FCS_RANDOM_NUMBER_EXT 143
#define INTEL_SIP_SMC_FCS_RANDOM_NUMBER_EXT \
INTEL_SIP_SMC_STD_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_RANDOM_NUMBER_EXT)
/**
* Request INTEL_SIP_SMC_FCS_CRYPTION_EXT
* Sync call for data encryption or data decryption.
*
* Call register usage:
* a0 INTEL_SIP_SMC_FCS_CRYPTION_EXT
* a1 session ID
* a2 context ID
* a3 cryption operating mode (1 for encryption and 0 for decryption)
* a4 physical address which stores to be encrypted or decrypted data
* a5 size of input data
* a6 physical address which will hold the encrypted or decrypted output data
* a7 size of output data
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK, INTEL_SIP_SMC_STATUS_NOT_SUPPORTED or
* INTEL_SIP_SMC_STATUS_ERROR
* a1 mailbox errors if a0 is INTEL_SIP_SMC_STATUS_ERROR
* a2 physical address of (output) decrypted or encrypted data
* a3 size of (output) decrypted or encrypted data
*/
#define INTEL_SIP_SMC_FUNCID_FCS_CRYPTION_EXT 144
#define INTEL_SIP_SMC_FCS_CRYPTION_EXT \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_FCS_CRYPTION_EXT)
/**
* Request INTEL_SIP_SMC_SVC_VERSION
*
* Sync call used to query the SIP SMC API Version
*
* Call register usage:
* a0 INTEL_SIP_SMC_SVC_VERSION
* a1-a7 not used
*
* Return status:
* a0 INTEL_SIP_SMC_STATUS_OK
* a1 Major
* a2 Minor
*/
#define INTEL_SIP_SMC_SVC_FUNCID_VERSION 512
#define INTEL_SIP_SMC_SVC_VERSION \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_SVC_FUNCID_VERSION)
/**
* Request INTEL_SIP_SMC_HWMON_READTEMP
* Sync call to request temperature
*
* Call register usage:
* a0 Temperature Channel
* a1-a7 not used
*
* Return status
* a0 INTEL_SIP_SMC_STATUS_OK
* a1 Temperature Value
* a2-a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_HWMON_READTEMP 32
#define INTEL_SIP_SMC_HWMON_READTEMP \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_HWMON_READTEMP)
/**
* Request INTEL_SIP_SMC_HWMON_READVOLT
* Sync call to request voltage
*
* Call register usage:
* a0 Voltage Channel
* a1-a7 not used
*
* Return status
* a0 INTEL_SIP_SMC_STATUS_OK
* a1 Voltage Value
* a2-a3 not used
*/
#define INTEL_SIP_SMC_FUNCID_HWMON_READVOLT 33
#define INTEL_SIP_SMC_HWMON_READVOLT \
INTEL_SIP_SMC_FAST_CALL_VAL(INTEL_SIP_SMC_FUNCID_HWMON_READVOLT)
#endif