Lines Matching full:slave

156 static int rt712_sdca_update_status(struct sdw_slave *slave,
159 struct rt712_sdca_priv *rt712 = dev_get_drvdata(&slave->dev);
172 sdw_write_no_pm(rt712->slave, SDW_SCP_SDCA_INTMASK1,
174 sdw_write_no_pm(rt712->slave, SDW_SCP_SDCA_INTMASK2,
180 * Perform initialization only if slave status is present and
186 /* perform I/O transfers required for Slave initialization */
187 return rt712_sdca_io_init(&slave->dev, slave);
190 static int rt712_sdca_read_prop(struct sdw_slave *slave)
192 struct sdw_slave_prop *prop = &slave->prop;
199 sdw_slave_read_prop(slave);
211 prop->src_dpn_prop = devm_kcalloc(&slave->dev, nval,
229 prop->sink_dpn_prop = devm_kcalloc(&slave->dev, nval,
254 static int rt712_sdca_interrupt_callback(struct sdw_slave *slave,
257 struct rt712_sdca_priv *rt712 = dev_get_drvdata(&slave->dev);
262 dev_dbg(&slave->dev,
267 dev_warn(&slave->dev, "%s the pending delayed_work was cancelled", __func__);
282 ret = sdw_read_no_pm(rt712->slave, SDW_SCP_SDCA_INT1);
286 ret = sdw_read_no_pm(rt712->slave, SDW_SCP_SDCA_INT2);
295 ret = sdw_read_no_pm(rt712->slave, SDW_SCP_SDCA_INT1);
299 ret = sdw_write_no_pm(rt712->slave, SDW_SCP_SDCA_INT1,
304 ret = sdw_read_no_pm(rt712->slave, SDW_SCP_SDCA_INT2);
308 ret = sdw_write_no_pm(rt712->slave, SDW_SCP_SDCA_INT2,
315 ret = sdw_read_no_pm(rt712->slave, SDW_DP0_INT);
320 ret = sdw_read_no_pm(rt712->slave, SDW_SCP_SDCA_INT1);
325 ret = sdw_read_no_pm(rt712->slave, SDW_SCP_SDCA_INT2);
336 dev_warn(&slave->dev,
360 static int rt712_sdca_sdw_probe(struct sdw_slave *slave,
366 mbq_regmap = devm_regmap_init_sdw_mbq(slave, &rt712_sdca_mbq_regmap);
370 regmap = devm_regmap_init_sdw(slave, &rt712_sdca_regmap);
374 return rt712_sdca_init(&slave->dev, regmap, mbq_regmap, slave);
377 static int rt712_sdca_sdw_remove(struct sdw_slave *slave)
379 struct rt712_sdca_priv *rt712 = dev_get_drvdata(&slave->dev);
386 pm_runtime_disable(&slave->dev);
422 struct sdw_slave *slave = dev_to_sdw_dev(dev);
435 ret1 = sdw_update_no_pm(slave, SDW_SCP_SDCA_INTMASK1,
437 ret2 = sdw_update_no_pm(slave, SDW_SCP_SDCA_INTMASK2,
443 dev_dbg(&slave->dev, "%s: could not disable SDCA interrupts\n:", __func__);
453 struct sdw_slave *slave = dev_to_sdw_dev(dev);
460 if (!slave->unattach_request) {
464 sdw_write_no_pm(slave, SDW_SCP_SDCA_INTMASK1, SDW_SCP_SDCA_INTMASK_SDCA_0);
465 sdw_write_no_pm(slave, SDW_SCP_SDCA_INTMASK2, SDW_SCP_SDCA_INTMASK_SDCA_8);
472 time = wait_for_completion_timeout(&slave->initialization_complete,
475 dev_err(&slave->dev, "%s: Initialization not complete, timed out\n", __func__);
476 sdw_show_ping_status(slave->bus, true);
482 slave->unattach_request = 0;