2019-01-08 09:46:35 +00:00
|
|
|
/*
|
2021-08-09 19:00:41 +01:00
|
|
|
* Copyright (c) 2019-2022, Xilinx, Inc. All rights reserved.
|
2019-01-08 09:46:35 +00:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef PM_API_SYS_H
|
|
|
|
#define PM_API_SYS_H
|
|
|
|
|
|
|
|
#include <stdint.h>
|
2019-12-09 07:29:44 +00:00
|
|
|
#include "pm_defs.h"
|
2019-01-08 09:46:35 +00:00
|
|
|
|
|
|
|
/**********************************************************
|
|
|
|
* PM API function declarations
|
|
|
|
**********************************************************/
|
|
|
|
|
2021-08-09 19:00:41 +01:00
|
|
|
enum pm_ret_status pm_handle_eemi_call(uint32_t flag, uint32_t x0, uint32_t x1,
|
|
|
|
uint32_t x2, uint32_t x3, uint32_t x4,
|
|
|
|
uint32_t x5, uint64_t *result);
|
2019-12-09 07:29:44 +00:00
|
|
|
enum pm_ret_status pm_self_suspend(uint32_t nid,
|
|
|
|
unsigned int latency,
|
|
|
|
unsigned int state,
|
2021-02-26 04:16:56 +00:00
|
|
|
uintptr_t address, uint32_t flag);
|
|
|
|
enum pm_ret_status pm_abort_suspend(enum pm_abort_reason reason, uint32_t flag);
|
2019-12-09 07:29:44 +00:00
|
|
|
enum pm_ret_status pm_req_suspend(uint32_t target,
|
|
|
|
uint8_t ack,
|
|
|
|
unsigned int latency,
|
2021-02-26 04:16:56 +00:00
|
|
|
unsigned int state, uint32_t flag);
|
2019-01-23 08:48:51 +00:00
|
|
|
enum pm_ret_status pm_req_wakeup(uint32_t target, uint32_t set_address,
|
2021-02-26 04:16:56 +00:00
|
|
|
uintptr_t address, uint8_t ack, uint32_t flag);
|
2019-01-23 08:48:53 +00:00
|
|
|
enum pm_ret_status pm_set_wakeup_source(uint32_t target, uint32_t device_id,
|
2021-02-26 04:16:56 +00:00
|
|
|
uint8_t enable, uint32_t flag);
|
|
|
|
void pm_get_callbackdata(uint32_t *data, size_t count, uint32_t flag);
|
2019-01-08 09:46:41 +00:00
|
|
|
enum pm_ret_status pm_pll_set_param(uint32_t clk_id, uint32_t param,
|
2021-02-26 04:16:56 +00:00
|
|
|
uint32_t value, uint32_t flag);
|
2019-01-08 09:46:41 +00:00
|
|
|
enum pm_ret_status pm_pll_get_param(uint32_t clk_id, uint32_t param,
|
2021-02-26 04:16:56 +00:00
|
|
|
uint32_t *value, uint32_t flag);
|
|
|
|
enum pm_ret_status pm_pll_set_mode(uint32_t clk_id, uint32_t mode,
|
|
|
|
uint32_t flag);
|
|
|
|
enum pm_ret_status pm_pll_get_mode(uint32_t clk_id, uint32_t *mode,
|
|
|
|
uint32_t flag);
|
|
|
|
enum pm_ret_status pm_force_powerdown(uint32_t target, uint8_t ack,
|
|
|
|
uint32_t flag);
|
|
|
|
enum pm_ret_status pm_system_shutdown(uint32_t type, uint32_t subtype,
|
|
|
|
uint32_t flag);
|
2019-01-10 11:03:48 +00:00
|
|
|
enum pm_ret_status pm_api_ioctl(uint32_t device_id, uint32_t ioctl_id,
|
2021-02-26 04:16:56 +00:00
|
|
|
uint32_t arg1, uint32_t arg2, uint32_t *value,
|
|
|
|
uint32_t flag);
|
2019-02-01 11:55:19 +00:00
|
|
|
enum pm_ret_status pm_query_data(uint32_t qid, uint32_t arg1, uint32_t arg2,
|
2021-02-26 04:16:56 +00:00
|
|
|
uint32_t arg3, uint32_t *data, uint32_t flag);
|
2019-12-09 07:35:35 +00:00
|
|
|
unsigned int pm_get_shutdown_scope(void);
|
2021-02-26 04:16:56 +00:00
|
|
|
enum pm_ret_status pm_feature_check(uint32_t api_id, unsigned int *version,
|
|
|
|
uint32_t flag);
|
2019-03-22 00:03:39 +00:00
|
|
|
enum pm_ret_status pm_load_pdi(uint32_t src, uint32_t address_low,
|
2021-02-26 04:16:56 +00:00
|
|
|
uint32_t address_high, uint32_t flag);
|
2020-11-25 09:56:57 +00:00
|
|
|
enum pm_ret_status pm_register_notifier(uint32_t device_id, uint32_t event,
|
2021-02-26 04:16:56 +00:00
|
|
|
uint32_t wake, uint32_t enable,
|
|
|
|
uint32_t flag);
|
2019-01-08 09:46:35 +00:00
|
|
|
#endif /* PM_API_SYS_H */
|