REF: https://bugzilla.tianocore.org/show_bug.cgi?id=3737 Apply uncrustify changes to .c/.h files in the ArmPkg package Cc: Andrew Fish <afish@apple.com> Cc: Leif Lindholm <leif@nuviainc.com> Cc: Michael D Kinney <michael.d.kinney@intel.com> Signed-off-by: Michael Kubacki <michael.kubacki@microsoft.com> Reviewed-by: Andrew Fish <afish@apple.com>
		
			
				
	
	
		
			192 lines
		
	
	
		
			6.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			192 lines
		
	
	
		
			6.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
| 
 | |
|   Copyright (c) 2017-2021, Arm Limited. All rights reserved.
 | |
| 
 | |
|   SPDX-License-Identifier: BSD-2-Clause-Patent
 | |
| 
 | |
|   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_CLOCK2_PROTOCOL_H_
 | |
| #define ARM_SCMI_CLOCK2_PROTOCOL_H_
 | |
| 
 | |
| #include <Protocol/ArmScmi.h>
 | |
| #include <Protocol/ArmScmiClockProtocol.h>
 | |
| 
 | |
| #define ARM_SCMI_CLOCK2_PROTOCOL_GUID  {\
 | |
|   0xb8d8caf2, 0x9e94, 0x462c, { 0xa8, 0x34, 0x6c, 0x99, 0xfc, 0x05, 0xef, 0xcf } \
 | |
|   }
 | |
| 
 | |
| extern EFI_GUID  gArmScmiClock2ProtocolGuid;
 | |
| 
 | |
| #define SCMI_CLOCK2_PROTOCOL_VERSION  1
 | |
| 
 | |
| typedef struct _SCMI_CLOCK2_PROTOCOL SCMI_CLOCK2_PROTOCOL;
 | |
| 
 | |
| // Protocol Interface functions.
 | |
| 
 | |
| /** Return version of the clock management protocol supported by SCP firmware.
 | |
| 
 | |
|   @param[in]  This     A Pointer to SCMI_CLOCK2_PROTOCOL Instance.
 | |
| 
 | |
|   @param[out] Version  Version of the supported SCMI Clock management protocol.
 | |
| 
 | |
|   @retval EFI_SUCCESS       The version is returned.
 | |
|   @retval EFI_DEVICE_ERROR  SCP returns an SCMI error.
 | |
|   @retval !(EFI_SUCCESS)    Other errors.
 | |
| **/
 | |
| typedef
 | |
| EFI_STATUS
 | |
| (EFIAPI *SCMI_CLOCK2_GET_VERSION)(
 | |
|   IN  SCMI_CLOCK2_PROTOCOL  *This,
 | |
|   OUT UINT32                *Version
 | |
|   );
 | |
| 
 | |
| /** Return total number of clock devices supported by the clock management
 | |
|    protocol.
 | |
| 
 | |
|   @param[in]  This         A Pointer to SCMI_CLOCK2_PROTOCOL Instance.
 | |
| 
 | |
|   @param[out] TotalClocks  Total number of clocks supported.
 | |
| 
 | |
|   @retval EFI_SUCCESS       Total number of clocks supported is returned.
 | |
|   @retval EFI_DEVICE_ERROR  SCP returns an SCMI error.
 | |
|   @retval !(EFI_SUCCESS)    Other errors.
 | |
| **/
 | |
| typedef
 | |
| EFI_STATUS
 | |
| (EFIAPI *SCMI_CLOCK2_GET_TOTAL_CLOCKS)(
 | |
|   IN  SCMI_CLOCK2_PROTOCOL  *This,
 | |
|   OUT UINT32                *TotalClocks
 | |
|   );
 | |
| 
 | |
| /** Return attributes of a clock device.
 | |
| 
 | |
|   @param[in]  This        A Pointer to SCMI_CLOCK2_PROTOCOL Instance.
 | |
|   @param[in]  ClockId     Identifier for the clock device.
 | |
| 
 | |
|   @param[out] Enabled         If TRUE, the clock device is enabled.
 | |
|   @param[out] ClockAsciiName  A NULL terminated ASCII string with the clock
 | |
|                               name, of up to 16 bytes.
 | |
| 
 | |
|   @retval EFI_SUCCESS          Clock device attributes are returned.
 | |
|   @retval EFI_DEVICE_ERROR     SCP returns an SCMI error.
 | |
|   @retval !(EFI_SUCCESS)       Other errors.
 | |
| **/
 | |
| typedef
 | |
| EFI_STATUS
 | |
| (EFIAPI *SCMI_CLOCK2_GET_CLOCK_ATTRIBUTES)(
 | |
|   IN  SCMI_CLOCK2_PROTOCOL  *This,
 | |
|   IN  UINT32                ClockId,
 | |
|   OUT BOOLEAN               *Enabled,
 | |
|   OUT CHAR8                 *ClockAsciiName
 | |
|   );
 | |
| 
 | |
| /** Return list of rates supported by a given clock device.
 | |
| 
 | |
|   @param[in] This        A pointer to SCMI_CLOCK2_PROTOCOL Instance.
 | |
|   @param[in] ClockId     Identifier for the clock device.
 | |
| 
 | |
|   @param[out] Format      ScmiClockRateFormatDiscrete: Clock device
 | |
|                           supports range of clock rates which are non-linear.
 | |
| 
 | |
|                           ScmiClockRateFormatLinear: Clock device supports
 | |
|                           range of linear clock rates from Min to Max in steps.
 | |
| 
 | |
|   @param[out] TotalRates  Total number of rates.
 | |
| 
 | |
|   @param[in,out] RateArraySize  Size of the RateArray.
 | |
| 
 | |
|   @param[out] RateArray   List of clock rates.
 | |
| 
 | |
|   @retval EFI_SUCCESS          List of clock rates are returned.
 | |
|   @retval EFI_DEVICE_ERROR     SCP returns an SCMI error.
 | |
|   @retval EFI_BUFFER_TOO_SMALL RateArraySize is too small for the result.
 | |
|                                It has been updated to the size needed.
 | |
|   @retval !(EFI_SUCCESS)       Other errors.
 | |
| **/
 | |
| typedef
 | |
| EFI_STATUS
 | |
| (EFIAPI *SCMI_CLOCK2_DESCRIBE_RATES)(
 | |
|   IN     SCMI_CLOCK2_PROTOCOL     *This,
 | |
|   IN     UINT32                   ClockId,
 | |
|   OUT    SCMI_CLOCK_RATE_FORMAT   *Format,
 | |
|   OUT    UINT32                   *TotalRates,
 | |
|   IN OUT UINT32                   *RateArraySize,
 | |
|   OUT    SCMI_CLOCK_RATE          *RateArray
 | |
|   );
 | |
| 
 | |
| /** Get clock rate.
 | |
| 
 | |
|   @param[in]  This        A Pointer to SCMI_CLOCK2_PROTOCOL Instance.
 | |
|   @param[in]  ClockId     Identifier for the clock device.
 | |
| 
 | |
|   @param[out]  Rate       Clock rate.
 | |
| 
 | |
|   @retval EFI_SUCCESS          Clock rate is returned.
 | |
|   @retval EFI_DEVICE_ERROR     SCP returns an SCMI error.
 | |
|   @retval !(EFI_SUCCESS)       Other errors.
 | |
| **/
 | |
| typedef
 | |
| EFI_STATUS
 | |
| (EFIAPI *SCMI_CLOCK2_RATE_GET)(
 | |
|   IN  SCMI_CLOCK2_PROTOCOL  *This,
 | |
|   IN  UINT32                ClockId,
 | |
|   OUT UINT64                *Rate
 | |
|   );
 | |
| 
 | |
| /** Set clock rate.
 | |
| 
 | |
|   @param[in]  This        A Pointer to SCMI_CLOCK2_PROTOCOL Instance.
 | |
|   @param[in]  ClockId     Identifier for the clock device.
 | |
|   @param[in]  Rate        Clock rate.
 | |
| 
 | |
|   @retval EFI_SUCCESS          Clock rate set success.
 | |
|   @retval EFI_DEVICE_ERROR     SCP returns an SCMI error.
 | |
|   @retval !(EFI_SUCCESS)       Other errors.
 | |
| **/
 | |
| typedef
 | |
| EFI_STATUS
 | |
| (EFIAPI *SCMI_CLOCK2_RATE_SET)(
 | |
|   IN SCMI_CLOCK2_PROTOCOL   *This,
 | |
|   IN UINT32                 ClockId,
 | |
|   IN UINT64                 Rate
 | |
|   );
 | |
| 
 | |
| /** Enable/Disable specified clock.
 | |
|     Function is only available under gArmScmiClock2ProtocolGuid
 | |
| 
 | |
|   @param[in]  This        A Pointer to SCMI_CLOCK2_PROTOCOL Instance.
 | |
|   @param[in]  ClockId     Identifier for the clock device.
 | |
|   @param[in]  Enable      TRUE to enable, FALSE to disable.
 | |
| 
 | |
|   @retval EFI_SUCCESS          Clock enable/disable successful.
 | |
|   @retval EFI_DEVICE_ERROR     SCP returns an SCMI error.
 | |
|   @retval !(EFI_SUCCESS)       Other errors.
 | |
| **/
 | |
| typedef
 | |
| EFI_STATUS
 | |
| (EFIAPI *SCMI_CLOCK2_ENABLE)(
 | |
|   IN SCMI_CLOCK2_PROTOCOL   *This,
 | |
|   IN UINT32                 ClockId,
 | |
|   IN BOOLEAN                Enable
 | |
|   );
 | |
| 
 | |
| typedef struct _SCMI_CLOCK2_PROTOCOL {
 | |
|   SCMI_CLOCK2_GET_VERSION             GetVersion;
 | |
|   SCMI_CLOCK2_GET_TOTAL_CLOCKS        GetTotalClocks;
 | |
|   SCMI_CLOCK2_GET_CLOCK_ATTRIBUTES    GetClockAttributes;
 | |
|   SCMI_CLOCK2_DESCRIBE_RATES          DescribeRates;
 | |
|   SCMI_CLOCK2_RATE_GET                RateGet;
 | |
|   SCMI_CLOCK2_RATE_SET                RateSet;
 | |
| 
 | |
|   // Extension to original ClockProtocol, added here so SCMI_CLOCK2_PROTOCOL
 | |
|   // can be cast to SCMI_CLOCK_PROTOCOL
 | |
|   UINTN                               Version; // For future expandability
 | |
|   SCMI_CLOCK2_ENABLE                  Enable;
 | |
| } SCMI_CLOCK2_PROTOCOL;
 | |
| 
 | |
| #endif /* ARM_SCMI_CLOCK2_PROTOCOL_H_ */
 |