blob: 5a927043e790634624d9583b3da905c4006013f0 [file] [log] [blame]
Tejas Patel9d09ff92019-01-08 01:46:35 -08001/*
Ravi Patel476b5b12019-08-12 03:10:10 -07002 * Copyright (c) 2019-2020, Xilinx, Inc. All rights reserved.
Tejas Patel9d09ff92019-01-08 01:46:35 -08003 *
4 * SPDX-License-Identifier: BSD-3-Clause
5 */
6
7#ifndef PM_API_SYS_H
8#define PM_API_SYS_H
9
10#include <stdint.h>
Tejas Patelfe0e10a2019-12-08 23:29:44 -080011#include "pm_defs.h"
Tejas Patel9d09ff92019-01-08 01:46:35 -080012
13/**********************************************************
14 * PM API function declarations
15 **********************************************************/
16
Tejas Patel18072da2021-02-25 20:16:56 -080017enum pm_ret_status pm_get_api_version(unsigned int *version, uint32_t flag);
18enum pm_ret_status pm_init_finalize(uint32_t flag);
Tejas Patelfe0e10a2019-12-08 23:29:44 -080019enum pm_ret_status pm_self_suspend(uint32_t nid,
20 unsigned int latency,
21 unsigned int state,
Tejas Patel18072da2021-02-25 20:16:56 -080022 uintptr_t address, uint32_t flag);
23enum pm_ret_status pm_abort_suspend(enum pm_abort_reason reason, uint32_t flag);
Tejas Patelfe0e10a2019-12-08 23:29:44 -080024enum pm_ret_status pm_req_suspend(uint32_t target,
25 uint8_t ack,
26 unsigned int latency,
Tejas Patel18072da2021-02-25 20:16:56 -080027 unsigned int state, uint32_t flag);
Tejas Patel49cd8712019-01-23 14:18:51 +053028enum pm_ret_status pm_req_wakeup(uint32_t target, uint32_t set_address,
Tejas Patel18072da2021-02-25 20:16:56 -080029 uintptr_t address, uint8_t ack, uint32_t flag);
Tejas Pateldb812052019-01-23 14:18:53 +053030enum pm_ret_status pm_set_wakeup_source(uint32_t target, uint32_t device_id,
Tejas Patel18072da2021-02-25 20:16:56 -080031 uint8_t enable, uint32_t flag);
Tejas Patel41f3e0b2019-01-08 01:46:37 -080032enum pm_ret_status pm_request_device(uint32_t device_id, uint32_t capabilities,
Tejas Patel18072da2021-02-25 20:16:56 -080033 uint32_t qos, uint32_t ack, uint32_t flag);
34enum pm_ret_status pm_release_device(uint32_t device_id, uint32_t flag);
Tejas Patel41f3e0b2019-01-08 01:46:37 -080035enum pm_ret_status pm_set_requirement(uint32_t device_id, uint32_t capabilities,
Tejas Patel18072da2021-02-25 20:16:56 -080036 uint32_t latency, uint32_t qos,
37 uint32_t flag);
38enum pm_ret_status pm_get_device_status(uint32_t device_id, uint32_t *response,
39 uint32_t flag);
40enum pm_ret_status pm_reset_assert(uint32_t reset, bool assert, uint32_t flag);
41enum pm_ret_status pm_reset_get_status(uint32_t reset, uint32_t *status,
42 uint32_t flag);
43void pm_get_callbackdata(uint32_t *data, size_t count, uint32_t flag);
44enum pm_ret_status pm_pinctrl_request(uint32_t pin, uint32_t flag);
45enum pm_ret_status pm_pinctrl_release(uint32_t pin, uint32_t flag);
46enum pm_ret_status pm_pinctrl_set_function(uint32_t pin, uint32_t function,
47 uint32_t flag);
48enum pm_ret_status pm_pinctrl_get_function(uint32_t pin, uint32_t *function,
49 uint32_t flag);
Tejas Patel20e92022019-01-08 01:46:39 -080050enum pm_ret_status pm_pinctrl_set_pin_param(uint32_t pin, uint32_t param,
Tejas Patel18072da2021-02-25 20:16:56 -080051 uint32_t value, uint32_t flag);
Tejas Patel20e92022019-01-08 01:46:39 -080052enum pm_ret_status pm_pinctrl_get_pin_param(uint32_t pin, uint32_t param,
Tejas Patel18072da2021-02-25 20:16:56 -080053 uint32_t *value, uint32_t flag);
54enum pm_ret_status pm_clock_enable(uint32_t clk_id, uint32_t flag);
55enum pm_ret_status pm_clock_disable(uint32_t clk_id, uint32_t flag);
56enum pm_ret_status pm_clock_get_state(uint32_t clk_id, uint32_t *state,
57 uint32_t flag);
58enum pm_ret_status pm_clock_set_divider(uint32_t clk_id, uint32_t divider,
59 uint32_t flag);
60enum pm_ret_status pm_clock_get_divider(uint32_t clk_id, uint32_t *divider,
61 uint32_t flag);
62enum pm_ret_status pm_clock_set_parent(uint32_t clk_id, uint32_t parent,
63 uint32_t flag);
64enum pm_ret_status pm_clock_get_parent(uint32_t clk_id, uint32_t *parent,
65 uint32_t flag);
66enum pm_ret_status pm_clock_get_rate(uint32_t clk_id, uint32_t *clk_rate,
67 uint32_t flag);
Tejas Patel023116d2019-01-08 01:46:41 -080068enum pm_ret_status pm_pll_set_param(uint32_t clk_id, uint32_t param,
Tejas Patel18072da2021-02-25 20:16:56 -080069 uint32_t value, uint32_t flag);
Tejas Patel023116d2019-01-08 01:46:41 -080070enum pm_ret_status pm_pll_get_param(uint32_t clk_id, uint32_t param,
Tejas Patel18072da2021-02-25 20:16:56 -080071 uint32_t *value, uint32_t flag);
72enum pm_ret_status pm_pll_set_mode(uint32_t clk_id, uint32_t mode,
73 uint32_t flag);
74enum pm_ret_status pm_pll_get_mode(uint32_t clk_id, uint32_t *mode,
75 uint32_t flag);
76enum pm_ret_status pm_force_powerdown(uint32_t target, uint8_t ack,
77 uint32_t flag);
78enum pm_ret_status pm_system_shutdown(uint32_t type, uint32_t subtype,
79 uint32_t flag);
Tejas Patel9141f442019-01-10 03:03:48 -080080enum pm_ret_status pm_api_ioctl(uint32_t device_id, uint32_t ioctl_id,
Tejas Patel18072da2021-02-25 20:16:56 -080081 uint32_t arg1, uint32_t arg2, uint32_t *value,
82 uint32_t flag);
Tejas Patela3e34ad2019-02-01 17:25:19 +053083enum pm_ret_status pm_query_data(uint32_t qid, uint32_t arg1, uint32_t arg2,
Tejas Patel18072da2021-02-25 20:16:56 -080084 uint32_t arg3, uint32_t *data, uint32_t flag);
Saeed Nowshadic5a1bda2019-12-08 23:35:35 -080085unsigned int pm_get_shutdown_scope(void);
Tejas Patel18072da2021-02-25 20:16:56 -080086enum pm_ret_status pm_get_chipid(uint32_t *value, uint32_t flag);
87enum pm_ret_status pm_feature_check(uint32_t api_id, unsigned int *version,
88 uint32_t flag);
Jolly Shahed05a712019-03-22 05:33:39 +053089enum pm_ret_status pm_load_pdi(uint32_t src, uint32_t address_low,
Tejas Patel18072da2021-02-25 20:16:56 -080090 uint32_t address_high, uint32_t flag);
Saeed Nowshadi2294b422019-06-03 10:22:35 -070091enum pm_ret_status pm_get_op_characteristic(uint32_t device_id,
92 enum pm_opchar_type type,
Tejas Patel18072da2021-02-25 20:16:56 -080093 uint32_t *result, uint32_t flag);
94enum pm_ret_status pm_set_max_latency(uint32_t device_id, uint32_t latency,
95 uint32_t flag);
Tejas Patel42015552020-11-25 01:56:57 -080096enum pm_ret_status pm_register_notifier(uint32_t device_id, uint32_t event,
Tejas Patel18072da2021-02-25 20:16:56 -080097 uint32_t wake, uint32_t enable,
98 uint32_t flag);
Tejas Patel9d09ff92019-01-08 01:46:35 -080099#endif /* PM_API_SYS_H */