Lines Matching refs:cr
433 int cr; member
444 struct afu_config_record *cr = to_cr(kobj); in vendor_show() local
446 return scnprintf(buf, PAGE_SIZE, "0x%.4x\n", cr->vendor); in vendor_show()
452 struct afu_config_record *cr = to_cr(kobj); in device_show() local
454 return scnprintf(buf, PAGE_SIZE, "0x%.4x\n", cr->device); in device_show()
460 struct afu_config_record *cr = to_cr(kobj); in class_show() local
462 return scnprintf(buf, PAGE_SIZE, "0x%.6x\n", cr->class); in class_show()
469 struct afu_config_record *cr = to_cr(kobj); in afu_read_config() local
475 val = cxl_afu_cr_read64(afu, cr->cr, off & ~0x7); in afu_read_config()
499 struct afu_config_record *cr = to_cr(kobj); in release_afu_config_record() local
501 kfree(cr); in release_afu_config_record()
512 struct afu_config_record *cr; in cxl_sysfs_afu_new_cr() local
515 cr = kzalloc(sizeof(struct afu_config_record), GFP_KERNEL); in cxl_sysfs_afu_new_cr()
516 if (!cr) in cxl_sysfs_afu_new_cr()
519 cr->cr = cr_idx; in cxl_sysfs_afu_new_cr()
520 cr->device = cxl_afu_cr_read16(afu, cr_idx, PCI_DEVICE_ID); in cxl_sysfs_afu_new_cr()
521 cr->vendor = cxl_afu_cr_read16(afu, cr_idx, PCI_VENDOR_ID); in cxl_sysfs_afu_new_cr()
522 cr->class = cxl_afu_cr_read32(afu, cr_idx, PCI_CLASS_REVISION) >> 8; in cxl_sysfs_afu_new_cr()
533 sysfs_bin_attr_init(&cr->config_attr); in cxl_sysfs_afu_new_cr()
534 cr->config_attr.attr.name = "config"; in cxl_sysfs_afu_new_cr()
535 cr->config_attr.attr.mode = S_IRUSR; in cxl_sysfs_afu_new_cr()
536 cr->config_attr.size = afu->crs_len; in cxl_sysfs_afu_new_cr()
537 cr->config_attr.read = afu_read_config; in cxl_sysfs_afu_new_cr()
539 rc = kobject_init_and_add(&cr->kobj, &afu_config_record_type, in cxl_sysfs_afu_new_cr()
540 &afu->dev.kobj, "cr%i", cr->cr); in cxl_sysfs_afu_new_cr()
544 rc = sysfs_create_bin_file(&cr->kobj, &cr->config_attr); in cxl_sysfs_afu_new_cr()
548 rc = kobject_uevent(&cr->kobj, KOBJ_ADD); in cxl_sysfs_afu_new_cr()
552 return cr; in cxl_sysfs_afu_new_cr()
554 sysfs_remove_bin_file(&cr->kobj, &cr->config_attr); in cxl_sysfs_afu_new_cr()
556 kobject_put(&cr->kobj); in cxl_sysfs_afu_new_cr()
559 kfree(cr); in cxl_sysfs_afu_new_cr()
565 struct afu_config_record *cr, *tmp; in cxl_sysfs_afu_remove() local
575 list_for_each_entry_safe(cr, tmp, &afu->crs, list) { in cxl_sysfs_afu_remove()
576 sysfs_remove_bin_file(&cr->kobj, &cr->config_attr); in cxl_sysfs_afu_remove()
577 kobject_put(&cr->kobj); in cxl_sysfs_afu_remove()
583 struct afu_config_record *cr; in cxl_sysfs_afu_add() local
612 cr = cxl_sysfs_afu_new_cr(afu, i); in cxl_sysfs_afu_add()
613 if (IS_ERR(cr)) { in cxl_sysfs_afu_add()
614 rc = PTR_ERR(cr); in cxl_sysfs_afu_add()
617 list_add(&cr->list, &afu->crs); in cxl_sysfs_afu_add()