162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */ 262306a36Sopenharmony_ci/* Copyright (c) 2015, The Linux Foundation. All rights reserved. 362306a36Sopenharmony_ci */ 462306a36Sopenharmony_ci 562306a36Sopenharmony_ci#ifndef UFSHCD_PLTFRM_H_ 662306a36Sopenharmony_ci#define UFSHCD_PLTFRM_H_ 762306a36Sopenharmony_ci 862306a36Sopenharmony_ci#include <ufs/ufshcd.h> 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci#define UFS_PWM_MODE 1 1162306a36Sopenharmony_ci#define UFS_HS_MODE 2 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_cistruct ufs_dev_params { 1462306a36Sopenharmony_ci u32 pwm_rx_gear; /* pwm rx gear to work in */ 1562306a36Sopenharmony_ci u32 pwm_tx_gear; /* pwm tx gear to work in */ 1662306a36Sopenharmony_ci u32 hs_rx_gear; /* hs rx gear to work in */ 1762306a36Sopenharmony_ci u32 hs_tx_gear; /* hs tx gear to work in */ 1862306a36Sopenharmony_ci u32 rx_lanes; /* number of rx lanes */ 1962306a36Sopenharmony_ci u32 tx_lanes; /* number of tx lanes */ 2062306a36Sopenharmony_ci u32 rx_pwr_pwm; /* rx pwm working pwr */ 2162306a36Sopenharmony_ci u32 tx_pwr_pwm; /* tx pwm working pwr */ 2262306a36Sopenharmony_ci u32 rx_pwr_hs; /* rx hs working pwr */ 2362306a36Sopenharmony_ci u32 tx_pwr_hs; /* tx hs working pwr */ 2462306a36Sopenharmony_ci u32 hs_rate; /* rate A/B to work in HS */ 2562306a36Sopenharmony_ci u32 desired_working_mode; 2662306a36Sopenharmony_ci}; 2762306a36Sopenharmony_ci 2862306a36Sopenharmony_ciint ufshcd_get_pwr_dev_param(const struct ufs_dev_params *dev_param, 2962306a36Sopenharmony_ci const struct ufs_pa_layer_attr *dev_max, 3062306a36Sopenharmony_ci struct ufs_pa_layer_attr *agreed_pwr); 3162306a36Sopenharmony_civoid ufshcd_init_pwr_dev_param(struct ufs_dev_params *dev_param); 3262306a36Sopenharmony_ciint ufshcd_pltfrm_init(struct platform_device *pdev, 3362306a36Sopenharmony_ci const struct ufs_hba_variant_ops *vops); 3462306a36Sopenharmony_ciint ufshcd_populate_vreg(struct device *dev, const char *name, 3562306a36Sopenharmony_ci struct ufs_vreg **out_vreg); 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_ci#endif /* UFSHCD_PLTFRM_H_ */ 38