xref: /dpdk/drivers/bus/fslmc/mc/dpmng.c (revision 131a75b6e4df60586103d71defb85dcf9f77fb17)
1*131a75b6SHemant Agrawal /* SPDX-License-Identifier: (BSD-3-Clause OR GPL-2.0)
2e24b05bfSHemant Agrawal  *
3e24b05bfSHemant Agrawal  * Copyright 2013-2015 Freescale Semiconductor Inc.
4*131a75b6SHemant Agrawal  * Copyright 2017 NXP
5e24b05bfSHemant Agrawal  *
6e24b05bfSHemant Agrawal  */
7e24b05bfSHemant Agrawal #include <fsl_mc_sys.h>
8e24b05bfSHemant Agrawal #include <fsl_mc_cmd.h>
9e24b05bfSHemant Agrawal #include <fsl_dpmng.h>
10e24b05bfSHemant Agrawal #include <fsl_dpmng_cmd.h>
11e24b05bfSHemant Agrawal 
1216bbc98aSShreyansh Jain /**
1316bbc98aSShreyansh Jain  * mc_get_version() - Retrieves the Management Complex firmware
1416bbc98aSShreyansh Jain  *			version information
1516bbc98aSShreyansh Jain  * @mc_io:		Pointer to opaque I/O object
1616bbc98aSShreyansh Jain  * @cmd_flags:		Command flags; one or more of 'MC_CMD_FLAG_'
1716bbc98aSShreyansh Jain  * @mc_ver_info:	Returned version information structure
1816bbc98aSShreyansh Jain  *
1916bbc98aSShreyansh Jain  * Return:	'0' on Success; Error code otherwise.
2016bbc98aSShreyansh Jain  */
mc_get_version(struct fsl_mc_io * mc_io,uint32_t cmd_flags,struct mc_version * mc_ver_info)21e24b05bfSHemant Agrawal int mc_get_version(struct fsl_mc_io *mc_io,
22e24b05bfSHemant Agrawal 		   uint32_t cmd_flags,
23e24b05bfSHemant Agrawal 		   struct mc_version *mc_ver_info)
24e24b05bfSHemant Agrawal {
25e24b05bfSHemant Agrawal 	struct mc_command cmd = { 0 };
2616bbc98aSShreyansh Jain 	struct dpmng_rsp_get_version *rsp_params;
27e24b05bfSHemant Agrawal 	int err;
28e24b05bfSHemant Agrawal 
29e24b05bfSHemant Agrawal 	/* prepare command */
30e24b05bfSHemant Agrawal 	cmd.header = mc_encode_cmd_header(DPMNG_CMDID_GET_VERSION,
31e24b05bfSHemant Agrawal 					  cmd_flags,
32e24b05bfSHemant Agrawal 					  0);
33e24b05bfSHemant Agrawal 
34e24b05bfSHemant Agrawal 	/* send command to mc*/
35e24b05bfSHemant Agrawal 	err = mc_send_command(mc_io, &cmd);
36e24b05bfSHemant Agrawal 	if (err)
37e24b05bfSHemant Agrawal 		return err;
38e24b05bfSHemant Agrawal 
39e24b05bfSHemant Agrawal 	/* retrieve response parameters */
4016bbc98aSShreyansh Jain 	rsp_params = (struct dpmng_rsp_get_version *)cmd.params;
4116bbc98aSShreyansh Jain 	mc_ver_info->revision = le32_to_cpu(rsp_params->revision);
4216bbc98aSShreyansh Jain 	mc_ver_info->major = le32_to_cpu(rsp_params->version_major);
4316bbc98aSShreyansh Jain 	mc_ver_info->minor = le32_to_cpu(rsp_params->version_minor);
44e24b05bfSHemant Agrawal 
45e24b05bfSHemant Agrawal 	return 0;
46e24b05bfSHemant Agrawal }
47e24b05bfSHemant Agrawal 
4816bbc98aSShreyansh Jain /**
4916bbc98aSShreyansh Jain  * mc_get_soc_version() - Retrieves the Management Complex firmware
5016bbc98aSShreyansh Jain  *                     version information
5116bbc98aSShreyansh Jain  * @mc_io		Pointer to opaque I/O object
5216bbc98aSShreyansh Jain  * @cmd_flags:		Command flags; one or more of 'MC_CMD_FLAG_'
5316bbc98aSShreyansh Jain  * @mc_platform_info:	Returned version information structure. The structure
5416bbc98aSShreyansh Jain  *			contains the values of SVR and PVR registers.
5516bbc98aSShreyansh Jain  *			Please consult platform specific reference manual
5616bbc98aSShreyansh Jain  *			for detailed information.
5716bbc98aSShreyansh Jain  *
5816bbc98aSShreyansh Jain  * Return:     '0' on Success; Error code otherwise.
5916bbc98aSShreyansh Jain  */
mc_get_soc_version(struct fsl_mc_io * mc_io,uint32_t cmd_flags,struct mc_soc_version * mc_platform_info)60e24b05bfSHemant Agrawal int mc_get_soc_version(struct fsl_mc_io *mc_io,
61e24b05bfSHemant Agrawal 		       uint32_t cmd_flags,
62e24b05bfSHemant Agrawal 		       struct mc_soc_version *mc_platform_info)
63e24b05bfSHemant Agrawal {
6416bbc98aSShreyansh Jain 	struct dpmng_rsp_get_soc_version *rsp_params;
65e24b05bfSHemant Agrawal 	struct mc_command cmd = { 0 };
66e24b05bfSHemant Agrawal 	int err;
67e24b05bfSHemant Agrawal 
68e24b05bfSHemant Agrawal 	/* prepare command */
69e24b05bfSHemant Agrawal 	cmd.header = mc_encode_cmd_header(DPMNG_CMDID_GET_SOC_VERSION,
70e24b05bfSHemant Agrawal 					  cmd_flags,
71e24b05bfSHemant Agrawal 					  0);
72e24b05bfSHemant Agrawal 
73e24b05bfSHemant Agrawal 	/* send command to mc*/
74e24b05bfSHemant Agrawal 	err = mc_send_command(mc_io, &cmd);
75e24b05bfSHemant Agrawal 	if (err)
76e24b05bfSHemant Agrawal 		return err;
77e24b05bfSHemant Agrawal 
78e24b05bfSHemant Agrawal 	/* retrieve response parameters */
7916bbc98aSShreyansh Jain 	rsp_params = (struct dpmng_rsp_get_soc_version *)cmd.params;
8016bbc98aSShreyansh Jain 	mc_platform_info->svr = le32_to_cpu(rsp_params->svr);
8116bbc98aSShreyansh Jain 	mc_platform_info->pvr = le32_to_cpu(rsp_params->pvr);
82e24b05bfSHemant Agrawal 
83e24b05bfSHemant Agrawal 	return 0;
84e24b05bfSHemant Agrawal }
85