[PATCH v5 1/3] firmware: xilinx: Add support for runtime features

Michal Simek michal.simek at xilinx.com
Wed Feb 9 01:27:59 PST 2022



On 2/9/22 09:27, Ronak Jain wrote:
> Add support for runtime features by using an IOCTL call. The features
>   can be enabled or disabled from the firmware as well as the features
>   can be configured at runtime by querying IOCTL_SET_FEATURE_CONFIG id.
>   Similarly, the user can get the configured values of features by
>   querying IOCTL_GET_FEATURE_CONFIG id.
> 
> Signed-off-by: Ronak Jain <ronak.jain at xilinx.com>
> ---
> Changes in v5:
> - Resolved merge conflicts
> 
> Changes in v4:
> - Update commit message
> 
> Changes in v3:
> - Resolved merged conflict
> 
> Changes in v2:
> - Resolved merged conflict
> - Update commit message
> ---
>   drivers/firmware/xilinx/zynqmp.c     | 27 +++++++++++++++++++++++++++
>   include/linux/firmware/xlnx-zynqmp.h | 25 +++++++++++++++++++++++++
>   2 files changed, 52 insertions(+)
> 
> diff --git a/drivers/firmware/xilinx/zynqmp.c b/drivers/firmware/xilinx/zynqmp.c
> index 450c5f6a1cbf..0fa6cae4969d 100644
> --- a/drivers/firmware/xilinx/zynqmp.c
> +++ b/drivers/firmware/xilinx/zynqmp.c
> @@ -1156,6 +1156,33 @@ int zynqmp_pm_system_shutdown(const u32 type, const u32 subtype)
>   				   0, 0, NULL);
>   }
>   
> +/**
> + * zynqmp_pm_set_feature_config - PM call to request IOCTL for feature config
> + * @id:         The config ID of the feature to be configured
> + * @value:      The config value of the feature to be configured
> + *
> + * Return:      Returns 0 on success or error value on failure.
> + */
> +int zynqmp_pm_set_feature_config(enum pm_feature_config_id id, u32 value)
> +{
> +	return zynqmp_pm_invoke_fn(PM_IOCTL, 0, IOCTL_SET_FEATURE_CONFIG,
> +				   id, value, NULL);
> +}
> +
> +/**
> + * zynqmp_pm_get_feature_config - PM call to get value of configured feature
> + * @id:         The config id of the feature to be queried
> + * @payload:    Returned value array
> + *
> + * Return:      Returns 0 on success or error value on failure.
> + */
> +int zynqmp_pm_get_feature_config(enum pm_feature_config_id id,
> +				 u32 *payload)
> +{
> +	return zynqmp_pm_invoke_fn(PM_IOCTL, 0, IOCTL_GET_FEATURE_CONFIG,
> +				   id, 0, payload);
> +}
> +
>   /**
>    * struct zynqmp_pm_shutdown_scope - Struct for shutdown scope
>    * @subtype:	Shutdown subtype
> diff --git a/include/linux/firmware/xlnx-zynqmp.h b/include/linux/firmware/xlnx-zynqmp.h
> index 907cb01890cf..cf557fbeb8c7 100644
> --- a/include/linux/firmware/xlnx-zynqmp.h
> +++ b/include/linux/firmware/xlnx-zynqmp.h
> @@ -143,6 +143,9 @@ enum pm_ioctl_id {
>   	IOCTL_OSPI_MUX_SELECT = 21,
>   	/* Register SGI to ATF */
>   	IOCTL_REGISTER_SGI = 25,
> +	/* Runtime feature configuration */
> +	IOCTL_SET_FEATURE_CONFIG = 26,
> +	IOCTL_GET_FEATURE_CONFIG = 27,
>   };
>   
>   enum pm_query_id {
> @@ -376,6 +379,14 @@ enum ospi_mux_select_type {
>   	PM_OSPI_MUX_SEL_LINEAR = 1,
>   };
>   
> +enum pm_feature_config_id {
> +	PM_FEATURE_INVALID = 0,
> +	PM_FEATURE_OVERTEMP_STATUS = 1,
> +	PM_FEATURE_OVERTEMP_VALUE = 2,
> +	PM_FEATURE_EXTWDT_STATUS = 3,
> +	PM_FEATURE_EXTWDT_VALUE = 4,
> +};
> +
>   /**
>    * struct zynqmp_pm_query_data - PM query data
>    * @qid:	query ID
> @@ -447,6 +458,8 @@ int zynqmp_pm_load_pdi(const u32 src, const u64 address);
>   int zynqmp_pm_register_notifier(const u32 node, const u32 event,
>   				const u32 wake, const u32 enable);
>   int zynqmp_pm_feature(const u32 api_id);
> +int zynqmp_pm_set_feature_config(enum pm_feature_config_id id, u32 value);
> +int zynqmp_pm_get_feature_config(enum pm_feature_config_id id, u32 *payload);
>   #else
>   static inline int zynqmp_pm_get_api_version(u32 *version)
>   {
> @@ -689,6 +702,18 @@ static inline int zynqmp_pm_feature(const u32 api_id)
>   {
>   	return -ENODEV;
>   }
> +
> +static inline int zynqmp_pm_set_feature_config(enum pm_feature_config_id id,
> +					       u32 value)
> +{
> +	return -ENODEV;
> +}
> +
> +static inline int zynqmp_pm_get_feature_config(enum pm_feature_config_id id,
> +					       u32 *payload)
> +{
> +	return -ENODEV;
> +}
>   #endif
>   
>   #endif /* __FIRMWARE_ZYNQMP_H__ */


Acked-by: Michal Simek <michal.simek at xilinx.com>

Thanks,
Michal



More information about the linux-arm-kernel mailing list