Lines Matching full:slave

141 static int rt711_sdca_update_status(struct sdw_slave *slave,
144 struct rt711_sdca_priv *rt711 = dev_get_drvdata(&slave->dev);
157 sdw_write_no_pm(rt711->slave, SDW_SCP_SDCA_INTMASK1,
159 sdw_write_no_pm(rt711->slave, SDW_SCP_SDCA_INTMASK2,
165 * Perform initialization only if slave status is present and
171 /* perform I/O transfers required for Slave initialization */
172 return rt711_sdca_io_init(&slave->dev, slave);
175 static int rt711_sdca_read_prop(struct sdw_slave *slave)
177 struct sdw_slave_prop *prop = &slave->prop;
194 prop->src_dpn_prop = devm_kcalloc(&slave->dev, nval,
212 prop->sink_dpn_prop = devm_kcalloc(&slave->dev, nval,
228 prop->dp0_prop = devm_kzalloc(&slave->dev, sizeof(*prop->dp0_prop),
245 static int rt711_sdca_interrupt_callback(struct sdw_slave *slave,
248 struct rt711_sdca_priv *rt711 = dev_get_drvdata(&slave->dev);
253 dev_dbg(&slave->dev,
258 dev_warn(&slave->dev, "%s the pending delayed_work was cancelled", __func__);
273 ret = sdw_read_no_pm(rt711->slave, SDW_SCP_SDCA_INT1);
277 ret = sdw_read_no_pm(rt711->slave, SDW_SCP_SDCA_INT2);
286 ret = sdw_read_no_pm(rt711->slave, SDW_SCP_SDCA_INT1);
290 ret = sdw_write_no_pm(rt711->slave, SDW_SCP_SDCA_INT1,
295 ret = sdw_read_no_pm(rt711->slave, SDW_SCP_SDCA_INT2);
299 ret = sdw_write_no_pm(rt711->slave, SDW_SCP_SDCA_INT2,
306 ret = sdw_read_no_pm(rt711->slave, SDW_DP0_INT);
311 ret = sdw_read_no_pm(rt711->slave, SDW_SCP_SDCA_INT1);
316 ret = sdw_read_no_pm(rt711->slave, SDW_SCP_SDCA_INT2);
327 dev_warn(&slave->dev,
351 static int rt711_sdca_sdw_probe(struct sdw_slave *slave,
357 mbq_regmap = devm_regmap_init_sdw_mbq(slave, &rt711_sdca_mbq_regmap);
361 regmap = devm_regmap_init_sdw(slave, &rt711_sdca_regmap);
365 return rt711_sdca_init(&slave->dev, regmap, mbq_regmap, slave);
368 static int rt711_sdca_sdw_remove(struct sdw_slave *slave)
370 struct rt711_sdca_priv *rt711 = dev_get_drvdata(&slave->dev);
377 pm_runtime_disable(&slave->dev);
410 struct sdw_slave *slave = dev_to_sdw_dev(dev);
423 ret1 = sdw_update_no_pm(slave, SDW_SCP_SDCA_INTMASK1,
425 ret2 = sdw_update_no_pm(slave, SDW_SCP_SDCA_INTMASK2,
431 dev_dbg(&slave->dev, "%s: could not disable SDCA interrupts\n:", __func__);
441 struct sdw_slave *slave = dev_to_sdw_dev(dev);
448 if (!slave->unattach_request) {
451 sdw_write_no_pm(slave, SDW_SCP_SDCA_INTMASK1, SDW_SCP_SDCA_INTMASK_SDCA_0);
452 sdw_write_no_pm(slave, SDW_SCP_SDCA_INTMASK2, SDW_SCP_SDCA_INTMASK_SDCA_8);
459 time = wait_for_completion_timeout(&slave->initialization_complete,
462 dev_err(&slave->dev, "%s: Initialization not complete, timed out\n", __func__);
463 sdw_show_ping_status(slave->bus, true);
469 slave->unattach_request = 0;