2018-01-15 15:53:26 +01:00
|
|
|
/** @file
|
|
|
|
|
|
|
|
Copyright (c) 2017-2018, Arm Limited. All rights reserved.
|
|
|
|
|
2019-04-04 01:03:18 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2018-01-15 15:53:26 +01:00
|
|
|
|
|
|
|
System Control and Management Interface V1.0
|
|
|
|
http://infocenter.arm.com/help/topic/com.arm.doc.den0056a/
|
|
|
|
DEN0056A_System_Control_and_Management_Interface.pdf
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef ARM_SCMI_CLOCK_PROTOCOL_PRIVATE_H_
|
|
|
|
#define ARM_SCMI_CLOCK_PROTOCOL_PRIVATE_H_
|
|
|
|
|
|
|
|
#pragma pack(1)
|
|
|
|
|
|
|
|
// Clock rate in two 32bit words.
|
|
|
|
typedef struct {
|
2021-12-05 23:53:50 +01:00
|
|
|
UINT32 Low;
|
|
|
|
UINT32 High;
|
2018-01-15 15:53:26 +01:00
|
|
|
} CLOCK_RATE_DWORD;
|
|
|
|
|
|
|
|
// Format of the returned rate array. Linear or Non-linear,.RatesFlag Bit[12]
|
2021-12-05 23:53:50 +01:00
|
|
|
#define RATE_FORMAT_SHIFT 12
|
|
|
|
#define RATE_FORMAT_MASK 0x0001
|
|
|
|
#define RATE_FORMAT(RatesFlags) ((RatesFlags >> RATE_FORMAT_SHIFT) \
|
2018-01-15 15:53:26 +01:00
|
|
|
& RATE_FORMAT_MASK)
|
|
|
|
|
|
|
|
// Number of remaining rates after a call to the SCP, RatesFlag Bits[31:16]
|
2021-12-05 23:53:50 +01:00
|
|
|
#define NUM_REMAIN_RATES_SHIFT 16
|
2018-01-15 15:53:26 +01:00
|
|
|
#define NUM_REMAIN_RATES(RatesFlags) ((RatesFlags >> NUM_REMAIN_RATES_SHIFT))
|
|
|
|
|
|
|
|
// Number of rates that are returned by a call.to the SCP, RatesFlag Bits[11:0]
|
2021-12-05 23:53:50 +01:00
|
|
|
#define NUM_RATES_MASK 0x0FFF
|
|
|
|
#define NUM_RATES(RatesFlags) (RatesFlags & NUM_RATES_MASK)
|
2018-01-15 15:53:26 +01:00
|
|
|
|
|
|
|
// Return values for the CLOCK_DESCRIBER_RATE command.
|
|
|
|
typedef struct {
|
2021-12-05 23:53:50 +01:00
|
|
|
UINT32 NumRatesFlags;
|
2018-01-15 15:53:26 +01:00
|
|
|
|
|
|
|
// NOTE: Since EDK2 does not allow flexible array member [] we declare
|
|
|
|
// here array of 1 element length. However below is used as a variable
|
|
|
|
// length array.
|
2021-12-05 23:53:50 +01:00
|
|
|
CLOCK_RATE_DWORD Rates[1];
|
2018-01-15 15:53:26 +01:00
|
|
|
} CLOCK_DESCRIBE_RATES;
|
|
|
|
|
2021-12-05 23:53:50 +01:00
|
|
|
#define CLOCK_SET_DEFAULT_FLAGS 0
|
2018-01-15 15:53:26 +01:00
|
|
|
|
|
|
|
// Message parameters for CLOCK_RATE_SET command.
|
|
|
|
typedef struct {
|
2021-12-05 23:53:50 +01:00
|
|
|
UINT32 Flags;
|
|
|
|
UINT32 ClockId;
|
|
|
|
CLOCK_RATE_DWORD Rate;
|
2018-01-15 15:53:26 +01:00
|
|
|
} CLOCK_RATE_SET_ATTRIBUTES;
|
|
|
|
|
2018-12-14 00:48:44 +01:00
|
|
|
// Message parameters for CLOCK_CONFIG_SET command.
|
|
|
|
typedef struct {
|
2021-12-05 23:53:50 +01:00
|
|
|
UINT32 ClockId;
|
|
|
|
UINT32 Attributes;
|
2018-12-14 00:48:44 +01:00
|
|
|
} CLOCK_CONFIG_SET_ATTRIBUTES;
|
|
|
|
|
2018-01-15 15:53:26 +01:00
|
|
|
// if ClockAttr Bit[0] is set then clock device is enabled.
|
2021-12-05 23:53:50 +01:00
|
|
|
#define CLOCK_ENABLE_MASK 0x1
|
2018-01-15 15:53:26 +01:00
|
|
|
#define CLOCK_ENABLED(ClockAttr) ((ClockAttr & CLOCK_ENABLE_MASK) == 1)
|
|
|
|
|
|
|
|
typedef struct {
|
2021-12-05 23:53:50 +01:00
|
|
|
UINT32 Attributes;
|
|
|
|
UINT8 ClockName[SCMI_MAX_STR_LEN];
|
2018-01-15 15:53:26 +01:00
|
|
|
} CLOCK_ATTRIBUTES;
|
|
|
|
|
|
|
|
#pragma pack()
|
|
|
|
|
|
|
|
/** Initialize clock management protocol and install protocol on a given handle.
|
|
|
|
|
|
|
|
@param[in] Handle Handle to install clock management protocol.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS Clock protocol interface installed successfully.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
ScmiClockProtocolInit (
|
2021-12-05 23:53:50 +01:00
|
|
|
IN EFI_HANDLE *Handle
|
2018-01-15 15:53:26 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
#endif /* ARM_SCMI_CLOCK_PROTOCOL_PRIVATE_H_ */
|