Lines Matching refs:i3cbus
95 i3c_bus_to_i3c_master(struct i3c_bus *i3cbus) in i3c_bus_to_i3c_master() argument
97 return container_of(i3cbus, struct i3c_master_controller, bus); in i3c_bus_to_i3c_master()
418 static void i3c_bus_cleanup(struct i3c_bus *i3cbus) in i3c_bus_cleanup() argument
421 idr_remove(&i3c_bus_idr, i3cbus->id); in i3c_bus_cleanup()
425 static int i3c_bus_init(struct i3c_bus *i3cbus) in i3c_bus_init() argument
429 init_rwsem(&i3cbus->lock); in i3c_bus_init()
430 INIT_LIST_HEAD(&i3cbus->devs.i2c); in i3c_bus_init()
431 INIT_LIST_HEAD(&i3cbus->devs.i3c); in i3c_bus_init()
432 i3c_bus_init_addrslots(i3cbus); in i3c_bus_init()
433 i3cbus->mode = I3C_BUS_MODE_PURE; in i3c_bus_init()
436 ret = idr_alloc(&i3c_bus_idr, i3cbus, 0, 0, GFP_KERNEL); in i3c_bus_init()
442 i3cbus->id = ret; in i3c_bus_init()
458 struct i3c_bus *i3cbus = dev_to_i3cbus(dev); in mode_show() local
461 i3c_bus_normaluse_lock(i3cbus); in mode_show()
462 if (i3cbus->mode < 0 || in mode_show()
463 i3cbus->mode >= ARRAY_SIZE(i3c_bus_mode_strings) || in mode_show()
464 !i3c_bus_mode_strings[i3cbus->mode]) in mode_show()
467 ret = sprintf(buf, "%s\n", i3c_bus_mode_strings[i3cbus->mode]); in mode_show()
468 i3c_bus_normaluse_unlock(i3cbus); in mode_show()
478 struct i3c_bus *i3cbus = dev_to_i3cbus(dev); in current_master_show() local
481 i3c_bus_normaluse_lock(i3cbus); in current_master_show()
482 ret = sprintf(buf, "%d-%llx\n", i3cbus->id, in current_master_show()
483 i3cbus->cur_master->info.pid); in current_master_show()
484 i3c_bus_normaluse_unlock(i3cbus); in current_master_show()
494 struct i3c_bus *i3cbus = dev_to_i3cbus(dev); in i3c_scl_frequency_show() local
497 i3c_bus_normaluse_lock(i3cbus); in i3c_scl_frequency_show()
498 ret = sprintf(buf, "%ld\n", i3cbus->scl_rate.i3c); in i3c_scl_frequency_show()
499 i3c_bus_normaluse_unlock(i3cbus); in i3c_scl_frequency_show()
509 struct i3c_bus *i3cbus = dev_to_i3cbus(dev); in i2c_scl_frequency_show() local
512 i3c_bus_normaluse_lock(i3cbus); in i2c_scl_frequency_show()
513 ret = sprintf(buf, "%ld\n", i3cbus->scl_rate.i2c); in i2c_scl_frequency_show()
514 i3c_bus_normaluse_unlock(i3cbus); in i2c_scl_frequency_show()
552 static int i3c_bus_set_mode(struct i3c_bus *i3cbus, enum i3c_bus_mode mode, in i3c_bus_set_mode() argument
555 struct i3c_master_controller *master = i3c_bus_to_i3c_master(i3cbus); in i3c_bus_set_mode()
557 i3cbus->mode = mode; in i3c_bus_set_mode()
559 switch (i3cbus->mode) { in i3c_bus_set_mode()
561 if (!i3cbus->scl_rate.i3c) in i3c_bus_set_mode()
562 i3cbus->scl_rate.i3c = I3C_BUS_TYP_I3C_SCL_RATE; in i3c_bus_set_mode()
566 if (!i3cbus->scl_rate.i3c) in i3c_bus_set_mode()
567 i3cbus->scl_rate.i3c = I3C_BUS_TYP_I3C_SCL_RATE; in i3c_bus_set_mode()
568 if (!i3cbus->scl_rate.i2c) in i3c_bus_set_mode()
569 i3cbus->scl_rate.i2c = max_i2c_scl_rate; in i3c_bus_set_mode()
572 if (!i3cbus->scl_rate.i2c) in i3c_bus_set_mode()
573 i3cbus->scl_rate.i2c = max_i2c_scl_rate; in i3c_bus_set_mode()
574 if (!i3cbus->scl_rate.i3c || in i3c_bus_set_mode()
575 i3cbus->scl_rate.i3c > i3cbus->scl_rate.i2c) in i3c_bus_set_mode()
576 i3cbus->scl_rate.i3c = i3cbus->scl_rate.i2c; in i3c_bus_set_mode()
583 i3cbus->scl_rate.i2c, i3cbus->scl_rate.i3c); in i3c_bus_set_mode()
589 if (i3cbus->scl_rate.i3c > I3C_BUS_MAX_I3C_SCL_RATE || in i3c_bus_set_mode()
590 i3cbus->scl_rate.i2c > I3C_BUS_I2C_FM_PLUS_SCL_RATE) in i3c_bus_set_mode()
2471 struct i3c_bus *i3cbus = i3c_master_get_bus(master); in i3c_master_register() local
2494 ret = i3c_bus_init(i3cbus); in i3c_master_register()
2499 dev_set_name(&master->dev, "i3c-%d", i3cbus->id); in i3c_master_register()
2528 ret = i3c_bus_set_mode(i3cbus, mode, i2c_scl_rate); in i3c_master_register()