mirror of
https://github.com/ARM-software/arm-trusted-firmware.git
synced 2025-04-16 01:24:27 +00:00

Add the basic support for i.MX8ULP. The i.MX 8ULP family of processors features NXP’s advanced implementation of the dual Arm Cortex-A35 cores alongside an Arm Cortex-M33. This combined architecture enables the device to run a rich operating system (such as Linux) on the Cortex-A35 core and an RTOS (such as FreeRTOS) on the Cortex-M33 core. It also includes a Cadence Tensilica Fusion DSP for low-power audio and a HiFi4 DSP for advanced audio and machine learning applications. Signed-off-by: Peng Fan <peng.fan@nxp.com> Signed-off-by: Ye Li <ye.li@nxp.com> Signed-off-by: Jacky Bai <ping.bai@nxp.com> Change-Id: I12df622b95960bcdf7da52e4c66470a700690e36
1629 lines
72 KiB
C
1629 lines
72 KiB
C
/* SPDX-License-Identifier: BSD-3-Clause */
|
|
/**
|
|
* Copyright 2019-2024 NXP
|
|
*
|
|
* KEYWORDS: micro-power uPower driver API
|
|
* -----------------------------------------------------------------------------
|
|
* PURPOSE: uPower driver API
|
|
* -----------------------------------------------------------------------------
|
|
* PARAMETERS:
|
|
* PARAM NAME RANGE:DESCRIPTION: DEFAULTS: UNITS
|
|
* -----------------------------------------------------------------------------
|
|
* REUSE ISSUES: no reuse issues
|
|
*/
|
|
#ifndef UPWR_API_H
|
|
#define UPWR_API_H
|
|
|
|
#include "upmu.h"
|
|
#include "upower_soc_defs.h"
|
|
/******************************************************************************
|
|
* uPower API Overview and Concepts
|
|
*
|
|
* This API is intended to be used by the OS drivers (Linux, FreeRTOS etc)
|
|
* as well as bare metal drivers to command and use services from the uPower.
|
|
* It aims to be OS-independent.
|
|
*
|
|
* The API functions fall in 3 categories:
|
|
* - initialization/start-up
|
|
* - service requests
|
|
* - auxiliary
|
|
*
|
|
* The communication with the uPower is mostly made through the Message Unit
|
|
* (MU) IP. uPower provides one MU for each CPU cluster in a different
|
|
* power domain. An API instance runs on each CPU cluster.
|
|
*
|
|
* The API assumes each SoC power domain/CPU cluster receives 2 interrupts
|
|
* from the uPower MU:
|
|
* 1. Tx/Rx, which is issued on both transmission and reception
|
|
* 2. Exception interrupt, to handle critical alams, catastrophic errors, etc.
|
|
* This interrupt should have a high priority, preferably an NMI.
|
|
*
|
|
* The normal uPower operation is done by service requests. There is an API
|
|
* function for each service request, and all service requests send back a
|
|
* response, at least to indicate success/failure.
|
|
* The service request functions are non-blocking, and their completion can be
|
|
* tracked in two ways:
|
|
* 1. by a callback, registered when the service request call is made by
|
|
* passing the callback function pointer; a NULL pointer may be passed,
|
|
* in which case no callback is made.
|
|
* 2. by polling, using the auxiliary functions upwr_req_status or
|
|
* upwr_poll_req_status;
|
|
* polling must be used if no callback is registered, but callbacks and
|
|
* polling are completely independent.
|
|
*
|
|
* Note: a service request must not be started from a callback.
|
|
*
|
|
* uPower service requests are classified in Service Groups.
|
|
* Each Service Group has a set of related functions, named upwr_XXX_,
|
|
* where XXX is a 3-letter service group mnemonic. The service groups are:
|
|
* - Exception Service Group - upwr_xcp_*
|
|
* ~ gathers functions that deal with errors and other processes outside
|
|
* the functional scope.
|
|
* - Power Management Service Group - upwr_pwm_*
|
|
* ~ functions to control switches, configure power modes, set internal voltage etc
|
|
* - Delay Measurement Service Group - upwr_dlm_*
|
|
* ~ delay measurements function using the process monitor and delay meter
|
|
* - Voltage Measurement Service Group - upwr_vtm_*
|
|
* ~ functions for voltage measurements, comparisons, alarms, power meter, set PMIC rail voltage
|
|
* - Temperature Measurement Service Group - upwr_tpm_*
|
|
* ~ functions for temperature measurements, comparisons, alarms
|
|
* - Current Measurement Service Group - upwr_crm_*
|
|
* ~ functions for current and charge measurement
|
|
* - Diagnostic Service Group - upwr_dgn_*
|
|
* ~ functions for log configuration and statistics collecting
|
|
*
|
|
* Service requests follow this "golden rule":
|
|
* *** No two requests run simultaneously for the same service group,
|
|
* on the same domain ***
|
|
* They can run simultaneously on different domains (RTD/APD), and can also run
|
|
* simultaneously if belong to different service groups (even on same domain).
|
|
* Therefore, requests to the same service group on the same domain must be
|
|
* serialized. A service request call returns error if there is another request
|
|
* on the same service group pending, waiting a response (on the same domain).
|
|
*
|
|
* A request for continuous service does not block the service group.
|
|
* For instance, a request to "measure the temperature each 10 miliseconds"
|
|
* responds quickly, unlocks the service group, and the temperature
|
|
* continues to be measured as requested, every 10 miliseconds from then on.
|
|
*
|
|
* Service Groups have a fixed priority in the API, from higher to lower:
|
|
* 1. Exception
|
|
* 2. Power Management
|
|
* 3. Delay Measurement
|
|
* 4. Voltage Measurement
|
|
* 5. Current Measurement
|
|
* 6. Temperature Measurement
|
|
* 7. Diagnostics
|
|
*
|
|
* The priority above only affects the order in which requests are sent to the
|
|
* uPower firmware: request to the higher priority Service Group is sent first,
|
|
* even if the call was made later, if there is an MU transmission pending,
|
|
* blocking it. The service priorities in the firmware depend on other factors.
|
|
*
|
|
* Services are requested using API functions. A service function returns with
|
|
* no error if a request was successfully made, but it doesn't mean the service
|
|
* was completed. The service is executed asynchronously, and returns a result
|
|
* (at least success/fail) via a callback or polling for service status.
|
|
* The possible service response codes are:
|
|
* - UPWR_RESP_OK = 0, : no error
|
|
* - UPWR_RESP_SG_BUSY : service group is busy
|
|
* - UPWR_RESP_SHUTDOWN : services not up or shutting down
|
|
* - UPWR_RESP_BAD_REQ : invalid request (usually invalid argumnents)
|
|
* - UPWR_RESP_BAD_STATE : system state doesn't allow perform the request
|
|
* - UPWR_RESP_UNINSTALLD : service or function not installed
|
|
* - UPWR_RESP_UNINSTALLED : service or function not installed (alias)
|
|
* - UPWR_RESP_RESOURCE : resource not available
|
|
* - UPWR_RESP_TIMEOUT : service timeout
|
|
*/
|
|
|
|
/**
|
|
* upwr_callb()-generic function pointer for a request return callback;
|
|
* @sg: request service group
|
|
* @func: service request function id.
|
|
* @errcode: error code.
|
|
* @ret: return value, if any. Note that a request may return a value even if
|
|
* service error is returned (errcode != UPWR_RESP_OK); that is dependent on
|
|
* the specific service.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: none (void)
|
|
*/
|
|
typedef void (*upwr_callb)(upwr_sg_t sg, uint32_t func,
|
|
upwr_resp_t errcode, ...);
|
|
|
|
/**---------------------------------------------------------------
|
|
* INITIALIZATION, CONFIGURATION
|
|
*
|
|
* A reference uPower initialization sequence goes as follows:
|
|
*
|
|
* 1. host CPU calls upwr_init.
|
|
* 2. (optional) host checks the ROM version and SoC code calling upwr_vers(...)
|
|
* and optionally performs any configuration or workaround accordingly.
|
|
* 3. host CPU calls upwr_start to start the uPower services, passing a
|
|
* service option number.
|
|
* If no RAM code is loaded or it has no service options, the launch option
|
|
* number passed must be 0, which will start the services available in ROM.
|
|
* upwr_start also receives a pointer to a callback called by the API
|
|
* when the firmware is ready to receive service requests.
|
|
* The callback may be replaced by polling, calling upwr_req_status in a loop
|
|
* or upwr_poll_req_status; in this case the callback pointer may be NULL.
|
|
* A host may call upwr_start even if the services were already started by
|
|
* any host: if the launch option is the same, the response will be ok,
|
|
* but will indicate error if the services were already started with a
|
|
* different launch option.
|
|
* 4. host waits for the callback calling, or polling finishing;
|
|
* if no error is returned, it can start making service calls using the API.
|
|
*
|
|
* Variations on that reference sequence are possible:
|
|
* - the uPower services can be started using the ROM code only, which includes
|
|
* the basic Power Management services, among others, with launch option
|
|
* number = 0.
|
|
* The code RAM can be loaded while these services are running and,
|
|
* when the loading is done, the services can be re-started with these 2
|
|
* requests executed in order: upwr_xcp_shutdown and upwr_start,
|
|
* using the newly loaded RAM code (launch option > 0).
|
|
*
|
|
* NOTE: the initialization call upwr_init is not effective and
|
|
* returns error when called after the uPower services are started.
|
|
*/
|
|
|
|
/**
|
|
* upwr_init() - API initialization; must be the first API call after reset.
|
|
* @domain: SoC-dependent CPU domain id; identifier used by the firmware in
|
|
* many services. Defined by SoC-dependent type soc_domain_t found in
|
|
* upower_soc_defs.h.
|
|
* @muptr: pointer to the MU instance.
|
|
* @mallocptr: pointer to the memory allocation function
|
|
* @physaddrptr: pointer to the function to convert pointers to
|
|
* physical addresses. If NULL, no conversion is made (pointer=physical address)
|
|
* @isrinstptr: pointer to the function to install the uPower ISR callbacks;
|
|
* the function receives the pointers to the MU tx/rx and Exception ISRs
|
|
* callbacks, which must be called from the actual system ISRs.
|
|
* The function pointed by isrinstptr must also enable the interrupt at the
|
|
* core/interrupt controller, but must not enable the interrupt at the MU IP.
|
|
* The system ISRs are responsible for dealing with the interrupt controller,
|
|
* performing any other context save/restore, and any other housekeeping.
|
|
* @lockptr: pointer to a function that prevents MU interrupts (if argrument=1)
|
|
* or allows it (if argument=0). The API calls this function to make small
|
|
* specific code portions thread safe. Only MU interrupts must be avoided,
|
|
* the code may be suspended for other reasons.
|
|
* If no MU interrupts can happen during the execution of an API call or
|
|
* callback, even if enabled, for some other reason (e.g. interrupt priority),
|
|
* then this argument may be NULL.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if failed to allocate memory, or use some other resource.
|
|
* -2 if any argument is invalid.
|
|
* -3 if failed to send the ping message.
|
|
* -4 if failed to receive the initialization message, or was invalid
|
|
*/
|
|
|
|
/* malloc function ptr */
|
|
typedef void* (*upwr_malloc_ptr_t)(unsigned int size);
|
|
|
|
/* pointer->physical address conversion function ptr */
|
|
typedef void* (*upwr_phyadr_ptr_t)(const void *addr);
|
|
|
|
typedef uint32_t upwr_api_state_t;
|
|
|
|
extern volatile upwr_api_state_t api_state;
|
|
|
|
/*
|
|
* upwr_lock_ptr_t: pointer to a function that prevents MU interrupts
|
|
* (if argrument lock=1) or allows it (if argument lock=0).
|
|
* The API calls this function to make small specific code portions thread safe.
|
|
* Only MU interrupts must be avoided, the code may be suspended for other
|
|
* reasons.
|
|
*/
|
|
typedef void (*upwr_lock_ptr_t)(int lock);
|
|
|
|
typedef void (*upwr_isr_callb)(void);
|
|
|
|
typedef void (*upwr_inst_isr_ptr_t)(upwr_isr_callb txrx_isr,
|
|
upwr_isr_callb excp_isr);
|
|
void upwr_start_callb(void);
|
|
|
|
int upwr_init(soc_domain_t domain, struct MU_t *muptr,
|
|
const upwr_malloc_ptr_t mallocptr,
|
|
const upwr_phyadr_ptr_t phyadrptr,
|
|
const upwr_inst_isr_ptr_t isrinstptr,
|
|
const upwr_lock_ptr_t lockptr);
|
|
|
|
/**
|
|
* upwr_start() - Starts the uPower services.
|
|
* @launchopt: a number to select between multiple launch options,
|
|
* that may define, among other things, which services will be started,
|
|
* or which services implementations, features etc.
|
|
* launchopt = 0 selects a subset of services implemented in ROM;
|
|
* any other number selects service sets implemented in RAM, launched
|
|
* by the firmware function ram_launch; if an invalid launchopt value is passed,
|
|
* no services are started, and the callback returns error (see below).
|
|
* @rdycallb: pointer to the callback to be called when the uPower is ready
|
|
* to receive service requests. NULL if no callback needed.
|
|
* The callback receives as arguments the RAM firmware version numbers.
|
|
* If all 3 numbers (vmajor, vminor, vfixes) are 0, that means the
|
|
* service launching failed.
|
|
* Firmware version numbers will be the same as ROM if launchopt = 0,
|
|
* selecting the ROM services.
|
|
*
|
|
* upwr_start can be called by any domain even if the services are already
|
|
* started: it has no effect, returning success, if the launch option is the
|
|
* same as the one that actually started the service, and returns error if
|
|
* called with a different option.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded or
|
|
* not.
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_EXCEPT as the service group argument.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if a resource failed,
|
|
* -2 if the domain passed is the same as the caller,
|
|
* -3 if called in an invalid API state
|
|
*/
|
|
|
|
extern void upwr_txrx_isr(void);
|
|
|
|
typedef void (*upwr_rdy_callb)(uint32_t vmajor, uint32_t vminor, uint32_t vfixes);
|
|
|
|
int upwr_start(uint32_t launchopt, const upwr_rdy_callb rdycallb);
|
|
|
|
|
|
/**---------------------------------------------------------------
|
|
* EXCEPTION SERVICE GROUP
|
|
*/
|
|
|
|
/**
|
|
* upwr_xcp_config() - Applies general uPower configurations.
|
|
* @config: pointer to the uPower SoC-dependent configuration struct
|
|
* upwr_xcp_config_t defined in upower_soc_defs.h. NULL may be passed, meaning
|
|
* a request to read the configuration, in which case it appears in the callback
|
|
* argument ret, or can be pointed by argument retptr in the upwr_req_status and
|
|
* upwr_poll_req_status calls, casted to upwr_xcp_config_t.
|
|
* @callb: pointer to the callback to be called when the uPower has finished
|
|
* the configuration, or NULL if no callback needed (polling used instead).
|
|
*
|
|
* Some configurations are targeted for a specific domain (see the struct
|
|
* upwr_xcp_config_t definition in upower_soc_defs.h); this call has implicit
|
|
* domain target (the same domain from which is called).
|
|
*
|
|
* The return value is always the current configuration value, either in a
|
|
* read-only request (config = NULL) or after setting a new configuration
|
|
* (non-NULL config).
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded or
|
|
* not.
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_EXCEPT as the service group argument.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
*/
|
|
|
|
int upwr_xcp_config(const upwr_xcp_config_t *config, const upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_xcp_sw_alarm() - Makes uPower issue an alarm interrupt to given domain.
|
|
* @domain: identifier of the domain to alarm. Defined by SoC-dependent type
|
|
* soc_domain_t found in upower_soc_defs.h.
|
|
* @code: alarm code. Defined by SoC-dependent type upwr_alarm_t found in
|
|
* upower_soc_defs.h.
|
|
* @callb: pointer to the callback to be called when the uPower has finished
|
|
* the alarm, or NULL if no callback needed (polling used instead).
|
|
*
|
|
* The function requests the uPower to issue an alarm of the given code as if
|
|
* it had originated internally. This service is useful mainly to test the
|
|
* system response to such alarms, or to make the system handle a similar alarm
|
|
* situation detected externally to uPower.
|
|
*
|
|
* The system ISR/code handling the alarm may retrieve the alarm code by calling
|
|
* the auxiliary function upwr_alarm_code.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded or
|
|
* not.
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_EXCEPT as the service group argument.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
*/
|
|
|
|
int upwr_xcp_sw_alarm(soc_domain_t domain, upwr_alarm_t code,
|
|
const upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_xcp_set_ddr_retention() - M33/A35 can use this API to set/clear ddr retention
|
|
* @domain: identifier of the caller domain.
|
|
* soc_domain_t found in upower_soc_defs.h.
|
|
* @enable: true, means that set ddr retention, false clear ddr retention.
|
|
* @callb: NULL
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_EXCEPT as the service group argument.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
*/
|
|
|
|
int upwr_xcp_set_ddr_retention(soc_domain_t domain, uint32_t enable,
|
|
const upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_xcp_set_mipi_dsi_ena() - M33/A35 can use this API to set/clear mipi dsi ena
|
|
* @domain: identifier of the caller domain.
|
|
* soc_domain_t found in upower_soc_defs.h.
|
|
* @enable: true, means that set ddr retention, false clear ddr retention.
|
|
* @callb: NULL
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_EXCEPT as the service group argument.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
*/
|
|
|
|
int upwr_xcp_set_mipi_dsi_ena(soc_domain_t domain, uint32_t enable,
|
|
const upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_xcp_get_mipi_dsi_ena() - M33/A35 can use this API to get mipi dsi ena status
|
|
* @domain: identifier of the caller domain.
|
|
* soc_domain_t found in upower_soc_defs.h.
|
|
* @callb: NULL
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_EXCEPT as the service group argument.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
*/
|
|
|
|
int upwr_xcp_get_mipi_dsi_ena(soc_domain_t domain, const upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_xcp_set_osc_mode() - M33/A35 can use this API to set uPower OSC mode
|
|
* @domain: identifier of the caller domain.
|
|
* soc_domain_t found in upower_soc_defs.h.
|
|
* @osc_mode, 0 means low frequency, not 0 means high frequency.
|
|
* @callb: NULL
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_EXCEPT as the service group argument.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
*/
|
|
int upwr_xcp_set_osc_mode(soc_domain_t domain, uint32_t osc_mode,
|
|
const upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_xcp_set_rtd_use_ddr() - M33 call this API to inform uPower, M33 is using ddr
|
|
* @domain: identifier of the caller domain.
|
|
* soc_domain_t found in upower_soc_defs.h.
|
|
* @is_use_ddr: not 0, true, means that RTD is using ddr. 0, false, means that, RTD
|
|
* is not using ddr.
|
|
* @callb: NULL
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_EXCEPT as the service group argument.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
*/
|
|
int upwr_xcp_set_rtd_use_ddr(soc_domain_t domain, uint32_t is_use_ddr,
|
|
const upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_xcp_set_rtd_apd_llwu() - M33/A35 can use this API to set/clear rtd_llwu apd_llwu
|
|
* @domain: set which domain (RTD_DOMAIN, APD_DOMAIN) LLWU.
|
|
* soc_domain_t found in upower_soc_defs.h.
|
|
* @enable: true, means that set rtd_llwu or apd_llwu, false clear rtd_llwu or apd_llwu.
|
|
* @callb: NULL
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_EXCEPT as the service group argument.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
*/
|
|
int upwr_xcp_set_rtd_apd_llwu(soc_domain_t domain, uint32_t enable,
|
|
const upwr_callb callb);
|
|
/**
|
|
* upwr_xcp_shutdown() - Shuts down all uPower services and power mode tasks.
|
|
* @callb: pointer to the callback to be called when the uPower has finished
|
|
* the shutdown, or NULL if no callback needed
|
|
* (polling used instead).
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded or
|
|
* not.
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_EXCEPT as the service group argument.
|
|
*
|
|
* At the callback the uPower/API is back to initialization/start-up phase,
|
|
* so service request calls return error.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
*/
|
|
int upwr_xcp_shutdown(const upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_xcp_i2c_access() - Performs an access through the uPower I2C interface.
|
|
* @addr: I2C slave address, up to 10 bits.
|
|
* @data_size: determines the access direction and data size in bytes, up to 4;
|
|
* negetive data_size determines a read access with size -data_size;
|
|
* positive data_size determines a write access with size data_size;
|
|
* data_size=0 is invalid, making the service return error UPWR_RESP_BAD_REQ.
|
|
* @subaddr_size: size of the sub-address in bytes, up to 4; if subaddr_size=0,
|
|
* no subaddress is used.
|
|
* @subaddr: sub-address, only used if subaddr_size > 0.
|
|
* @wdata: write data, up to 4 bytes; ignored if data_size < 0 (read)
|
|
* @callb: pointer to the callback to be called when the uPower has finished
|
|
* the access, or NULL if no callback needed
|
|
* (polling used instead).
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded or
|
|
* not.
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_EXCEPT as the service group argument.
|
|
*
|
|
* The service performs a read (data_size < 0) or a write (data_size > 0) of
|
|
* up to 4 bytes on the uPower I2C interface. The data read from I2C comes via
|
|
* the callback argument ret, or written to the variable pointed by retptr,
|
|
* if polling is used (calls upwr_req_status or upwr_poll_req_status).
|
|
* ret (or *retptr) also returns the data written on writes.
|
|
*
|
|
* Sub-addressing is supported, with sub-address size determined by the argument
|
|
* subaddr_size, up to 4 bytes. Sub-addressing is not used if subaddr_size=0.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
*/
|
|
int upwr_xcp_i2c_access(uint16_t addr, int8_t data_size, uint8_t subaddr_size,
|
|
uint32_t subaddr, uint32_t wdata,
|
|
const upwr_callb callb);
|
|
|
|
|
|
/**---------------------------------------------------------------
|
|
* POWER MANAGEMENT SERVICE GROUP
|
|
*/
|
|
|
|
/**
|
|
* upwr_pwm_dom_power_on() - Commands uPower to power on the platform of other
|
|
* domain (not necessarily its core(s)); does not release the core reset.
|
|
* @domain: identifier of the domain to power on. Defined by SoC-dependent type
|
|
* soc_domain_t found in upower_soc_defs.h.
|
|
* @boot_start: must be 1 to start the domain core(s) boot(s), releasing
|
|
* its (their) resets, or 0 otherwise.
|
|
* @pwroncallb: pointer to the callback to be called when the uPower has
|
|
* finished the power on procedure, or NULL if no callback needed
|
|
* (polling used instead).
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded or
|
|
* not.
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_PWRMGMT as the service group argument.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -2 if the domain passed is the same as the caller,
|
|
* -3 if called in an invalid API state
|
|
*/
|
|
int upwr_pwm_dom_power_on(soc_domain_t domain, int boot_start,
|
|
const upwr_callb pwroncallb);
|
|
|
|
/**
|
|
* upwr_pwm_boot_start() - Commands uPower to release the reset of other CPU(s),
|
|
* starting their boots.
|
|
* @domain: identifier of the domain to release the reset. Defined by
|
|
* SoC-dependent type soc_domain_t found in upower_soc_defs.h.
|
|
* @bootcallb: pointer to the callback to be called when the uPower has finished
|
|
* the boot start procedure, or NULL if no callback needed
|
|
* (polling used instead).
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded or
|
|
* not.
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_PWRMGMT as the service group argument.
|
|
*
|
|
* The callback calling doesn't mean the CPUs boots have finished:
|
|
* it only indicates that uPower released the CPUs resets, and can receive
|
|
* other power management service group requests.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -2 if the domain passed is the same as the caller,
|
|
* -3 if called in an invalid API state
|
|
*/
|
|
int upwr_pwm_boot_start(soc_domain_t domain, const upwr_callb bootcallb);
|
|
|
|
/**
|
|
* upwr_pwm_param() - Changes Power Management parameters.
|
|
* @param: pointer to a parameter structure upwr_pwm_param_t, SoC-dependent,
|
|
* defined in upwr_soc_defines.h. NULL may be passed, meaning
|
|
* a request to read the parameter set, in which case it appears in the callback
|
|
* argument ret, or can be pointed by argument retptr in the upwr_req_status and
|
|
* upwr_poll_req_status calls, casted to upwr_pwm_param_t.
|
|
* @callb: response callback pointer; NULL if no callback needed.
|
|
*
|
|
* The return value is always the current parameter set value, either in a
|
|
* read-only request (param = NULL) or after setting a new parameter
|
|
* (non-NULL param).
|
|
*
|
|
* Some parameters may be targeted for a specific domain (see the struct
|
|
* upwr_pwm_param_t definition in upower_soc_defs.h); this call has implicit
|
|
* domain target (the same domain from which is called).
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded or
|
|
* not.
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_PWRMGMT as the service group argument.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
*/
|
|
int upwr_pwm_param(upwr_pwm_param_t *param, const upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_pwm_chng_reg_voltage() - Changes the voltage at a given regulator.
|
|
* @reg: regulator id.
|
|
* @volt: voltage value; value unit is SoC-dependent, converted from mV by the
|
|
* macro UPWR_VOLT_MILIV, or from micro-Volts by the macro UPWR_VOLT_MICROV,
|
|
* both macros in upower_soc_defs.h
|
|
* @callb: response callback pointer; NULL if no callback needed.
|
|
*
|
|
* The function requests uPower to change the voltage of the given regulator.
|
|
* The request is executed if arguments are within range, with no protections
|
|
* regarding the adequate voltage value for the given domain process,
|
|
* temperature and frequency.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_PWRMGMT as the service group argument.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
int upwr_pwm_chng_reg_voltage(uint32_t reg, uint32_t volt, upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_pwm_freq_setup() - Determines the next frequency target for a given
|
|
* domain and current frequency.
|
|
* @domain: identifier of the domain to change frequency. Defined by
|
|
* SoC-dependent type soc_domain_t found in upower_soc_defs.h.
|
|
* @rail: the pmic regulator number for the target domain.
|
|
* @stage: DVA adjust stage
|
|
* refer to upower_defs.h "DVA adjust stage"
|
|
* @target_freq: the target adjust frequency, accurate to MHz
|
|
*
|
|
* refer to upower_defs.h structure definition upwr_pwm_freq_msg
|
|
*
|
|
* @callb: response callback pointer; NULL if no callback needed.
|
|
*
|
|
* The DVA algorithm is broken down into two phases.
|
|
* The first phase uses a look up table to get a safe operating voltage
|
|
* for the requested frequency.
|
|
* This voltage is guaranteed to work over process and temperature.
|
|
*
|
|
* The second step of the second phase is to measure the temperature
|
|
* using the uPower Temperature Sensor module.
|
|
* This is accomplished by doing a binary search of the TSEL bit field
|
|
* in the Temperature Measurement Register (TMR).
|
|
* The search is repeated until the THIGH bit fields in the same register change value.
|
|
* There are 3 temperature sensors in 8ULP (APD, AVD, and RTD).
|
|
*
|
|
*
|
|
* The second phase is the fine adjust of the voltage.
|
|
* This stage is entered only when the new frequency requested
|
|
* by application was already set as well as the voltage for that frequency.
|
|
* The first step of the fine adjust is to find what is the current margins
|
|
* for the monitored critical paths, or, in other words,
|
|
* how many delay cells will be necessary to generate a setup-timing violation.
|
|
* The function informs uPower that the given domain frequency has changed or
|
|
* will change to the given value. uPower firmware will then adjust voltage and
|
|
* bias to cope with the new frequency (if decreasing) or prepare for it
|
|
* (if increasing). The function must be called after decreasing the frequency,
|
|
* and before increasing it. The actual increase in frequency must not occur
|
|
* before the service returns its response.
|
|
*
|
|
* So, for increase clock frequency case, user need to call this API twice,
|
|
* the first stage gross adjust and the second stage fine adjust.
|
|
*
|
|
* for reduce clock frequency case, user can only call this API once,
|
|
* full stage (combine gross stage and fine adjust)
|
|
*
|
|
* The request is executed if arguments are within range.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_PWRMGMT as the service group argument.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
int upwr_pwm_freq_setup(soc_domain_t domain, uint32_t rail, uint32_t stage,
|
|
uint32_t target_freq, upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_pwm_power_on()- Powers on (not off) one or more switches and ROM/RAMs.
|
|
* @swton: pointer to an array of words that tells which power switches to
|
|
* turn on. Each word in the array has 1 bit for each switch.
|
|
* A bit=1 means the respective switch must be turned on,
|
|
* bit = 0 means it will stay unchanged (on or off).
|
|
* The pointer may be set to NULL, in which case no switch will be changed,
|
|
* unless a memory that it feeds must be turned on.
|
|
* WARNING: swton must not point to the first shared memory address.
|
|
* @memon: pointer to an array of words that tells which memories to turn on.
|
|
* Each word in the array has 1 bit for each switch.
|
|
* A bit=1 means the respective memory must be turned on, both array and
|
|
* periphery logic;
|
|
* bit = 0 means it will stay unchanged (on or off).
|
|
* The pointer may be set to NULL, in which case no memory will be changed.
|
|
* WARNING: memon must not point to the first shared memory address.
|
|
* @callb: pointer to the callback called when configurations are applyed.
|
|
* NULL if no callback is required.
|
|
*
|
|
* The function requests uPower to turn on the PMC and memory array/peripheral
|
|
* switches that control their power, as specified above.
|
|
* The request is executed if arguments are within range, with no protections
|
|
* regarding the adequate memory power state related to overall system state.
|
|
*
|
|
* If a memory is requested to turn on, but the power switch that feeds that
|
|
* memory is not, the power switch will be turned on anyway, if the pwron
|
|
* array is not provided (that is, if pwron is NULL).
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_PWRMGMT as the service group argument.
|
|
*
|
|
* Callback or polling may return error if the service contends for a resource
|
|
* already being used by a power mode transition or an ongoing service in
|
|
* another domain.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok, -1 if service group is busy,
|
|
* -2 if a pointer conversion to physical address failed,
|
|
* -3 if called in an invalid API state.
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
int upwr_pwm_power_on(const uint32_t swton[], const uint32_t memon[],
|
|
upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_pwm_power_off()- Powers off (not on) one or more switches and ROM/RAMs.
|
|
* @swtoff: pointer to an array of words that tells which power switches to
|
|
* turn off. Each word in the array has 1 bit for each switch.
|
|
* A bit=1 means the respective switch must be turned off,
|
|
* bit = 0 means it will stay unchanged (on or off).
|
|
* The pointer may be set to NULL, in which case no switch will be changed.
|
|
* WARNING: swtoff must not point to the first shared memory address.
|
|
* @memoff: pointer to an array of words that tells which memories to turn off.
|
|
* Each word in the array has 1 bit for each switch.
|
|
* A bit=1 means the respective memory must be turned off, both array and
|
|
* periphery logic;
|
|
* bit = 0 means it will stay unchanged (on or off).
|
|
* The pointer may be set to NULL, in which case no memory will be changed,
|
|
* but notice it may be turned off if the switch that feeds it is powered off.
|
|
* WARNING: memoff must not point to the first shared memory address.
|
|
* @callb: pointer to the callback called when configurations are applyed.
|
|
* NULL if no callback is required.
|
|
*
|
|
* The function requests uPower to turn off the PMC and memory array/peripheral
|
|
* switches that control their power, as specified above.
|
|
* The request is executed if arguments are within range, with no protections
|
|
* regarding the adequate memory power state related to overall system state.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_PWRMGMT as the service group argument.
|
|
*
|
|
* Callback or polling may return error if the service contends for a resource
|
|
* already being used by a power mode transition or an ongoing service in
|
|
* another domain.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok, -1 if service group is busy,
|
|
* -2 if a pointer conversion to physical address failed,
|
|
* -3 if called in an invalid API state.
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
int upwr_pwm_power_off(const uint32_t swtoff[], const uint32_t memoff[],
|
|
upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_pwm_mem_retain()- Configures one or more memory power switches to
|
|
* retain its contents, having the power array on, while its peripheral logic
|
|
* is turned off.
|
|
* @mem: pointer to an array of words that tells which memories to put in a
|
|
* retention state. Each word in the array has 1 bit for each memory.
|
|
* A bit=1 means the respective memory must be put in retention state,
|
|
* bit = 0 means it will stay unchanged (retention, fully on or off).
|
|
* @callb: pointer to the callback called when configurations are applyed.
|
|
* NULL if no callback is required.
|
|
*
|
|
* The function requests uPower to turn off the memory peripheral and leave
|
|
* its array on, as specified above.
|
|
* The request is executed if arguments are within range.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_PWRMGMT as the service group argument.
|
|
*
|
|
* Callback or polling may return error if the service contends for a resource
|
|
* already being used by a power mode transition or an ongoing service in
|
|
* another domain.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok, -1 if service group is busy,
|
|
* -2 if a pointer conversion to physical address failed,
|
|
* -3 if called in an invalid API state.
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
int upwr_pwm_mem_retain(const uint32_t mem[], upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_pwm_chng_switch_mem() - Turns on/off power on one or more PMC switches
|
|
* and memories, including their array and peripheral logic.
|
|
* @swt: pointer to a list of PMC switches to be opened/closed.
|
|
* The list is structured as an array of struct upwr_switch_board_t
|
|
* (see upower_defs.h), each one containing a word for up to 32 switches,
|
|
* one per bit. A bit = 1 means switch closed, bit = 0 means switch open.
|
|
* struct upwr_switch_board_t also specifies a mask with 1 bit for each
|
|
* respective switch: mask bit = 1 means the open/close action is applied,
|
|
* mask bit = 0 means the switch stays unchanged.
|
|
* The pointer may be set to NULL, in which case no switch will be changed,
|
|
* unless a memory that it feeds must be turned on.
|
|
* WARNING: swt must not point to the first shared memory address.
|
|
* @mem: pointer to a list of switches to be turned on/off.
|
|
* The list is structured as an array of struct upwr_mem_switches_t
|
|
* (see upower_defs.h), each one containing 2 word for up to 32 switches,
|
|
* one per bit, one word for the RAM array power switch, other for the
|
|
* RAM peripheral logic power switch. A bit = 1 means switch closed,
|
|
* bit = 0 means switch open.
|
|
* struct upwr_mem_switches_t also specifies a mask with 1 bit for each
|
|
* respective switch: mask bit = 1 means the open/close action is applied,
|
|
* mask bit = 0 means the switch stays unchanged.
|
|
* The pointer may be set to NULL, in which case no memory switch will be
|
|
* changed, but notice it may be turned off if the switch that feeds it is
|
|
* powered off.
|
|
* WARNING: mem must not point to the first shared memory address.
|
|
* @callb: pointer to the callback called when the configurations are applied.
|
|
* NULL if no callback is required.
|
|
*
|
|
* The function requests uPower to change the PMC switches and/or memory power
|
|
* as specified above.
|
|
* The request is executed if arguments are within range, with no protections
|
|
* regarding the adequate switch combinations and overall system state.
|
|
*
|
|
* If a memory is requested to turn on, but the power switch that feeds that
|
|
* memory is not, the power switch will be turned on anyway, if the swt
|
|
* array is not provided (that is, if swt is NULL).
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_PWRMGMT as the service group argument.
|
|
*
|
|
* Callback or polling may return error if the service contends for a resource
|
|
* already being used by a power mode transition or an ongoing service in
|
|
* another domain.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok, -1 if service group is busy.
|
|
* -2 if a pointer conversion to physical address failed,
|
|
* -3 if called in an invalid API state.
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
int upwr_pwm_chng_switch_mem(const struct upwr_switch_board_t swt[],
|
|
const struct upwr_mem_switches_t mem[],
|
|
upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_pwm_pmode_config() - Configures a given power mode in a given domain.
|
|
* @domain: identifier of the domain to which the power mode belongs.
|
|
* Defined by SoC-dependent type soc_domain_t found in upower_soc_defs.h.
|
|
* @pmode: SoC-dependent power mode identifier defined by type abs_pwr_mode_t
|
|
* found in upower_soc_defs.h.
|
|
* @config: pointer to an SoC-dependent struct defining the power mode
|
|
* configuration, found in upower_soc_defs.h.
|
|
* @callb: pointer to the callback called when configurations are applied.
|
|
* NULL if no callback is required.
|
|
*
|
|
* The function requests uPower to change the power mode configuration as
|
|
* specified above. The request is executed if arguments are within range,
|
|
* and complies with SoC-dependent restrictions on value combinations.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_PWRMGMT as the service group argument.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok, -1 if service group is busy,
|
|
* -2 if the pointer conversion to physical address failed,
|
|
* -3 if called in an invalid API state.
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
int upwr_pwm_pmode_config(soc_domain_t domain, abs_pwr_mode_t pmode,
|
|
const void *config, upwr_callb callb);
|
|
|
|
|
|
|
|
/**
|
|
* upwr_pwm_reg_config() - Configures the uPower internal regulators.
|
|
* @config: pointer to the struct defining the regulator configuration;
|
|
* the struct upwr_reg_config_t is defined in the file upower_defs.h.
|
|
* @callb: pointer to the callback called when configurations are applied.
|
|
* NULL if no callback is required.
|
|
*
|
|
* The function requests uPower to change/define the configurations of the
|
|
* internal regulators.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_PWRMGMT as the service group argument.
|
|
*
|
|
* The service may fail with error UPWR_RESP_RESOURCE if a power mode transition
|
|
* or the same service (called from another domain) is executing simultaneously.
|
|
* This error should be interpreted as a "try later" response, as the service
|
|
* will succeed once those concurrent executions are done, and no other is
|
|
* started.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok, -1 if service group is busy,
|
|
* -2 if the pointer conversion to physical address failed,
|
|
* -3 if called in an invalid API state.
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
int upwr_pwm_reg_config(const struct upwr_reg_config_t *config,
|
|
upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_pwm_chng_dom_bias() - Changes the domain bias.
|
|
* @bias: pointer to a domain bias configuration struct (see upower_soc_defs.h).
|
|
* @callb: pointer to the callback called when configurations are applied.
|
|
* NULL if no callback is required.
|
|
*
|
|
* The function requests uPower to change the domain bias configuration as
|
|
* specified above. The request is executed if arguments are within range,
|
|
* with no protections regarding the adequate value combinations and
|
|
* overall system state.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_PWRMGMT as the service group argument.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok, -1 if service group is busy,
|
|
* -3 if called in an invalid API state.
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
|
|
int upwr_pwm_chng_dom_bias(const struct upwr_dom_bias_cfg_t *bias,
|
|
upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_pwm_chng_mem_bias()- Changes a ROM/RAM power bias.
|
|
* @domain: identifier of the domain upon which the bias is applied.
|
|
* Defined by SoC-dependent type soc_domain_t found in upower_soc_defs.h.
|
|
* @bias: pointer to a memory bias configuration struct (see upower_soc_defs.h).
|
|
* @callb: pointer to the callback called when configurations are applied.
|
|
* NULL if no callback is required.
|
|
*
|
|
* The function requests uPower to change the memory bias configuration as
|
|
* specified above. The request is executed if arguments are within range,
|
|
* with no protections regarding the adequate value combinations and
|
|
* overall system state.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_PWRMGMT as the service group argument.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok, -1 if service group is busy,
|
|
* -3 if called in an invalid API state.
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
|
|
int upwr_pwm_chng_mem_bias(soc_domain_t domain,
|
|
const struct upwr_mem_bias_cfg_t *bias,
|
|
upwr_callb callb);
|
|
|
|
/**---------------------------------------------------------------
|
|
* VOLTAGE MANAGEMENT SERVICE GROUP
|
|
*/
|
|
|
|
/**
|
|
* upwr_vtm_pmic_cold_reset() -request cold reset the pmic.
|
|
* pmic will power cycle all the regulators
|
|
* @callb: response callback pointer; NULL if no callback needed.
|
|
*
|
|
* The function requests uPower to cold reset the pmic.
|
|
* The request is executed if arguments are within range, with no protections
|
|
* regarding the adequate voltage value for the given domain process,
|
|
* temperature and frequency.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_VOLTM as the service group argument.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
int upwr_vtm_pmic_cold_reset(upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_vtm_set_pmic_mode() -request uPower set pmic mode
|
|
* @pmic_mode: the target mode need to be set
|
|
* @callb: response callback pointer; NULL if no callback needed.
|
|
*
|
|
* The function requests uPower to set pmic mode
|
|
* The request is executed if arguments are within range, with no protections
|
|
* regarding the adequate voltage value for the given domain process,
|
|
* temperature and frequency.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_VOLTM as the service group argument.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
int upwr_vtm_set_pmic_mode(uint32_t pmic_mode, upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_vtm_chng_pmic_voltage() - Changes the voltage of a given rail.
|
|
* @rail: pmic rail id.
|
|
* @volt: the target voltage of the given rail, accurate to uV
|
|
* If pass volt value 0, means that power off this rail.
|
|
* @callb: response callback pointer; NULL if no callback needed.
|
|
*
|
|
* The function requests uPower to change the voltage of the given rail.
|
|
* The request is executed if arguments are within range, with no protections
|
|
* regarding the adequate voltage value for the given domain process,
|
|
* temperature and frequency.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_VOLTM as the service group argument.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
int upwr_vtm_chng_pmic_voltage(uint32_t rail, uint32_t volt, upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_vtm_get_pmic_voltage() - Get the voltage of a given ral.
|
|
* @rail: pmic rail id.
|
|
* @callb: response callback pointer; NULL if no callback needed.
|
|
* (polling used instead)
|
|
*
|
|
* The function requests uPower to get the voltage of the given rail.
|
|
* The request is executed if arguments are within range, with no protections
|
|
* regarding the adequate voltage value for the given domain process,
|
|
* temperature and frequency.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_VOLTM as the service group argument.
|
|
*
|
|
* The voltage data read from uPower via
|
|
* the callback argument ret, or written to the variable pointed by retptr,
|
|
* if polling is used (calls upwr_req_status or upwr_poll_req_status).
|
|
* ret (or *retptr) also returns the data written on writes.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
int upwr_vtm_get_pmic_voltage(uint32_t rail, upwr_callb callb);
|
|
|
|
|
|
/**
|
|
* upwr_vtm_power_measure() - request uPower to measure power consumption
|
|
* @ssel: This field determines which power switches will have their currents
|
|
* sampled to be accounted for a
|
|
* current/power measurement. Support 0~7
|
|
|
|
* SSEL bit # Power Switch
|
|
* 0 M33 core complex/platform/peripherals
|
|
* 1 Fusion Core and Peripherals
|
|
* 2 A35[0] core complex
|
|
* 3 A35[1] core complex
|
|
* 4 3DGPU
|
|
* 5 HiFi4
|
|
* 6 DDR Controller (PHY and PLL NOT included)
|
|
* 7 PXP, EPDC
|
|
*
|
|
* @callb: response callback pointer; NULL if no callback needed.
|
|
* (polling used instead)
|
|
*
|
|
* The function requests uPower to measure power consumption
|
|
* The request is executed if arguments are within range, with no protections
|
|
* regarding the adequate voltage value for the given domain process,
|
|
* temperature and frequency.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_VOLTM as the service group argument.
|
|
*
|
|
* The power consumption data read from uPower via
|
|
* the callback argument ret, or written to the variable pointed by retptr,
|
|
* if polling is used (calls upwr_req_status or upwr_poll_req_status).
|
|
* ret (or *retptr) also returns the data written on writes.
|
|
* upower fw needs support cocurrent request from M33 and A35.
|
|
*
|
|
* Accurate to uA
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
int upwr_vtm_power_measure(uint32_t ssel, upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_vtm_vmeter_measure() - request uPower to measure voltage
|
|
* @vdetsel: Voltage Detector Selector, support 0~3
|
|
* 00b - RTD sense point
|
|
* 01b - LDO output
|
|
* 10b - APD domain sense point
|
|
* 11b - AVD domain sense point
|
|
* Refer to upower_defs.h
|
|
* @callb: response callback pointer; NULL if no callback needed.
|
|
* (polling used instead)
|
|
*
|
|
* The function requests uPower to use vmeter to measure voltage
|
|
* The request is executed if arguments are within range, with no protections
|
|
* regarding the adequate voltage value for the given domain process,
|
|
* temperature and frequency.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_VOLTM as the service group argument.
|
|
*
|
|
* The voltage data read from uPower via
|
|
* the callback argument ret, or written to the variable pointed by retptr,
|
|
* if polling is used (calls upwr_req_status or upwr_poll_req_status).
|
|
* ret (or *retptr) also returns the data written on writes.
|
|
* upower fw needs support cocurrent request from M33 and A35.
|
|
*
|
|
* Refer to RM COREREGVL (Core Regulator Voltage Level)
|
|
* uPower return VDETLVL to user, user can calculate the real voltage:
|
|
*
|
|
* 0b000000(0x00) - 0.595833V
|
|
* 0b100110(0x26) - 1.007498V
|
|
* <value> - 0.595833V + <value>x10.8333mV
|
|
* 0b110010(0x32) - 1.138V
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
int upwr_vtm_vmeter_measure(uint32_t vdetsel, upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_vtm_pmic_config() - Configures the SoC PMIC (Power Management IC).
|
|
* @config: pointer to a PMIC-dependent struct defining the PMIC configuration.
|
|
* @size: size of the struct pointed by config, in bytes.
|
|
* @callb: pointer to the callback called when configurations are applied.
|
|
* NULL if no callback is required.
|
|
*
|
|
* The function requests uPower to change/define the PMIC configuration.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_PWRMGMT as the service group argument.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok, -1 if service group is busy,
|
|
* -2 if the pointer conversion to physical address failed,
|
|
* -3 if called in an invalid API state.
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
int upwr_vtm_pmic_config(const void *config, uint32_t size, upwr_callb callb);
|
|
|
|
/**---------------------------------------------------------------
|
|
* TEMPERATURE MANAGEMENT SERVICE GROUP
|
|
*/
|
|
|
|
/**
|
|
* upwr_tpm_get_temperature() - request uPower to get temperature of one temperature sensor
|
|
* @sensor_id: temperature sensor ID, support 0~2
|
|
* @callb: response callback pointer; NULL if no callback needed.
|
|
* (polling used instead)
|
|
*
|
|
* The function requests uPower to measure temperature
|
|
* The request is executed if arguments are within range, with no protections
|
|
* regarding the adequate voltage value for the given domain process,
|
|
* temperature and frequency.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_TEMPM as the service group argument.
|
|
*
|
|
* The temperature data read from uPower via
|
|
* the callback argument ret, or written to the variable pointed by retptr,
|
|
* if polling is used (calls upwr_req_status or upwr_poll_req_status).
|
|
* ret (or *retptr) also returns the data written on writes.
|
|
*
|
|
* uPower return TSEL to the caller (M33 or A35), caller calculate the real temperature
|
|
* Tsh = 0.000002673049*TSEL[7:0]^3 + 0.0003734262*TSEL[7:0]^2 +
|
|
0.4487042*TSEL[7:0] - 46.98694
|
|
*
|
|
* upower fw needs support cocurrent request from M33 and A35.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
int upwr_tpm_get_temperature(uint32_t sensor_id, upwr_callb callb);
|
|
|
|
/**---------------------------------------------------------------
|
|
* DELAY MANAGEMENT SERVICE GROUP
|
|
*/
|
|
|
|
/**
|
|
* upwr_dlm_get_delay_margin() - request uPower to get delay margin
|
|
* @path: The critical path
|
|
* @index: Use whitch delay meter
|
|
* @callb: response callback pointer; NULL if no callback needed.
|
|
* (polling used instead)
|
|
*
|
|
* The function requests uPower to get delay margin
|
|
* The request is executed if arguments are within range, with no protections
|
|
* regarding the adequate voltage value for the given domain process,
|
|
* temperature and frequency.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_DELAYM as the service group argument.
|
|
*
|
|
* The delay margin data read from uPower via
|
|
* the callback argument ret, or written to the variable pointed by retptr,
|
|
* if polling is used (calls upwr_req_status or upwr_poll_req_status).
|
|
* ret (or *retptr) also returns the data written on writes.
|
|
* upower fw needs support cocurrent request from M33 and A35.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
int upwr_dlm_get_delay_margin(uint32_t path, uint32_t index, upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_dlm_set_delay_margin() - request uPower to set delay margin
|
|
* @path: The critical path
|
|
* @index: Use whitch delay meter
|
|
* @delay_margin: the value of delay margin
|
|
* @callb: response callback pointer; NULL if no callback needed.
|
|
* (polling used instead)
|
|
*
|
|
* The function requests uPower to set delay margin
|
|
* The request is executed if arguments are within range, with no protections
|
|
* regarding the adequate voltage value for the given domain process,
|
|
* temperature and frequency.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_DELAYM as the service group argument.
|
|
*
|
|
* The result of the corresponding critical path, failed or not read from uPower via
|
|
* the callback argument ret, or written to the variable pointed by retptr,
|
|
* if polling is used (calls upwr_req_status or upwr_poll_req_status).
|
|
* ret (or *retptr) also returns the data written on writes.
|
|
* upower fw needs support cocurrent request from M33 and A35.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
int upwr_dlm_set_delay_margin(uint32_t path, uint32_t index, uint32_t delay_margin, upwr_callb callb);
|
|
|
|
/**
|
|
* upwr_dlm_process_monitor() - request uPower to do process monitor
|
|
* @chain_sel: Chain Cell Type Selection
|
|
* Select the chain to be used for the clock signal generation.
|
|
* Support two types chain cell, 0~1
|
|
0b - P4 type delay cells selected
|
|
1b - P16 type delay cells selected
|
|
* @callb: response callback pointer; NULL if no callback needed.
|
|
* (polling used instead)
|
|
*
|
|
* The function requests uPower to do process monitor
|
|
* The request is executed if arguments are within range, with no protections
|
|
* regarding the adequate voltage value for the given domain process,
|
|
* temperature and frequency.
|
|
*
|
|
* A callback can be optionally registered, and will be called upon the arrival
|
|
* of the request response from the uPower firmware, telling if it succeeded
|
|
* or not.
|
|
*
|
|
* A callback may not be registered (NULL pointer), in which case polling has
|
|
* to be used to check the response, by calling upwr_req_status or
|
|
* upwr_poll_req_status, using UPWR_SG_DELAYM as the service group argument.
|
|
*
|
|
* The result of process monitor, failed or not read from uPower via
|
|
* the callback argument ret, or written to the variable pointed by retptr,
|
|
* if polling is used (calls upwr_req_status or upwr_poll_req_status).
|
|
* ret (or *retptr) also returns the data written on writes.
|
|
* upower fw needs support cocurrent request from M33 and A35.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
* Note that this is not the error response from the request itself:
|
|
* it only tells if the request was successfully sent to the uPower.
|
|
*/
|
|
int upwr_dlm_process_monitor(uint32_t chain_sel, upwr_callb callb);
|
|
|
|
/**---------------------------------------------------------------
|
|
* DIAGNOSE SERVICE GROUP
|
|
*/
|
|
|
|
/**
|
|
* upwr_dgn_mode() - Sets the diagnostic mode.
|
|
* @mode: diagnostic mode, which can be:
|
|
* - UPWR_DGN_NONE: no diagnostic recorded
|
|
* - UPWR_DGN_TRACE: warnings, errors, service, internal activity recorded
|
|
* - UPWR_DGN_SRVREQ: warnings, errors, service activity recorded
|
|
* - UPWR_DGN_WARN: warnings and errors recorded
|
|
* - UPWR_DGN_ALL: trace, service, warnings, errors, task state recorded
|
|
* - UPWR_DGN_ERROR: only errors recorded
|
|
* - UPWR_DGN_ALL2ERR: record all until an error occurs,
|
|
* freeze recording on error
|
|
* - UPWR_DGN_ALL2HLT: record all until an error occurs,
|
|
* executes an ebreak on error, which halts the core if enabled through
|
|
* the debug interface
|
|
* @callb: pointer to the callback called when mode is changed.
|
|
* NULL if no callback is required.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok,
|
|
* -1 if service group is busy,
|
|
* -3 if called in an invalid API state
|
|
*/
|
|
int upwr_dgn_mode(upwr_dgn_mode_t mode, const upwr_callb callb);
|
|
|
|
/**---------------------------------------------------------------
|
|
* AUXILIARY CALLS
|
|
*/
|
|
|
|
/**
|
|
* upwr_rom_version() - informs the ROM firwmware version.
|
|
* @vmajor: pointer to the variable to get the firmware major version number.
|
|
* @vminor: pointer to the variable to get the firmware minor version number.
|
|
* @vfixes: pointer to the variable to get the firmware fixes number.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: SoC id.
|
|
*/
|
|
uint32_t upwr_rom_version(uint32_t *vmajor, uint32_t *vminor, uint32_t *vfixes);
|
|
|
|
/**
|
|
* upwr_ram_version() - informs the RAM firwmware version.
|
|
* @vminor: pointer to the variable to get the firmware minor version number.
|
|
* @vfixes: pointer to the variable to get the firmware fixes number.
|
|
*
|
|
* The 3 values returned are 0 if no RAM firmwmare was loaded and initialized.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: firmware major version number.
|
|
*/
|
|
uint32_t upwr_ram_version(uint32_t *vminor, uint32_t *vfixes);
|
|
|
|
/**
|
|
* upwr_req_status() - tells the status of the service group request, and
|
|
* returns a request return value, if any.
|
|
* @sg: service group of the request
|
|
* @sgfptr: pointer to the variable that will hold the function id of
|
|
* the last request completed; can be NULL, in which case it is not used.
|
|
* @errptr: pointer to the variable that will hold the error code;
|
|
* can be NULL, in which case it is not used.
|
|
* @retptr: pointer to the variable that will hold the value returned
|
|
* by the last request completed (invalid if the last request completed didn't
|
|
* return any value); can be NULL, in which case it is not used.
|
|
* Note that a request may return a value even if service error is returned
|
|
* (*errptr != UPWR_RESP_OK): that is dependent on the specific service.
|
|
*
|
|
* This call can be used in a poll loop of a service request completion in case
|
|
* a callback was not registered.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: service request status: succeeded, failed, or ongoing (busy)
|
|
*/
|
|
|
|
/* service request status */
|
|
typedef enum {
|
|
UPWR_REQ_OK, /* request succeeded */
|
|
UPWR_REQ_ERR, /* request failed */
|
|
UPWR_REQ_BUSY /* request execution ongoing */
|
|
} upwr_req_status_t;
|
|
|
|
upwr_req_status_t upwr_req_status(upwr_sg_t sg,
|
|
uint32_t *sgfptr,
|
|
upwr_resp_t *errptr,
|
|
int *retptr);
|
|
|
|
/**
|
|
* upwr_poll_req_status() - polls the status of the service group request, and
|
|
* returns a request return value, if any.
|
|
* @sg: service group of the request
|
|
* @sgfptr: pointer to the variable that will hold the function id of
|
|
* the last request completed; can be NULL, in which case it is not used.
|
|
* @errptr: pointer to the variable that will hold the error code;
|
|
* can be NULL, in which case it is not used.
|
|
* @retptr: pointer to the variable that will hold the value returned
|
|
* by the last request completed (invalid if the last request completed didn't
|
|
* return any value); can be NULL, in which case it is not used.
|
|
* Note that a request may return a value even if service error is returned
|
|
* (*errptr != UPWR_RESP_OK): that is dependent on the specific service.
|
|
* @attempts: maximum number of polling attempts; if attempts > 0 and is
|
|
* reached with no service response received, upwr_poll_req_status returns
|
|
* UPWR_REQ_BUSY and variables pointed by sgfptr, retptr and errptr are not
|
|
* updated; if attempts = 0, upwr_poll_req_status waits "forever".
|
|
*
|
|
* This call can be used to poll a service request completion in case a
|
|
* callback was not registered.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: service request status: succeeded, failed, or ongoing (busy)
|
|
*/
|
|
upwr_req_status_t upwr_poll_req_status(upwr_sg_t sg,
|
|
uint32_t *sgfptr,
|
|
upwr_resp_t *errptr,
|
|
int *retptr,
|
|
uint32_t attempts);
|
|
|
|
/**
|
|
* upwr_alarm_code() - returns the alarm code of the last alarm occurrence.
|
|
*
|
|
* The value returned is not meaningful if no alarm was issued by uPower.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: alarm code, as defined by the type upwr_alarm_t in upwr_soc_defines.h
|
|
*/
|
|
upwr_alarm_t upwr_alarm_code(void);
|
|
|
|
/**---------------------------------------------------------------
|
|
* TRANSMIT/RECEIVE PRIMITIVES
|
|
* ---------------------------------------------------------------
|
|
*/
|
|
|
|
typedef void (*UPWR_TX_CALLB_FUNC_T)(void);
|
|
typedef void (*UPWR_RX_CALLB_FUNC_T)(void);
|
|
|
|
/**
|
|
* upwr_tx() - queues a message for transmission.
|
|
* @msg : pointer to the message sent.
|
|
* @size: message size in 32-bit words
|
|
* @callback: pointer to a function to be called when transmission done;
|
|
* can be NULL, in which case no callback is done.
|
|
*
|
|
* This is an auxiliary function used by the rest of the API calls.
|
|
* It is normally not called by the driver code, unless maybe for test purposes.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: number of vacant positions left in the transmission queue, or
|
|
* -1 if the queue was already full when upwr_tx was called, or
|
|
* -2 if any argument is invalid (like size off-range)
|
|
*/
|
|
int upwr_tx(const uint32_t *msg, unsigned int size,
|
|
UPWR_TX_CALLB_FUNC_T callback);
|
|
|
|
/**
|
|
* upwr_rx() - unqueues a received message from the reception queue.
|
|
* @msg: pointer to the message destination buffer.
|
|
* @size: pointer to variable to hold message size in 32-bit words.
|
|
*
|
|
* This is an auxiliary function used by the rest of the API calls.
|
|
* It is normally not called by the driver code, unless maybe for test purposes.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: number of messages remaining in the reception queue, or
|
|
* -1 if the queue was already empty when upwr_rx was called, or
|
|
* -2 if any argument is invalid (like mu off-range)
|
|
*/
|
|
int upwr_rx(char *msg, unsigned int *size);
|
|
|
|
/**
|
|
* upwr_rx_callback() - sets up a callback for a message receiving event.
|
|
* @callback: pointer to a function to be called when a message arrives;
|
|
* can be NULL, in which case no callback is done.
|
|
*
|
|
* This is an auxiliary function used by the rest of the API calls.
|
|
* It is normally not called by the driver code, unless maybe for test purposes.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: 0 if ok; -2 if any argument is invalid (mu off-range).
|
|
*/
|
|
int upwr_rx_callback(UPWR_RX_CALLB_FUNC_T callback);
|
|
|
|
/**
|
|
* msg_copy() - copies a message.
|
|
* @dest: pointer to the destination message.
|
|
* @src : pointer to the source message.
|
|
* @size: message size in words.
|
|
*
|
|
* This is an auxiliary function used by the rest of the API calls.
|
|
* It is normally not called by the driver code, unless maybe for test purposes.
|
|
*
|
|
* Context: no sleep, no locks taken/released.
|
|
* Return: none (void)
|
|
*/
|
|
void msg_copy(char *dest, char *src, unsigned int size);
|
|
|
|
#endif /* UPWR_API_H */
|