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()
396 static void i3c_bus_cleanup(struct i3c_bus *i3cbus) in i3c_bus_cleanup() argument
399 idr_remove(&i3c_bus_idr, i3cbus->id); in i3c_bus_cleanup()
403 static int i3c_bus_init(struct i3c_bus *i3cbus) in i3c_bus_init() argument
407 init_rwsem(&i3cbus->lock); in i3c_bus_init()
408 INIT_LIST_HEAD(&i3cbus->devs.i2c); in i3c_bus_init()
409 INIT_LIST_HEAD(&i3cbus->devs.i3c); in i3c_bus_init()
410 i3c_bus_init_addrslots(i3cbus); in i3c_bus_init()
411 i3cbus->mode = I3C_BUS_MODE_PURE; in i3c_bus_init()
414 ret = idr_alloc(&i3c_bus_idr, i3cbus, 0, 0, GFP_KERNEL); in i3c_bus_init()
420 i3cbus->id = ret; in i3c_bus_init()
436 struct i3c_bus *i3cbus = dev_to_i3cbus(dev); in mode_show() local
439 i3c_bus_normaluse_lock(i3cbus); in mode_show()
440 if (i3cbus->mode < 0 || in mode_show()
441 i3cbus->mode >= ARRAY_SIZE(i3c_bus_mode_strings) || in mode_show()
442 !i3c_bus_mode_strings[i3cbus->mode]) in mode_show()
445 ret = sprintf(buf, "%s\n", i3c_bus_mode_strings[i3cbus->mode]); in mode_show()
446 i3c_bus_normaluse_unlock(i3cbus); in mode_show()
456 struct i3c_bus *i3cbus = dev_to_i3cbus(dev); in current_master_show() local
459 i3c_bus_normaluse_lock(i3cbus); in current_master_show()
460 ret = sprintf(buf, "%d-%llx\n", i3cbus->id, in current_master_show()
461 i3cbus->cur_master->info.pid); in current_master_show()
462 i3c_bus_normaluse_unlock(i3cbus); in current_master_show()
472 struct i3c_bus *i3cbus = dev_to_i3cbus(dev); in i3c_scl_frequency_show() local
475 i3c_bus_normaluse_lock(i3cbus); in i3c_scl_frequency_show()
476 ret = sprintf(buf, "%ld\n", i3cbus->scl_rate.i3c); in i3c_scl_frequency_show()
477 i3c_bus_normaluse_unlock(i3cbus); in i3c_scl_frequency_show()
487 struct i3c_bus *i3cbus = dev_to_i3cbus(dev); in i2c_scl_frequency_show() local
490 i3c_bus_normaluse_lock(i3cbus); in i2c_scl_frequency_show()
491 ret = sprintf(buf, "%ld\n", i3cbus->scl_rate.i2c); in i2c_scl_frequency_show()
492 i3c_bus_normaluse_unlock(i3cbus); in i2c_scl_frequency_show()
530 int i3c_bus_set_mode(struct i3c_bus *i3cbus, enum i3c_bus_mode mode, in i3c_bus_set_mode() argument
533 struct i3c_master_controller *master = i3c_bus_to_i3c_master(i3cbus); in i3c_bus_set_mode()
535 i3cbus->mode = mode; in i3c_bus_set_mode()
537 switch (i3cbus->mode) { in i3c_bus_set_mode()
539 if (!i3cbus->scl_rate.i3c) in i3c_bus_set_mode()
540 i3cbus->scl_rate.i3c = I3C_BUS_TYP_I3C_SCL_RATE; in i3c_bus_set_mode()
544 if (!i3cbus->scl_rate.i3c) in i3c_bus_set_mode()
545 i3cbus->scl_rate.i3c = I3C_BUS_TYP_I3C_SCL_RATE; in i3c_bus_set_mode()
546 if (!i3cbus->scl_rate.i2c) in i3c_bus_set_mode()
547 i3cbus->scl_rate.i2c = max_i2c_scl_rate; in i3c_bus_set_mode()
550 if (!i3cbus->scl_rate.i2c) in i3c_bus_set_mode()
551 i3cbus->scl_rate.i2c = max_i2c_scl_rate; in i3c_bus_set_mode()
552 if (!i3cbus->scl_rate.i3c || in i3c_bus_set_mode()
553 i3cbus->scl_rate.i3c > i3cbus->scl_rate.i2c) in i3c_bus_set_mode()
554 i3cbus->scl_rate.i3c = i3cbus->scl_rate.i2c; in i3c_bus_set_mode()
561 i3cbus->scl_rate.i2c, i3cbus->scl_rate.i3c); in i3c_bus_set_mode()
567 if (i3cbus->scl_rate.i3c > I3C_BUS_MAX_I3C_SCL_RATE || in i3c_bus_set_mode()
568 i3cbus->scl_rate.i2c > I3C_BUS_I2C_FM_PLUS_SCL_RATE) in i3c_bus_set_mode()
2411 struct i3c_bus *i3cbus = i3c_master_get_bus(master); in i3c_master_register() local
2434 ret = i3c_bus_init(i3cbus); in i3c_master_register()
2439 dev_set_name(&master->dev, "i3c-%d", i3cbus->id); in i3c_master_register()
2468 ret = i3c_bus_set_mode(i3cbus, mode, i2c_scl_rate); in i3c_master_register()