On 16-09-20, 10:21, Srinivas Kandagatla wrote: > currently the max rows and cols values are hardcoded. In reality > these values depend on the IP version. So get these based on > device tree compatible strings. > > Signed-off-by: Srinivas Kandagatla <srinivas.kandagatla@xxxxxxxxxx> > --- > drivers/soundwire/qcom.c | 50 ++++++++++++++++++++++++++++------------ > 1 file changed, 35 insertions(+), 15 deletions(-) > > diff --git a/drivers/soundwire/qcom.c b/drivers/soundwire/qcom.c > index 76963a7bdaa3..1dbf33684470 100644 > --- a/drivers/soundwire/qcom.c > +++ b/drivers/soundwire/qcom.c > @@ -66,11 +66,6 @@ > #define SWRM_REG_VAL_PACK(data, dev, id, reg) \ > ((reg) | ((id) << 16) | ((dev) << 20) | ((data) << 24)) > > -#define SWRM_MAX_ROW_VAL 0 /* Rows = 48 */ > -#define SWRM_DEFAULT_ROWS 48 > -#define SWRM_MIN_COL_VAL 0 /* Cols = 2 */ > -#define SWRM_DEFAULT_COL 16 > -#define SWRM_MAX_COL_VAL 7 > #define SWRM_SPECIAL_CMD_ID 0xF > #define MAX_FREQ_NUM 1 > #define TIMEOUT_MS (2 * HZ) > @@ -104,6 +99,8 @@ struct qcom_swrm_ctrl { > unsigned int version; > int num_din_ports; > int num_dout_ports; > + int cols_index; > + int rows_index; > unsigned long dout_port_mask; > unsigned long din_port_mask; > struct qcom_swrm_port_config pconfig[QCOM_SDW_MAX_PORTS]; > @@ -113,6 +110,21 @@ struct qcom_swrm_ctrl { > int (*reg_write)(struct qcom_swrm_ctrl *ctrl, int reg, int val); > }; > > +struct qcom_swrm_data { > + u32 default_cols; > + u32 default_rows; > +}; > + > +static struct qcom_swrm_data swrm_v1_3_data = { > + .default_rows = 48, > + .default_cols = 16, > +}; > + > +static struct qcom_swrm_data swrm_v1_5_data = { > + .default_rows = 50, > + .default_cols = 16, > +}; > + > #define to_qcom_sdw(b) container_of(b, struct qcom_swrm_ctrl, bus) > > static int qcom_swrm_ahb_reg_read(struct qcom_swrm_ctrl *ctrl, int reg, > @@ -299,8 +311,10 @@ static int qcom_swrm_init(struct qcom_swrm_ctrl *ctrl) > u32 val; > > /* Clear Rows and Cols */ > - val = FIELD_PREP(SWRM_MCP_FRAME_CTRL_BANK_ROW_CTRL_BMSK, SWRM_MAX_ROW_VAL); > - val |= FIELD_PREP(SWRM_MCP_FRAME_CTRL_BANK_COL_CTRL_BMSK, SWRM_MIN_COL_VAL); > + val = FIELD_PREP(SWRM_MCP_FRAME_CTRL_BANK_ROW_CTRL_BMSK, > + ctrl->rows_index); > + val |= FIELD_PREP(SWRM_MCP_FRAME_CTRL_BANK_COL_CTRL_BMSK, > + ctrl->cols_index); single line for these ? > ctrl->reg_write(ctrl, SWRM_MCP_FRAME_CTRL_BANK_ADDR(0), val); > > @@ -378,8 +392,10 @@ static int qcom_swrm_pre_bank_switch(struct sdw_bus *bus) > val &= ~SWRM_MCP_FRAME_CTRL_BANK_COL_CTRL_BMSK; > val &= ~SWRM_MCP_FRAME_CTRL_BANK_ROW_CTRL_BMSK; > > - val |= FIELD_PREP(SWRM_MCP_FRAME_CTRL_BANK_COL_CTRL_BMSK, SWRM_MAX_COL_VAL); > - val |= FIELD_PREP(SWRM_MCP_FRAME_CTRL_BANK_ROW_CTRL_BMSK, SWRM_MAX_ROW_VAL); > + val |= FIELD_PREP(SWRM_MCP_FRAME_CTRL_BANK_COL_CTRL_BMSK, > + ctrl->cols_index); > + val |= FIELD_PREP(SWRM_MCP_FRAME_CTRL_BANK_ROW_CTRL_BMSK, > + ctrl->rows_index); here as well > > return ctrl->reg_write(ctrl, reg, val); > } > @@ -780,6 +796,7 @@ static int qcom_swrm_probe(struct platform_device *pdev) > struct sdw_master_prop *prop; > struct sdw_bus_params *params; > struct qcom_swrm_ctrl *ctrl; > + const struct qcom_swrm_data *data; > int ret; > u32 val; > > @@ -787,6 +804,9 @@ static int qcom_swrm_probe(struct platform_device *pdev) > if (!ctrl) > return -ENOMEM; > > + data = of_device_get_match_data(dev); Wont it be good to check if data is valid, we do dereference it few line below > + ctrl->rows_index = sdw_find_row_index(data->default_rows); > + ctrl->cols_index = sdw_find_col_index(data->default_cols); > #if IS_ENABLED(CONFIG_SLIMBUS) > if (dev->parent->bus == &slimbus_bus) { > #else > @@ -836,8 +856,8 @@ static int qcom_swrm_probe(struct platform_device *pdev) > params = &ctrl->bus.params; > params->max_dr_freq = DEFAULT_CLK_FREQ; > params->curr_dr_freq = DEFAULT_CLK_FREQ; > - params->col = SWRM_DEFAULT_COL; > - params->row = SWRM_DEFAULT_ROWS; > + params->col = data->default_cols; > + params->row = data->default_rows; > ctrl->reg_read(ctrl, SWRM_MCP_STATUS, &val); > params->curr_bank = val & SWRM_MCP_STATUS_BANK_NUM_MASK; > params->next_bank = !params->curr_bank; > @@ -847,8 +867,8 @@ static int qcom_swrm_probe(struct platform_device *pdev) > prop->num_clk_gears = 0; > prop->num_clk_freq = MAX_FREQ_NUM; > prop->clk_freq = &qcom_swrm_freq_tbl[0]; > - prop->default_col = SWRM_DEFAULT_COL; > - prop->default_row = SWRM_DEFAULT_ROWS; > + prop->default_col = data->default_cols; > + prop->default_row = data->default_rows; > > ctrl->reg_read(ctrl, SWRM_COMP_HW_VERSION, &ctrl->version); > > @@ -899,8 +919,8 @@ static int qcom_swrm_remove(struct platform_device *pdev) > } > > static const struct of_device_id qcom_swrm_of_match[] = { > - { .compatible = "qcom,soundwire-v1.3.0", }, > - { .compatible = "qcom,soundwire-v1.5.1", }, > + { .compatible = "qcom,soundwire-v1.3.0", .data = &swrm_v1_3_data }, > + { .compatible = "qcom,soundwire-v1.5.1", .data = &swrm_v1_5_data }, > {/* sentinel */}, > }; > > -- > 2.21.0 -- ~Vinod