提交 8f8d37b2 编写于 作者: V Viresh Kumar 提交者: Rafael J. Wysocki

PM / OPP: Prefix exported opp routines with dev_pm_opp_

That's the naming convention followed in most of opp core, but few
routines didn't follow this, fix them.
Reviewed-by: NStephen Boyd <sboyd@codeaurora.org>
Signed-off-by: NViresh Kumar <viresh.kumar@linaro.org>
Acked-by: NShawn Guo <shawnguo@kernel.org>
Signed-off-by: NRafael J. Wysocki <rafael.j.wysocki@intel.com>
上级 f0489a5e
...@@ -350,7 +350,7 @@ static void __init imx6q_opp_init(void) ...@@ -350,7 +350,7 @@ static void __init imx6q_opp_init(void)
return; return;
} }
if (of_add_opp_table(cpu_dev)) { if (dev_pm_opp_of_add_table(cpu_dev)) {
pr_warn("failed to init OPP table\n"); pr_warn("failed to init OPP table\n");
goto put_node; goto put_node;
} }
......
...@@ -828,8 +828,8 @@ static int _opp_add(struct device *dev, struct dev_pm_opp *new_opp, ...@@ -828,8 +828,8 @@ static int _opp_add(struct device *dev, struct dev_pm_opp *new_opp,
* The opp is made available by default and it can be controlled using * The opp is made available by default and it can be controlled using
* dev_pm_opp_enable/disable functions and may be removed by dev_pm_opp_remove. * dev_pm_opp_enable/disable functions and may be removed by dev_pm_opp_remove.
* *
* NOTE: "dynamic" parameter impacts OPPs added by the of_add_opp_table and * NOTE: "dynamic" parameter impacts OPPs added by the dev_pm_opp_of_add_table
* freed by of_remove_opp_table. * and freed by dev_pm_opp_of_remove_table.
* *
* Locking: The internal device_opp and opp structures are RCU protected. * Locking: The internal device_opp and opp structures are RCU protected.
* Hence this function internally uses RCU updater strategy with mutex locks * Hence this function internally uses RCU updater strategy with mutex locks
...@@ -1213,7 +1213,8 @@ EXPORT_SYMBOL_GPL(dev_pm_opp_get_notifier); ...@@ -1213,7 +1213,8 @@ EXPORT_SYMBOL_GPL(dev_pm_opp_get_notifier);
#ifdef CONFIG_OF #ifdef CONFIG_OF
/** /**
* of_remove_opp_table() - Free OPP table entries created from static DT entries * dev_pm_opp_of_remove_table() - Free OPP table entries created from static DT
* entries
* @dev: device pointer used to lookup device OPPs. * @dev: device pointer used to lookup device OPPs.
* *
* Free OPPs created using static entries present in DT. * Free OPPs created using static entries present in DT.
...@@ -1224,7 +1225,7 @@ EXPORT_SYMBOL_GPL(dev_pm_opp_get_notifier); ...@@ -1224,7 +1225,7 @@ EXPORT_SYMBOL_GPL(dev_pm_opp_get_notifier);
* that this function is *NOT* called under RCU protection or in contexts where * that this function is *NOT* called under RCU protection or in contexts where
* mutex cannot be locked. * mutex cannot be locked.
*/ */
void of_remove_opp_table(struct device *dev) void dev_pm_opp_of_remove_table(struct device *dev)
{ {
struct device_opp *dev_opp; struct device_opp *dev_opp;
struct dev_pm_opp *opp, *tmp; struct dev_pm_opp *opp, *tmp;
...@@ -1259,9 +1260,9 @@ void of_remove_opp_table(struct device *dev) ...@@ -1259,9 +1260,9 @@ void of_remove_opp_table(struct device *dev)
unlock: unlock:
mutex_unlock(&dev_opp_list_lock); mutex_unlock(&dev_opp_list_lock);
} }
EXPORT_SYMBOL_GPL(of_remove_opp_table); EXPORT_SYMBOL_GPL(dev_pm_opp_of_remove_table);
void of_cpumask_remove_opp_table(cpumask_var_t cpumask) void dev_pm_opp_of_cpumask_remove_table(cpumask_var_t cpumask)
{ {
struct device *cpu_dev; struct device *cpu_dev;
int cpu; int cpu;
...@@ -1276,10 +1277,10 @@ void of_cpumask_remove_opp_table(cpumask_var_t cpumask) ...@@ -1276,10 +1277,10 @@ void of_cpumask_remove_opp_table(cpumask_var_t cpumask)
continue; continue;
} }
of_remove_opp_table(cpu_dev); dev_pm_opp_of_remove_table(cpu_dev);
} }
} }
EXPORT_SYMBOL_GPL(of_cpumask_remove_opp_table); EXPORT_SYMBOL_GPL(dev_pm_opp_of_cpumask_remove_table);
/* Returns opp descriptor node for a device, caller must do of_node_put() */ /* Returns opp descriptor node for a device, caller must do of_node_put() */
static struct device_node *_of_get_opp_desc_node(struct device *dev) static struct device_node *_of_get_opp_desc_node(struct device *dev)
...@@ -1337,7 +1338,7 @@ static int _of_add_opp_table_v2(struct device *dev, struct device_node *opp_np) ...@@ -1337,7 +1338,7 @@ static int _of_add_opp_table_v2(struct device *dev, struct device_node *opp_np)
return 0; return 0;
free_table: free_table:
of_remove_opp_table(dev); dev_pm_opp_of_remove_table(dev);
return ret; return ret;
} }
...@@ -1380,7 +1381,7 @@ static int _of_add_opp_table_v1(struct device *dev) ...@@ -1380,7 +1381,7 @@ static int _of_add_opp_table_v1(struct device *dev)
} }
/** /**
* of_add_opp_table() - Initialize opp table from device tree * dev_pm_opp_of_add_table() - Initialize opp table from device tree
* @dev: device pointer used to lookup device OPPs. * @dev: device pointer used to lookup device OPPs.
* *
* Register the initial OPP table with the OPP library for given device. * Register the initial OPP table with the OPP library for given device.
...@@ -1402,7 +1403,7 @@ static int _of_add_opp_table_v1(struct device *dev) ...@@ -1402,7 +1403,7 @@ static int _of_add_opp_table_v1(struct device *dev)
* -ENODATA when empty 'operating-points' property is found * -ENODATA when empty 'operating-points' property is found
* -EINVAL when invalid entries are found in opp-v2 table * -EINVAL when invalid entries are found in opp-v2 table
*/ */
int of_add_opp_table(struct device *dev) int dev_pm_opp_of_add_table(struct device *dev)
{ {
struct device_node *opp_np; struct device_node *opp_np;
int ret; int ret;
...@@ -1425,9 +1426,9 @@ int of_add_opp_table(struct device *dev) ...@@ -1425,9 +1426,9 @@ int of_add_opp_table(struct device *dev)
return ret; return ret;
} }
EXPORT_SYMBOL_GPL(of_add_opp_table); EXPORT_SYMBOL_GPL(dev_pm_opp_of_add_table);
int of_cpumask_add_opp_table(cpumask_var_t cpumask) int dev_pm_opp_of_cpumask_add_table(cpumask_var_t cpumask)
{ {
struct device *cpu_dev; struct device *cpu_dev;
int cpu, ret = 0; int cpu, ret = 0;
...@@ -1442,23 +1443,23 @@ int of_cpumask_add_opp_table(cpumask_var_t cpumask) ...@@ -1442,23 +1443,23 @@ int of_cpumask_add_opp_table(cpumask_var_t cpumask)
continue; continue;
} }
ret = of_add_opp_table(cpu_dev); ret = dev_pm_opp_of_add_table(cpu_dev);
if (ret) { if (ret) {
pr_err("%s: couldn't find opp table for cpu:%d, %d\n", pr_err("%s: couldn't find opp table for cpu:%d, %d\n",
__func__, cpu, ret); __func__, cpu, ret);
/* Free all other OPPs */ /* Free all other OPPs */
of_cpumask_remove_opp_table(cpumask); dev_pm_opp_of_cpumask_remove_table(cpumask);
break; break;
} }
} }
return ret; return ret;
} }
EXPORT_SYMBOL_GPL(of_cpumask_add_opp_table); EXPORT_SYMBOL_GPL(dev_pm_opp_of_cpumask_add_table);
/* Required only for V1 bindings, as v2 can manage it from DT itself */ /* Required only for V1 bindings, as v2 can manage it from DT itself */
int set_cpus_sharing_opps(struct device *cpu_dev, cpumask_var_t cpumask) int dev_pm_opp_set_sharing_cpus(struct device *cpu_dev, cpumask_var_t cpumask)
{ {
struct device_list_opp *list_dev; struct device_list_opp *list_dev;
struct device_opp *dev_opp; struct device_opp *dev_opp;
...@@ -1496,7 +1497,7 @@ int set_cpus_sharing_opps(struct device *cpu_dev, cpumask_var_t cpumask) ...@@ -1496,7 +1497,7 @@ int set_cpus_sharing_opps(struct device *cpu_dev, cpumask_var_t cpumask)
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(set_cpus_sharing_opps); EXPORT_SYMBOL_GPL(dev_pm_opp_set_sharing_cpus);
/* /*
* Works only for OPP v2 bindings. * Works only for OPP v2 bindings.
...@@ -1504,7 +1505,7 @@ EXPORT_SYMBOL_GPL(set_cpus_sharing_opps); ...@@ -1504,7 +1505,7 @@ EXPORT_SYMBOL_GPL(set_cpus_sharing_opps);
* cpumask should be already set to mask of cpu_dev->id. * cpumask should be already set to mask of cpu_dev->id.
* Returns -ENOENT if operating-points-v2 bindings aren't supported. * Returns -ENOENT if operating-points-v2 bindings aren't supported.
*/ */
int of_get_cpus_sharing_opps(struct device *cpu_dev, cpumask_var_t cpumask) int dev_pm_opp_of_get_sharing_cpus(struct device *cpu_dev, cpumask_var_t cpumask)
{ {
struct device_node *np, *tmp_np; struct device_node *np, *tmp_np;
struct device *tcpu_dev; struct device *tcpu_dev;
...@@ -1554,5 +1555,5 @@ int of_get_cpus_sharing_opps(struct device *cpu_dev, cpumask_var_t cpumask) ...@@ -1554,5 +1555,5 @@ int of_get_cpus_sharing_opps(struct device *cpu_dev, cpumask_var_t cpumask)
of_node_put(np); of_node_put(np);
return ret; return ret;
} }
EXPORT_SYMBOL_GPL(of_get_cpus_sharing_opps); EXPORT_SYMBOL_GPL(dev_pm_opp_of_get_sharing_cpus);
#endif #endif
...@@ -28,7 +28,7 @@ struct cpufreq_arm_bL_ops { ...@@ -28,7 +28,7 @@ struct cpufreq_arm_bL_ops {
/* /*
* This must set opp table for cpu_dev in a similar way as done by * This must set opp table for cpu_dev in a similar way as done by
* of_add_opp_table(). * dev_pm_opp_of_add_table().
*/ */
int (*init_opp_table)(struct device *cpu_dev); int (*init_opp_table)(struct device *cpu_dev);
......
...@@ -54,7 +54,7 @@ static int dt_init_opp_table(struct device *cpu_dev) ...@@ -54,7 +54,7 @@ static int dt_init_opp_table(struct device *cpu_dev)
return -ENOENT; return -ENOENT;
} }
ret = of_add_opp_table(cpu_dev); ret = dev_pm_opp_of_add_table(cpu_dev);
of_node_put(np); of_node_put(np);
return ret; return ret;
...@@ -82,7 +82,7 @@ static struct cpufreq_arm_bL_ops dt_bL_ops = { ...@@ -82,7 +82,7 @@ static struct cpufreq_arm_bL_ops dt_bL_ops = {
.name = "dt-bl", .name = "dt-bl",
.get_transition_latency = dt_get_transition_latency, .get_transition_latency = dt_get_transition_latency,
.init_opp_table = dt_init_opp_table, .init_opp_table = dt_init_opp_table,
.free_opp_table = of_remove_opp_table, .free_opp_table = dev_pm_opp_of_remove_table,
}; };
static int generic_bL_probe(struct platform_device *pdev) static int generic_bL_probe(struct platform_device *pdev)
......
...@@ -216,7 +216,7 @@ static int cpufreq_init(struct cpufreq_policy *policy) ...@@ -216,7 +216,7 @@ static int cpufreq_init(struct cpufreq_policy *policy)
} }
/* Get OPP-sharing information from "operating-points-v2" bindings */ /* Get OPP-sharing information from "operating-points-v2" bindings */
ret = of_get_cpus_sharing_opps(cpu_dev, policy->cpus); ret = dev_pm_opp_of_get_sharing_cpus(cpu_dev, policy->cpus);
if (ret) { if (ret) {
/* /*
* operating-points-v2 not supported, fallback to old method of * operating-points-v2 not supported, fallback to old method of
...@@ -238,7 +238,7 @@ static int cpufreq_init(struct cpufreq_policy *policy) ...@@ -238,7 +238,7 @@ static int cpufreq_init(struct cpufreq_policy *policy)
* *
* OPPs might be populated at runtime, don't check for error here * OPPs might be populated at runtime, don't check for error here
*/ */
of_cpumask_add_opp_table(policy->cpus); dev_pm_opp_of_cpumask_add_table(policy->cpus);
/* /*
* But we need OPP table to function so if it is not there let's * But we need OPP table to function so if it is not there let's
...@@ -261,7 +261,7 @@ static int cpufreq_init(struct cpufreq_policy *policy) ...@@ -261,7 +261,7 @@ static int cpufreq_init(struct cpufreq_policy *policy)
* OPP tables are initialized only for policy->cpu, do it for * OPP tables are initialized only for policy->cpu, do it for
* others as well. * others as well.
*/ */
ret = set_cpus_sharing_opps(cpu_dev, policy->cpus); ret = dev_pm_opp_set_sharing_cpus(cpu_dev, policy->cpus);
if (ret) if (ret)
dev_err(cpu_dev, "%s: failed to mark OPPs as shared: %d\n", dev_err(cpu_dev, "%s: failed to mark OPPs as shared: %d\n",
__func__, ret); __func__, ret);
...@@ -368,7 +368,7 @@ static int cpufreq_init(struct cpufreq_policy *policy) ...@@ -368,7 +368,7 @@ static int cpufreq_init(struct cpufreq_policy *policy)
out_free_priv: out_free_priv:
kfree(priv); kfree(priv);
out_free_opp: out_free_opp:
of_cpumask_remove_opp_table(policy->cpus); dev_pm_opp_of_cpumask_remove_table(policy->cpus);
out_node_put: out_node_put:
of_node_put(np); of_node_put(np);
out_put_reg_clk: out_put_reg_clk:
...@@ -385,7 +385,7 @@ static int cpufreq_exit(struct cpufreq_policy *policy) ...@@ -385,7 +385,7 @@ static int cpufreq_exit(struct cpufreq_policy *policy)
cpufreq_cooling_unregister(priv->cdev); cpufreq_cooling_unregister(priv->cdev);
dev_pm_opp_free_cpufreq_table(priv->cpu_dev, &policy->freq_table); dev_pm_opp_free_cpufreq_table(priv->cpu_dev, &policy->freq_table);
of_cpumask_remove_opp_table(policy->related_cpus); dev_pm_opp_of_cpumask_remove_table(policy->related_cpus);
clk_put(policy->clk); clk_put(policy->clk);
if (!IS_ERR(priv->cpu_reg)) if (!IS_ERR(priv->cpu_reg))
regulator_put(priv->cpu_reg); regulator_put(priv->cpu_reg);
......
...@@ -360,7 +360,7 @@ static int exynos_cpufreq_probe(struct platform_device *pdev) ...@@ -360,7 +360,7 @@ static int exynos_cpufreq_probe(struct platform_device *pdev)
goto err_put_node; goto err_put_node;
} }
ret = of_add_opp_table(dvfs_info->dev); ret = dev_pm_opp_of_add_table(dvfs_info->dev);
if (ret) { if (ret) {
dev_err(dvfs_info->dev, "failed to init OPP table: %d\n", ret); dev_err(dvfs_info->dev, "failed to init OPP table: %d\n", ret);
goto err_put_node; goto err_put_node;
...@@ -424,7 +424,7 @@ static int exynos_cpufreq_probe(struct platform_device *pdev) ...@@ -424,7 +424,7 @@ static int exynos_cpufreq_probe(struct platform_device *pdev)
err_free_table: err_free_table:
dev_pm_opp_free_cpufreq_table(dvfs_info->dev, &dvfs_info->freq_table); dev_pm_opp_free_cpufreq_table(dvfs_info->dev, &dvfs_info->freq_table);
err_free_opp: err_free_opp:
of_remove_opp_table(dvfs_info->dev); dev_pm_opp_of_remove_table(dvfs_info->dev);
err_put_node: err_put_node:
of_node_put(np); of_node_put(np);
dev_err(&pdev->dev, "%s: failed initialization\n", __func__); dev_err(&pdev->dev, "%s: failed initialization\n", __func__);
...@@ -435,7 +435,7 @@ static int exynos_cpufreq_remove(struct platform_device *pdev) ...@@ -435,7 +435,7 @@ static int exynos_cpufreq_remove(struct platform_device *pdev)
{ {
cpufreq_unregister_driver(&exynos_driver); cpufreq_unregister_driver(&exynos_driver);
dev_pm_opp_free_cpufreq_table(dvfs_info->dev, &dvfs_info->freq_table); dev_pm_opp_free_cpufreq_table(dvfs_info->dev, &dvfs_info->freq_table);
of_remove_opp_table(dvfs_info->dev); dev_pm_opp_of_remove_table(dvfs_info->dev);
return 0; return 0;
} }
......
...@@ -202,7 +202,7 @@ static int imx6q_cpufreq_probe(struct platform_device *pdev) ...@@ -202,7 +202,7 @@ static int imx6q_cpufreq_probe(struct platform_device *pdev)
*/ */
num = dev_pm_opp_get_opp_count(cpu_dev); num = dev_pm_opp_get_opp_count(cpu_dev);
if (num < 0) { if (num < 0) {
ret = of_add_opp_table(cpu_dev); ret = dev_pm_opp_of_add_table(cpu_dev);
if (ret < 0) { if (ret < 0) {
dev_err(cpu_dev, "failed to init OPP table: %d\n", ret); dev_err(cpu_dev, "failed to init OPP table: %d\n", ret);
goto put_reg; goto put_reg;
...@@ -312,7 +312,7 @@ static int imx6q_cpufreq_probe(struct platform_device *pdev) ...@@ -312,7 +312,7 @@ static int imx6q_cpufreq_probe(struct platform_device *pdev)
dev_pm_opp_free_cpufreq_table(cpu_dev, &freq_table); dev_pm_opp_free_cpufreq_table(cpu_dev, &freq_table);
out_free_opp: out_free_opp:
if (free_opp) if (free_opp)
of_remove_opp_table(cpu_dev); dev_pm_opp_of_remove_table(cpu_dev);
put_reg: put_reg:
if (!IS_ERR(arm_reg)) if (!IS_ERR(arm_reg))
regulator_put(arm_reg); regulator_put(arm_reg);
...@@ -340,7 +340,7 @@ static int imx6q_cpufreq_remove(struct platform_device *pdev) ...@@ -340,7 +340,7 @@ static int imx6q_cpufreq_remove(struct platform_device *pdev)
cpufreq_unregister_driver(&imx6q_cpufreq_driver); cpufreq_unregister_driver(&imx6q_cpufreq_driver);
dev_pm_opp_free_cpufreq_table(cpu_dev, &freq_table); dev_pm_opp_free_cpufreq_table(cpu_dev, &freq_table);
if (free_opp) if (free_opp)
of_remove_opp_table(cpu_dev); dev_pm_opp_of_remove_table(cpu_dev);
regulator_put(arm_reg); regulator_put(arm_reg);
if (!IS_ERR(pu_reg)) if (!IS_ERR(pu_reg))
regulator_put(pu_reg); regulator_put(pu_reg);
......
...@@ -344,7 +344,7 @@ static int mtk_cpu_dvfs_info_init(struct mtk_cpu_dvfs_info *info, int cpu) ...@@ -344,7 +344,7 @@ static int mtk_cpu_dvfs_info_init(struct mtk_cpu_dvfs_info *info, int cpu)
/* Both presence and absence of sram regulator are valid cases. */ /* Both presence and absence of sram regulator are valid cases. */
sram_reg = regulator_get_exclusive(cpu_dev, "sram"); sram_reg = regulator_get_exclusive(cpu_dev, "sram");
ret = of_add_opp_table(cpu_dev); ret = dev_pm_opp_of_add_table(cpu_dev);
if (ret) { if (ret) {
pr_warn("no OPP table for cpu%d\n", cpu); pr_warn("no OPP table for cpu%d\n", cpu);
goto out_free_resources; goto out_free_resources;
...@@ -378,7 +378,7 @@ static int mtk_cpu_dvfs_info_init(struct mtk_cpu_dvfs_info *info, int cpu) ...@@ -378,7 +378,7 @@ static int mtk_cpu_dvfs_info_init(struct mtk_cpu_dvfs_info *info, int cpu)
return 0; return 0;
out_free_opp_table: out_free_opp_table:
of_remove_opp_table(cpu_dev); dev_pm_opp_of_remove_table(cpu_dev);
out_free_resources: out_free_resources:
if (!IS_ERR(proc_reg)) if (!IS_ERR(proc_reg))
...@@ -404,7 +404,7 @@ static void mtk_cpu_dvfs_info_release(struct mtk_cpu_dvfs_info *info) ...@@ -404,7 +404,7 @@ static void mtk_cpu_dvfs_info_release(struct mtk_cpu_dvfs_info *info)
if (!IS_ERR(info->inter_clk)) if (!IS_ERR(info->inter_clk))
clk_put(info->inter_clk); clk_put(info->inter_clk);
of_remove_opp_table(info->cpu_dev); dev_pm_opp_of_remove_table(info->cpu_dev);
} }
static int mtk_cpufreq_init(struct cpufreq_policy *policy) static int mtk_cpufreq_init(struct cpufreq_policy *policy)
......
...@@ -132,37 +132,37 @@ static inline struct srcu_notifier_head *dev_pm_opp_get_notifier( ...@@ -132,37 +132,37 @@ static inline struct srcu_notifier_head *dev_pm_opp_get_notifier(
#endif /* CONFIG_PM_OPP */ #endif /* CONFIG_PM_OPP */
#if defined(CONFIG_PM_OPP) && defined(CONFIG_OF) #if defined(CONFIG_PM_OPP) && defined(CONFIG_OF)
int of_add_opp_table(struct device *dev); int dev_pm_opp_of_add_table(struct device *dev);
void of_remove_opp_table(struct device *dev); void dev_pm_opp_of_remove_table(struct device *dev);
int of_cpumask_add_opp_table(cpumask_var_t cpumask); int dev_pm_opp_of_cpumask_add_table(cpumask_var_t cpumask);
void of_cpumask_remove_opp_table(cpumask_var_t cpumask); void dev_pm_opp_of_cpumask_remove_table(cpumask_var_t cpumask);
int of_get_cpus_sharing_opps(struct device *cpu_dev, cpumask_var_t cpumask); int dev_pm_opp_of_get_sharing_cpus(struct device *cpu_dev, cpumask_var_t cpumask);
int set_cpus_sharing_opps(struct device *cpu_dev, cpumask_var_t cpumask); int dev_pm_opp_set_sharing_cpus(struct device *cpu_dev, cpumask_var_t cpumask);
#else #else
static inline int of_add_opp_table(struct device *dev) static inline int dev_pm_opp_of_add_table(struct device *dev)
{ {
return -EINVAL; return -EINVAL;
} }
static inline void of_remove_opp_table(struct device *dev) static inline void dev_pm_opp_of_remove_table(struct device *dev)
{ {
} }
static inline int of_cpumask_add_opp_table(cpumask_var_t cpumask) static inline int dev_pm_opp_of_cpumask_add_table(cpumask_var_t cpumask)
{ {
return -ENOSYS; return -ENOSYS;
} }
static inline void of_cpumask_remove_opp_table(cpumask_var_t cpumask) static inline void dev_pm_opp_of_cpumask_remove_table(cpumask_var_t cpumask)
{ {
} }
static inline int of_get_cpus_sharing_opps(struct device *cpu_dev, cpumask_var_t cpumask) static inline int dev_pm_opp_of_get_sharing_cpus(struct device *cpu_dev, cpumask_var_t cpumask)
{ {
return -ENOSYS; return -ENOSYS;
} }
static inline int set_cpus_sharing_opps(struct device *cpu_dev, cpumask_var_t cpumask) static inline int dev_pm_opp_set_sharing_cpus(struct device *cpu_dev, cpumask_var_t cpumask)
{ {
return -ENOSYS; return -ENOSYS;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册