2 * Copyright (c) 2013-2015, Linux Foundation. All rights reserved.
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 and
6 * only version 2 as published by the Free Software Foundation.
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
15 #include "phy-qcom-ufs-qmp-14nm.h"
17 #define UFS_PHY_NAME "ufs_phy_qmp_14nm"
18 #define UFS_PHY_VDDA_PHY_UV (925000)
21 int ufs_qcom_phy_qmp_14nm_phy_calibrate(struct ufs_qcom_phy
*ufs_qcom_phy
,
24 int tbl_size_A
= ARRAY_SIZE(phy_cal_table_rate_A
);
25 int tbl_size_B
= ARRAY_SIZE(phy_cal_table_rate_B
);
28 err
= ufs_qcom_phy_calibrate(ufs_qcom_phy
, phy_cal_table_rate_A
,
29 tbl_size_A
, phy_cal_table_rate_B
, tbl_size_B
, is_rate_B
);
32 dev_err(ufs_qcom_phy
->dev
,
33 "%s: ufs_qcom_phy_calibrate() failed %d\n",
39 void ufs_qcom_phy_qmp_14nm_advertise_quirks(struct ufs_qcom_phy
*phy_common
)
42 UFS_QCOM_PHY_QUIRK_HIBERN8_EXIT_AFTER_PHY_PWR_COLLAPSE
;
45 static int ufs_qcom_phy_qmp_14nm_init(struct phy
*generic_phy
)
50 static int ufs_qcom_phy_qmp_14nm_exit(struct phy
*generic_phy
)
56 void ufs_qcom_phy_qmp_14nm_power_control(struct ufs_qcom_phy
*phy
, bool val
)
58 writel_relaxed(val
? 0x1 : 0x0, phy
->mmio
+ UFS_PHY_POWER_DOWN_CONTROL
);
60 * Before any transactions involving PHY, ensure PHY knows
61 * that it's analog rail is powered ON (or OFF).
67 void ufs_qcom_phy_qmp_14nm_set_tx_lane_enable(struct ufs_qcom_phy
*phy
, u32 val
)
70 * 14nm PHY does not have TX_LANE_ENABLE register.
71 * Implement this function so as not to propagate error to caller.
75 static inline void ufs_qcom_phy_qmp_14nm_start_serdes(struct ufs_qcom_phy
*phy
)
79 tmp
= readl_relaxed(phy
->mmio
+ UFS_PHY_PHY_START
);
80 tmp
&= ~MASK_SERDES_START
;
81 tmp
|= (1 << OFFSET_SERDES_START
);
82 writel_relaxed(tmp
, phy
->mmio
+ UFS_PHY_PHY_START
);
83 /* Ensure register value is committed */
87 static int ufs_qcom_phy_qmp_14nm_is_pcs_ready(struct ufs_qcom_phy
*phy_common
)
92 err
= readl_poll_timeout(phy_common
->mmio
+ UFS_PHY_PCS_READY_STATUS
,
93 val
, (val
& MASK_PCS_READY
), 10, 1000000);
95 dev_err(phy_common
->dev
, "%s: poll for pcs failed err = %d\n",
100 static const struct phy_ops ufs_qcom_phy_qmp_14nm_phy_ops
= {
101 .init
= ufs_qcom_phy_qmp_14nm_init
,
102 .exit
= ufs_qcom_phy_qmp_14nm_exit
,
103 .power_on
= ufs_qcom_phy_power_on
,
104 .power_off
= ufs_qcom_phy_power_off
,
105 .owner
= THIS_MODULE
,
108 static struct ufs_qcom_phy_specific_ops phy_14nm_ops
= {
109 .calibrate_phy
= ufs_qcom_phy_qmp_14nm_phy_calibrate
,
110 .start_serdes
= ufs_qcom_phy_qmp_14nm_start_serdes
,
111 .is_physical_coding_sublayer_ready
= ufs_qcom_phy_qmp_14nm_is_pcs_ready
,
112 .set_tx_lane_enable
= ufs_qcom_phy_qmp_14nm_set_tx_lane_enable
,
113 .power_control
= ufs_qcom_phy_qmp_14nm_power_control
,
116 static int ufs_qcom_phy_qmp_14nm_probe(struct platform_device
*pdev
)
118 struct device
*dev
= &pdev
->dev
;
119 struct phy
*generic_phy
;
120 struct ufs_qcom_phy_qmp_14nm
*phy
;
121 struct ufs_qcom_phy
*phy_common
;
124 phy
= devm_kzalloc(dev
, sizeof(*phy
), GFP_KERNEL
);
129 phy_common
= &phy
->common_cfg
;
131 generic_phy
= ufs_qcom_phy_generic_probe(pdev
, phy_common
,
132 &ufs_qcom_phy_qmp_14nm_phy_ops
, &phy_14nm_ops
);
135 dev_err(dev
, "%s: ufs_qcom_phy_generic_probe() failed\n",
141 err
= ufs_qcom_phy_init_clks(phy_common
);
143 dev_err(phy_common
->dev
,
144 "%s: ufs_qcom_phy_init_clks() failed %d\n",
149 err
= ufs_qcom_phy_init_vregulators(phy_common
);
151 dev_err(phy_common
->dev
,
152 "%s: ufs_qcom_phy_init_vregulators() failed %d\n",
156 phy_common
->vdda_phy
.max_uV
= UFS_PHY_VDDA_PHY_UV
;
157 phy_common
->vdda_phy
.min_uV
= UFS_PHY_VDDA_PHY_UV
;
159 ufs_qcom_phy_qmp_14nm_advertise_quirks(phy_common
);
161 phy_set_drvdata(generic_phy
, phy
);
163 strlcpy(phy_common
->name
, UFS_PHY_NAME
, sizeof(phy_common
->name
));
169 static const struct of_device_id ufs_qcom_phy_qmp_14nm_of_match
[] = {
170 {.compatible
= "qcom,ufs-phy-qmp-14nm"},
171 {.compatible
= "qcom,msm8996-ufs-phy-qmp-14nm"},
174 MODULE_DEVICE_TABLE(of
, ufs_qcom_phy_qmp_14nm_of_match
);
176 static struct platform_driver ufs_qcom_phy_qmp_14nm_driver
= {
177 .probe
= ufs_qcom_phy_qmp_14nm_probe
,
179 .of_match_table
= ufs_qcom_phy_qmp_14nm_of_match
,
180 .name
= "ufs_qcom_phy_qmp_14nm",
184 module_platform_driver(ufs_qcom_phy_qmp_14nm_driver
);
186 MODULE_DESCRIPTION("Universal Flash Storage (UFS) QCOM PHY QMP 14nm");
187 MODULE_LICENSE("GPL v2");