1*91f16700Schasinglulu /* 2*91f16700Schasinglulu * Copyright (c) 2017-2019, ARM Limited and Contributors. All rights reserved. 3*91f16700Schasinglulu * 4*91f16700Schasinglulu * SPDX-License-Identifier: BSD-3-Clause 5*91f16700Schasinglulu */ 6*91f16700Schasinglulu 7*91f16700Schasinglulu #include <assert.h> 8*91f16700Schasinglulu 9*91f16700Schasinglulu #include <arch_helpers.h> 10*91f16700Schasinglulu #include <common/debug.h> 11*91f16700Schasinglulu #include <drivers/arm/css/scmi.h> 12*91f16700Schasinglulu 13*91f16700Schasinglulu #include "scmi_private.h" 14*91f16700Schasinglulu 15*91f16700Schasinglulu /* 16*91f16700Schasinglulu * API to set the SCMI power domain power state. 17*91f16700Schasinglulu */ 18*91f16700Schasinglulu int scmi_pwr_state_set(void *p, uint32_t domain_id, 19*91f16700Schasinglulu uint32_t scmi_pwr_state) 20*91f16700Schasinglulu { 21*91f16700Schasinglulu mailbox_mem_t *mbx_mem; 22*91f16700Schasinglulu unsigned int token = 0; 23*91f16700Schasinglulu int ret; 24*91f16700Schasinglulu 25*91f16700Schasinglulu /* 26*91f16700Schasinglulu * Only asynchronous mode of `set power state` command is allowed on 27*91f16700Schasinglulu * application processors. 28*91f16700Schasinglulu */ 29*91f16700Schasinglulu uint32_t pwr_state_set_msg_flag = SCMI_PWR_STATE_SET_FLAG_ASYNC; 30*91f16700Schasinglulu scmi_channel_t *ch = (scmi_channel_t *)p; 31*91f16700Schasinglulu 32*91f16700Schasinglulu validate_scmi_channel(ch); 33*91f16700Schasinglulu 34*91f16700Schasinglulu scmi_get_channel(ch); 35*91f16700Schasinglulu 36*91f16700Schasinglulu mbx_mem = (mailbox_mem_t *)(ch->info->scmi_mbx_mem); 37*91f16700Schasinglulu mbx_mem->msg_header = SCMI_MSG_CREATE(SCMI_PWR_DMN_PROTO_ID, 38*91f16700Schasinglulu SCMI_PWR_STATE_SET_MSG, token); 39*91f16700Schasinglulu mbx_mem->len = SCMI_PWR_STATE_SET_MSG_LEN; 40*91f16700Schasinglulu mbx_mem->flags = SCMI_FLAG_RESP_POLL; 41*91f16700Schasinglulu SCMI_PAYLOAD_ARG3(mbx_mem->payload, pwr_state_set_msg_flag, 42*91f16700Schasinglulu domain_id, scmi_pwr_state); 43*91f16700Schasinglulu 44*91f16700Schasinglulu scmi_send_sync_command(ch); 45*91f16700Schasinglulu 46*91f16700Schasinglulu /* Get the return values */ 47*91f16700Schasinglulu SCMI_PAYLOAD_RET_VAL1(mbx_mem->payload, ret); 48*91f16700Schasinglulu assert(mbx_mem->len == SCMI_PWR_STATE_SET_RESP_LEN); 49*91f16700Schasinglulu assert(token == SCMI_MSG_GET_TOKEN(mbx_mem->msg_header)); 50*91f16700Schasinglulu 51*91f16700Schasinglulu scmi_put_channel(ch); 52*91f16700Schasinglulu 53*91f16700Schasinglulu return ret; 54*91f16700Schasinglulu } 55*91f16700Schasinglulu 56*91f16700Schasinglulu /* 57*91f16700Schasinglulu * API to get the SCMI power domain power state. 58*91f16700Schasinglulu */ 59*91f16700Schasinglulu int scmi_pwr_state_get(void *p, uint32_t domain_id, 60*91f16700Schasinglulu uint32_t *scmi_pwr_state) 61*91f16700Schasinglulu { 62*91f16700Schasinglulu mailbox_mem_t *mbx_mem; 63*91f16700Schasinglulu unsigned int token = 0; 64*91f16700Schasinglulu int ret; 65*91f16700Schasinglulu scmi_channel_t *ch = (scmi_channel_t *)p; 66*91f16700Schasinglulu 67*91f16700Schasinglulu validate_scmi_channel(ch); 68*91f16700Schasinglulu 69*91f16700Schasinglulu scmi_get_channel(ch); 70*91f16700Schasinglulu 71*91f16700Schasinglulu mbx_mem = (mailbox_mem_t *)(ch->info->scmi_mbx_mem); 72*91f16700Schasinglulu mbx_mem->msg_header = SCMI_MSG_CREATE(SCMI_PWR_DMN_PROTO_ID, 73*91f16700Schasinglulu SCMI_PWR_STATE_GET_MSG, token); 74*91f16700Schasinglulu mbx_mem->len = SCMI_PWR_STATE_GET_MSG_LEN; 75*91f16700Schasinglulu mbx_mem->flags = SCMI_FLAG_RESP_POLL; 76*91f16700Schasinglulu SCMI_PAYLOAD_ARG1(mbx_mem->payload, domain_id); 77*91f16700Schasinglulu 78*91f16700Schasinglulu scmi_send_sync_command(ch); 79*91f16700Schasinglulu 80*91f16700Schasinglulu /* Get the return values */ 81*91f16700Schasinglulu SCMI_PAYLOAD_RET_VAL2(mbx_mem->payload, ret, *scmi_pwr_state); 82*91f16700Schasinglulu assert(mbx_mem->len == SCMI_PWR_STATE_GET_RESP_LEN); 83*91f16700Schasinglulu assert(token == SCMI_MSG_GET_TOKEN(mbx_mem->msg_header)); 84*91f16700Schasinglulu 85*91f16700Schasinglulu scmi_put_channel(ch); 86*91f16700Schasinglulu 87*91f16700Schasinglulu return ret; 88*91f16700Schasinglulu } 89