Lines Matching full:rt
25 * @rt: Retimer device
33 int tb_retimer_nvm_read(struct tb_retimer *rt, unsigned int address, void *buf, in tb_retimer_nvm_read() argument
36 return usb4_port_retimer_nvm_read(rt->port, rt->index, address, buf, size); in tb_retimer_nvm_read()
42 struct tb_retimer *rt = tb_to_retimer(nvm->dev); in nvm_read() local
45 pm_runtime_get_sync(&rt->dev); in nvm_read()
47 if (!mutex_trylock(&rt->tb->lock)) { in nvm_read()
52 ret = tb_retimer_nvm_read(rt, offset, val, bytes); in nvm_read()
53 mutex_unlock(&rt->tb->lock); in nvm_read()
56 pm_runtime_mark_last_busy(&rt->dev); in nvm_read()
57 pm_runtime_put_autosuspend(&rt->dev); in nvm_read()
65 struct tb_retimer *rt = tb_to_retimer(nvm->dev); in nvm_write() local
68 if (!mutex_trylock(&rt->tb->lock)) in nvm_write()
72 mutex_unlock(&rt->tb->lock); in nvm_write()
77 static int tb_retimer_nvm_add(struct tb_retimer *rt) in tb_retimer_nvm_add() argument
82 nvm = tb_nvm_alloc(&rt->dev); in tb_retimer_nvm_add()
96 if (!rt->no_nvm_upgrade) { in tb_retimer_nvm_add()
102 rt->nvm = nvm; in tb_retimer_nvm_add()
103 dev_dbg(&rt->dev, "NVM version %x.%x\n", nvm->major, nvm->minor); in tb_retimer_nvm_add()
107 dev_dbg(&rt->dev, "NVM upgrade disabled\n"); in tb_retimer_nvm_add()
108 rt->no_nvm_upgrade = true; in tb_retimer_nvm_add()
115 static int tb_retimer_nvm_validate_and_write(struct tb_retimer *rt) in tb_retimer_nvm_validate_and_write() argument
121 ret = tb_nvm_validate(rt->nvm); in tb_retimer_nvm_validate_and_write()
125 buf = rt->nvm->buf_data_start; in tb_retimer_nvm_validate_and_write()
126 image_size = rt->nvm->buf_data_size; in tb_retimer_nvm_validate_and_write()
128 ret = usb4_port_retimer_nvm_write(rt->port, rt->index, 0, buf, in tb_retimer_nvm_validate_and_write()
133 rt->nvm->flushed = true; in tb_retimer_nvm_validate_and_write()
137 static int tb_retimer_nvm_authenticate(struct tb_retimer *rt, bool auth_only) in tb_retimer_nvm_authenticate() argument
143 ret = usb4_port_retimer_nvm_set_offset(rt->port, rt->index, 0); in tb_retimer_nvm_authenticate()
148 ret = usb4_port_retimer_nvm_authenticate(rt->port, rt->index); in tb_retimer_nvm_authenticate()
158 ret = usb4_port_retimer_nvm_authenticate_status(rt->port, rt->index, in tb_retimer_nvm_authenticate()
161 rt->auth_status = status; in tb_retimer_nvm_authenticate()
171 struct tb_retimer *rt = tb_to_retimer(dev); in device_show() local
173 return sysfs_emit(buf, "%#x\n", rt->device); in device_show()
180 struct tb_retimer *rt = tb_to_retimer(dev); in nvm_authenticate_show() local
183 if (!mutex_trylock(&rt->tb->lock)) in nvm_authenticate_show()
186 if (!rt->nvm) in nvm_authenticate_show()
189 ret = sysfs_emit(buf, "%#x\n", rt->auth_status); in nvm_authenticate_show()
191 mutex_unlock(&rt->tb->lock); in nvm_authenticate_show()
253 struct tb_retimer *rt = tb_to_retimer(dev); in nvm_authenticate_store() local
256 pm_runtime_get_sync(&rt->dev); in nvm_authenticate_store()
258 if (!mutex_trylock(&rt->tb->lock)) { in nvm_authenticate_store()
263 if (!rt->nvm) { in nvm_authenticate_store()
273 rt->auth_status = 0; in nvm_authenticate_store()
283 tb_retimer_set_inbound_sbtx(rt->port); in nvm_authenticate_store()
285 ret = tb_retimer_nvm_authenticate(rt, true); in nvm_authenticate_store()
287 if (!rt->nvm->flushed) { in nvm_authenticate_store()
288 if (!rt->nvm->buf) { in nvm_authenticate_store()
293 ret = tb_retimer_nvm_validate_and_write(rt); in nvm_authenticate_store()
298 ret = tb_retimer_nvm_authenticate(rt, false); in nvm_authenticate_store()
304 tb_retimer_unset_inbound_sbtx(rt->port); in nvm_authenticate_store()
305 mutex_unlock(&rt->tb->lock); in nvm_authenticate_store()
307 pm_runtime_mark_last_busy(&rt->dev); in nvm_authenticate_store()
308 pm_runtime_put_autosuspend(&rt->dev); in nvm_authenticate_store()
319 struct tb_retimer *rt = tb_to_retimer(dev); in nvm_version_show() local
322 if (!mutex_trylock(&rt->tb->lock)) in nvm_version_show()
325 if (!rt->nvm) in nvm_version_show()
328 ret = sysfs_emit(buf, "%x.%x\n", rt->nvm->major, rt->nvm->minor); in nvm_version_show()
330 mutex_unlock(&rt->tb->lock); in nvm_version_show()
338 struct tb_retimer *rt = tb_to_retimer(dev); in vendor_show() local
340 return sysfs_emit(buf, "%#x\n", rt->vendor); in vendor_show()
348 struct tb_retimer *rt = tb_to_retimer(dev); in retimer_is_visible() local
352 return rt->no_nvm_upgrade ? 0 : attr->mode; in retimer_is_visible()
377 struct tb_retimer *rt = tb_to_retimer(dev); in tb_retimer_release() local
379 kfree(rt); in tb_retimer_release()
391 struct tb_retimer *rt; in tb_retimer_add() local
412 rt = kzalloc(sizeof(*rt), GFP_KERNEL); in tb_retimer_add()
413 if (!rt) in tb_retimer_add()
416 rt->index = index; in tb_retimer_add()
417 rt->vendor = vendor; in tb_retimer_add()
418 rt->device = device; in tb_retimer_add()
419 rt->auth_status = auth_status; in tb_retimer_add()
420 rt->port = port; in tb_retimer_add()
421 rt->tb = port->sw->tb; in tb_retimer_add()
428 rt->no_nvm_upgrade = true; in tb_retimer_add()
430 rt->dev.parent = &port->usb4->dev; in tb_retimer_add()
431 rt->dev.bus = &tb_bus_type; in tb_retimer_add()
432 rt->dev.type = &tb_retimer_type; in tb_retimer_add()
433 dev_set_name(&rt->dev, "%s:%u.%u", dev_name(&port->sw->dev), in tb_retimer_add()
436 ret = device_register(&rt->dev); in tb_retimer_add()
438 dev_err(&rt->dev, "failed to register retimer: %d\n", ret); in tb_retimer_add()
439 put_device(&rt->dev); in tb_retimer_add()
443 ret = tb_retimer_nvm_add(rt); in tb_retimer_add()
445 dev_err(&rt->dev, "failed to add NVM devices: %d\n", ret); in tb_retimer_add()
446 device_unregister(&rt->dev); in tb_retimer_add()
450 dev_info(&rt->dev, "new retimer found, vendor=%#x device=%#x\n", in tb_retimer_add()
451 rt->vendor, rt->device); in tb_retimer_add()
453 pm_runtime_no_callbacks(&rt->dev); in tb_retimer_add()
454 pm_runtime_set_active(&rt->dev); in tb_retimer_add()
455 pm_runtime_enable(&rt->dev); in tb_retimer_add()
456 pm_runtime_set_autosuspend_delay(&rt->dev, TB_AUTOSUSPEND_DELAY); in tb_retimer_add()
457 pm_runtime_mark_last_busy(&rt->dev); in tb_retimer_add()
458 pm_runtime_use_autosuspend(&rt->dev); in tb_retimer_add()
460 tb_retimer_debugfs_init(rt); in tb_retimer_add()
464 static void tb_retimer_remove(struct tb_retimer *rt) in tb_retimer_remove() argument
466 dev_info(&rt->dev, "retimer disconnected\n"); in tb_retimer_remove()
467 tb_retimer_debugfs_remove(rt); in tb_retimer_remove()
468 tb_nvm_free(rt->nvm); in tb_retimer_remove()
469 device_unregister(&rt->dev); in tb_retimer_remove()
480 struct tb_retimer *rt = tb_to_retimer(dev); in retimer_match() local
482 return rt && rt->port == lookup->port && rt->index == lookup->index; in retimer_match()
513 * Send broadcast RT to make sure retimer indices facing this in tb_retimer_scan()
553 struct tb_retimer *rt; in tb_retimer_scan() local
559 rt = tb_port_find_retimer(port, i); in tb_retimer_scan()
560 if (rt) { in tb_retimer_scan()
561 put_device(&rt->dev); in tb_retimer_scan()
575 struct tb_retimer *rt = tb_to_retimer(dev); in remove_retimer() local
578 if (rt && rt->port == port) in remove_retimer()
579 tb_retimer_remove(rt); in remove_retimer()