qdev: Replace device names containing whitespace
Device names with whitespace require quoting in the shell and in the monitor. Some of the offenders are also overly long. Some have a more convenient alias, some don't. The place for verbose device names is DeviceInfo member desc. The name should be short & sweet. Signed-off-by: Markus Armbruster <armbru@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
parent
063846984c
commit
556cd09885
@ -566,6 +566,6 @@ static struct bt_device_s *bt_hid_init(struct bt_scatternet_s *net,
|
||||
|
||||
struct bt_device_s *bt_keyboard_init(struct bt_scatternet_s *net)
|
||||
{
|
||||
USBDevice *dev = usb_create_simple(NULL /* FIXME */, "QEMU USB Keyboard");
|
||||
USBDevice *dev = usb_create_simple(NULL /* FIXME */, "usb-kbd");
|
||||
return bt_hid_init(net, dev, class_keyboard);
|
||||
}
|
||||
|
@ -3217,11 +3217,12 @@ static int pci_cirrus_vga_initfn(PCIDevice *dev)
|
||||
|
||||
void pci_cirrus_vga_init(PCIBus *bus)
|
||||
{
|
||||
pci_create_simple(bus, -1, "Cirrus VGA");
|
||||
pci_create_simple(bus, -1, "cirrus-vga");
|
||||
}
|
||||
|
||||
static PCIDeviceInfo cirrus_vga_info = {
|
||||
.qdev.name = "Cirrus VGA",
|
||||
.qdev.name = "cirrus-vga",
|
||||
.qdev.desc = "Cirrus CLGD 54xx VGA",
|
||||
.qdev.size = sizeof(PCICirrusVGAState),
|
||||
.qdev.vmsd = &vmstate_pci_cirrus_vga,
|
||||
.init = pci_cirrus_vga_initfn,
|
||||
|
@ -178,7 +178,7 @@ static PCIDeviceInfo grackle_pci_host_info = {
|
||||
};
|
||||
|
||||
static PCIDeviceInfo dec_21154_pci_host_info = {
|
||||
.qdev.name = "DEC 21154",
|
||||
.qdev.name = "dec-21154",
|
||||
.qdev.size = sizeof(PCIDevice),
|
||||
.init = dec_21154_pci_host_init,
|
||||
};
|
||||
@ -188,7 +188,7 @@ static void grackle_register_devices(void)
|
||||
sysbus_register_dev("grackle", sizeof(GrackleState),
|
||||
pci_grackle_init_device);
|
||||
pci_qdev_register(&grackle_pci_host_info);
|
||||
sysbus_register_dev("DEC 21154", sizeof(GrackleState),
|
||||
sysbus_register_dev("dec-21154", sizeof(GrackleState),
|
||||
pci_dec_21154_init_device);
|
||||
pci_qdev_register(&dec_21154_pci_host_info);
|
||||
}
|
||||
|
@ -245,7 +245,7 @@ void pci_cmd646_ide_init(PCIBus *bus, DriveInfo **hd_table,
|
||||
{
|
||||
PCIDevice *dev;
|
||||
|
||||
dev = pci_create(bus, -1, "CMD646 IDE");
|
||||
dev = pci_create(bus, -1, "cmd646-ide");
|
||||
qdev_prop_set_uint32(&dev->qdev, "secondary", secondary_ide_enabled);
|
||||
qdev_init_nofail(&dev->qdev);
|
||||
|
||||
@ -254,7 +254,7 @@ void pci_cmd646_ide_init(PCIBus *bus, DriveInfo **hd_table,
|
||||
|
||||
static PCIDeviceInfo cmd646_ide_info[] = {
|
||||
{
|
||||
.qdev.name = "CMD646 IDE",
|
||||
.qdev.name = "cmd646-ide",
|
||||
.qdev.size = sizeof(PCIIDEState),
|
||||
.init = pci_cmd646_ide_initfn,
|
||||
.qdev.props = (Property[]) {
|
||||
|
@ -161,7 +161,7 @@ void pci_piix3_ide_init(PCIBus *bus, DriveInfo **hd_table, int devfn)
|
||||
{
|
||||
PCIDevice *dev;
|
||||
|
||||
dev = pci_create_simple(bus, devfn, "PIIX3 IDE");
|
||||
dev = pci_create_simple(bus, devfn, "piix3-ide");
|
||||
pci_ide_create_devs(dev, hd_table);
|
||||
}
|
||||
|
||||
@ -171,18 +171,18 @@ void pci_piix4_ide_init(PCIBus *bus, DriveInfo **hd_table, int devfn)
|
||||
{
|
||||
PCIDevice *dev;
|
||||
|
||||
dev = pci_create_simple(bus, devfn, "PIIX4 IDE");
|
||||
dev = pci_create_simple(bus, devfn, "piix4-ide");
|
||||
pci_ide_create_devs(dev, hd_table);
|
||||
}
|
||||
|
||||
static PCIDeviceInfo piix_ide_info[] = {
|
||||
{
|
||||
.qdev.name = "PIIX3 IDE",
|
||||
.qdev.name = "piix3-ide",
|
||||
.qdev.size = sizeof(PCIIDEState),
|
||||
.qdev.no_user = 1,
|
||||
.init = pci_piix3_ide_initfn,
|
||||
},{
|
||||
.qdev.name = "PIIX4 IDE",
|
||||
.qdev.name = "piix4-ide",
|
||||
.qdev.size = sizeof(PCIIDEState),
|
||||
.qdev.no_user = 1,
|
||||
.init = pci_piix4_ide_initfn,
|
||||
|
@ -148,7 +148,7 @@ PCIBus *pci_pmac_init(qemu_irq *pic)
|
||||
|
||||
/* Use values found on a real PowerMac */
|
||||
/* Uninorth main bus */
|
||||
dev = qdev_create(NULL, "Uni-north main");
|
||||
dev = qdev_create(NULL, "uni-north-main");
|
||||
qdev_init_nofail(dev);
|
||||
s = sysbus_from_qdev(dev);
|
||||
d = FROM_SYSBUS(UNINState, s);
|
||||
@ -157,7 +157,7 @@ PCIBus *pci_pmac_init(qemu_irq *pic)
|
||||
pic, 11 << 3, 4);
|
||||
|
||||
#if 0
|
||||
pci_create_simple(d->host_state.bus, 11 << 3, "Uni-north main");
|
||||
pci_create_simple(d->host_state.bus, 11 << 3, "uni-north-main");
|
||||
#endif
|
||||
|
||||
sysbus_mmio_map(s, 0, 0xf2800000);
|
||||
@ -166,12 +166,12 @@ PCIBus *pci_pmac_init(qemu_irq *pic)
|
||||
/* DEC 21154 bridge */
|
||||
#if 0
|
||||
/* XXX: not activated as PPC BIOS doesn't handle multiple buses properly */
|
||||
pci_create_simple(d->host_state.bus, 12 << 3, "DEC 21154");
|
||||
pci_create_simple(d->host_state.bus, 12 << 3, "dec-21154");
|
||||
#endif
|
||||
|
||||
/* Uninorth AGP bus */
|
||||
pci_create_simple(d->host_state.bus, 11 << 3, "Uni-north AGP");
|
||||
dev = qdev_create(NULL, "Uni-north AGP");
|
||||
pci_create_simple(d->host_state.bus, 11 << 3, "uni-north-AGP");
|
||||
dev = qdev_create(NULL, "uni-north-AGP");
|
||||
qdev_init_nofail(dev);
|
||||
s = sysbus_from_qdev(dev);
|
||||
sysbus_mmio_map(s, 0, 0xf0800000);
|
||||
@ -180,8 +180,8 @@ PCIBus *pci_pmac_init(qemu_irq *pic)
|
||||
/* Uninorth internal bus */
|
||||
#if 0
|
||||
/* XXX: not needed for now */
|
||||
pci_create_simple(d->host_state.bus, 14 << 3, "Uni-north internal");
|
||||
dev = qdev_create(NULL, "Uni-north internal");
|
||||
pci_create_simple(d->host_state.bus, 14 << 3, "uni-north-internal");
|
||||
dev = qdev_create(NULL, "uni-north-internal");
|
||||
qdev_init_nofail(dev);
|
||||
s = sysbus_from_qdev(dev);
|
||||
sysbus_mmio_map(s, 0, 0xf4800000);
|
||||
@ -260,41 +260,41 @@ static int unin_internal_pci_host_init(PCIDevice *d)
|
||||
}
|
||||
|
||||
static PCIDeviceInfo unin_main_pci_host_info = {
|
||||
.qdev.name = "Uni-north main",
|
||||
.qdev.name = "uni-north-main",
|
||||
.qdev.size = sizeof(PCIDevice),
|
||||
.init = unin_main_pci_host_init,
|
||||
};
|
||||
|
||||
static PCIDeviceInfo dec_21154_pci_host_info = {
|
||||
.qdev.name = "DEC 21154",
|
||||
.qdev.name = "dec-21154",
|
||||
.qdev.size = sizeof(PCIDevice),
|
||||
.init = dec_21154_pci_host_init,
|
||||
};
|
||||
|
||||
static PCIDeviceInfo unin_agp_pci_host_info = {
|
||||
.qdev.name = "Uni-north AGP",
|
||||
.qdev.name = "uni-north-AGP",
|
||||
.qdev.size = sizeof(PCIDevice),
|
||||
.init = unin_agp_pci_host_init,
|
||||
};
|
||||
|
||||
static PCIDeviceInfo unin_internal_pci_host_info = {
|
||||
.qdev.name = "Uni-north internal",
|
||||
.qdev.name = "uni-north-internal",
|
||||
.qdev.size = sizeof(PCIDevice),
|
||||
.init = unin_internal_pci_host_init,
|
||||
};
|
||||
|
||||
static void unin_register_devices(void)
|
||||
{
|
||||
sysbus_register_dev("Uni-north main", sizeof(UNINState),
|
||||
sysbus_register_dev("uni-north-main", sizeof(UNINState),
|
||||
pci_unin_main_init_device);
|
||||
pci_qdev_register(&unin_main_pci_host_info);
|
||||
sysbus_register_dev("DEC 21154", sizeof(UNINState),
|
||||
sysbus_register_dev("dec-21154", sizeof(UNINState),
|
||||
pci_dec_21154_init_device);
|
||||
pci_qdev_register(&dec_21154_pci_host_info);
|
||||
sysbus_register_dev("Uni-north AGP", sizeof(UNINState),
|
||||
sysbus_register_dev("uni-north-AGP", sizeof(UNINState),
|
||||
pci_unin_agp_init_device);
|
||||
pci_qdev_register(&unin_agp_pci_host_info);
|
||||
sysbus_register_dev("Uni-north internal", sizeof(UNINState),
|
||||
sysbus_register_dev("uni-north-internal", sizeof(UNINState),
|
||||
pci_unin_internal_init_device);
|
||||
pci_qdev_register(&unin_internal_pci_host_info);
|
||||
}
|
||||
|
@ -630,7 +630,7 @@ USBDevice *usb_bt_init(HCIInfo *hci)
|
||||
|
||||
if (!hci)
|
||||
return NULL;
|
||||
dev = usb_create_simple(NULL /* FIXME */, "QEMU BT dongle");
|
||||
dev = usb_create_simple(NULL /* FIXME */, "usb-bt-dongle");
|
||||
s = DO_UPCAST(struct USBBtState, dev, dev);
|
||||
s->dev.opaque = s;
|
||||
|
||||
@ -646,7 +646,7 @@ USBDevice *usb_bt_init(HCIInfo *hci)
|
||||
|
||||
static struct USBDeviceInfo bt_info = {
|
||||
.product_desc = "QEMU BT dongle",
|
||||
.qdev.name = "QEMU BT dongle",
|
||||
.qdev.name = "usb-bt-dongle",
|
||||
.qdev.size = sizeof(struct USBBtState),
|
||||
.init = usb_bt_initfn,
|
||||
.handle_packet = usb_generic_handle_packet,
|
||||
|
@ -153,7 +153,7 @@ int usb_device_attach(USBDevice *dev)
|
||||
|
||||
if (bus->nfree == 1) {
|
||||
/* Create a new hub and chain it on. */
|
||||
hub = usb_create_simple(bus, "QEMU USB Hub");
|
||||
hub = usb_create_simple(bus, "usb-hub");
|
||||
}
|
||||
do_attach(dev);
|
||||
return 0;
|
||||
|
@ -881,8 +881,7 @@ void usb_hid_datain_cb(USBDevice *dev, void *opaque, void (*datain)(void *))
|
||||
static struct USBDeviceInfo hid_info[] = {
|
||||
{
|
||||
.product_desc = "QEMU USB Tablet",
|
||||
.qdev.name = "QEMU USB Tablet",
|
||||
.qdev.alias = "usb-tablet",
|
||||
.qdev.name = "usb-tablet",
|
||||
.usbdevice_name = "tablet",
|
||||
.qdev.size = sizeof(USBHIDState),
|
||||
.init = usb_tablet_initfn,
|
||||
@ -893,8 +892,7 @@ static struct USBDeviceInfo hid_info[] = {
|
||||
.handle_destroy = usb_hid_handle_destroy,
|
||||
},{
|
||||
.product_desc = "QEMU USB Mouse",
|
||||
.qdev.name = "QEMU USB Mouse",
|
||||
.qdev.alias = "usb-mouse",
|
||||
.qdev.name = "usb-mouse",
|
||||
.usbdevice_name = "mouse",
|
||||
.qdev.size = sizeof(USBHIDState),
|
||||
.init = usb_mouse_initfn,
|
||||
@ -905,8 +903,7 @@ static struct USBDeviceInfo hid_info[] = {
|
||||
.handle_destroy = usb_hid_handle_destroy,
|
||||
},{
|
||||
.product_desc = "QEMU USB Keyboard",
|
||||
.qdev.name = "QEMU USB Keyboard",
|
||||
.qdev.alias = "usb-kbd",
|
||||
.qdev.name = "usb-kbd",
|
||||
.usbdevice_name = "keyboard",
|
||||
.qdev.size = sizeof(USBHIDState),
|
||||
.init = usb_keyboard_initfn,
|
||||
|
@ -545,7 +545,7 @@ static int usb_hub_initfn(USBDevice *dev)
|
||||
|
||||
static struct USBDeviceInfo hub_info = {
|
||||
.product_desc = "QEMU USB Hub",
|
||||
.qdev.name = "QEMU USB Hub",
|
||||
.qdev.name = "usb-hub",
|
||||
.qdev.size = sizeof(USBHubState),
|
||||
.init = usb_hub_initfn,
|
||||
.handle_packet = usb_hub_handle_packet,
|
||||
|
@ -591,7 +591,7 @@ static USBDevice *usb_msd_init(const char *filename)
|
||||
}
|
||||
|
||||
/* create guest device */
|
||||
dev = usb_create(NULL /* FIXME */, "QEMU USB MSD");
|
||||
dev = usb_create(NULL /* FIXME */, "usb-storage");
|
||||
qdev_prop_set_drive(&dev->qdev, "drive", dinfo);
|
||||
if (qdev_init(&dev->qdev) < 0)
|
||||
return NULL;
|
||||
@ -601,8 +601,7 @@ static USBDevice *usb_msd_init(const char *filename)
|
||||
|
||||
static struct USBDeviceInfo msd_info = {
|
||||
.product_desc = "QEMU USB MSD",
|
||||
.qdev.name = "QEMU USB MSD",
|
||||
.qdev.alias = "usb-storage",
|
||||
.qdev.name = "usb-storage",
|
||||
.qdev.size = sizeof(MSDState),
|
||||
.init = usb_msd_initfn,
|
||||
.handle_packet = usb_generic_handle_packet,
|
||||
|
@ -1463,7 +1463,7 @@ USBDevice *usb_net_init(NICInfo *nd)
|
||||
USBDevice *dev;
|
||||
USBNetState *s;
|
||||
|
||||
dev = usb_create_simple(NULL /* FIXME */, "QEMU USB Network Interface");
|
||||
dev = usb_create_simple(NULL /* FIXME */, "usb-net");
|
||||
s = DO_UPCAST(USBNetState, dev, dev);
|
||||
|
||||
memcpy(s->conf.macaddr.a, nd->macaddr, sizeof(nd->macaddr));
|
||||
@ -1488,7 +1488,7 @@ USBDevice *usb_net_init(NICInfo *nd)
|
||||
|
||||
static struct USBDeviceInfo net_info = {
|
||||
.product_desc = "QEMU USB Network Interface",
|
||||
.qdev.name = "QEMU USB Network Interface",
|
||||
.qdev.name = "usb-net",
|
||||
.qdev.size = sizeof(USBNetState),
|
||||
.init = usb_net_initfn,
|
||||
.handle_packet = usb_generic_handle_packet,
|
||||
|
@ -1736,7 +1736,7 @@ static int usb_ohci_initfn_pci(struct PCIDevice *dev)
|
||||
|
||||
void usb_ohci_init_pci(struct PCIBus *bus, int devfn)
|
||||
{
|
||||
pci_create_simple(bus, devfn, "OHCI USB PCI");
|
||||
pci_create_simple(bus, devfn, "pci-ohci");
|
||||
}
|
||||
|
||||
void usb_ohci_init_pxa(target_phys_addr_t base, int num_ports, int devfn,
|
||||
@ -1762,8 +1762,7 @@ void usb_ohci_init_sm501(uint32_t mmio_base, uint32_t localmem_base,
|
||||
}
|
||||
|
||||
static PCIDeviceInfo ohci_info = {
|
||||
.qdev.name = "OHCI USB PCI",
|
||||
.qdev.alias = "pci-ohci",
|
||||
.qdev.name = "pci-ohci",
|
||||
.qdev.desc = "Apple USB Controller",
|
||||
.qdev.size = sizeof(OHCIPCIState),
|
||||
.init = usb_ohci_initfn_pci,
|
||||
|
@ -577,7 +577,7 @@ static USBDevice *usb_serial_init(const char *filename)
|
||||
if (!cdrv)
|
||||
return NULL;
|
||||
|
||||
dev = usb_create(NULL /* FIXME */, "QEMU USB Serial");
|
||||
dev = usb_create(NULL /* FIXME */, "usb-serial");
|
||||
qdev_prop_set_chr(&dev->qdev, "chardev", cdrv);
|
||||
if (vendorid)
|
||||
qdev_prop_set_uint16(&dev->qdev, "vendorid", vendorid);
|
||||
@ -597,7 +597,7 @@ static USBDevice *usb_braille_init(const char *unused)
|
||||
if (!cdrv)
|
||||
return NULL;
|
||||
|
||||
dev = usb_create(NULL /* FIXME */, "QEMU USB Braille");
|
||||
dev = usb_create(NULL /* FIXME */, "usb-braille");
|
||||
qdev_prop_set_chr(&dev->qdev, "chardev", cdrv);
|
||||
qdev_init(&dev->qdev);
|
||||
|
||||
@ -606,8 +606,7 @@ static USBDevice *usb_braille_init(const char *unused)
|
||||
|
||||
static struct USBDeviceInfo serial_info = {
|
||||
.product_desc = "QEMU USB Serial",
|
||||
.qdev.name = "QEMU USB Serial",
|
||||
.qdev.alias = "usb-serial",
|
||||
.qdev.name = "usb-serial",
|
||||
.qdev.size = sizeof(USBSerialState),
|
||||
.init = usb_serial_initfn,
|
||||
.handle_packet = usb_generic_handle_packet,
|
||||
@ -627,8 +626,7 @@ static struct USBDeviceInfo serial_info = {
|
||||
|
||||
static struct USBDeviceInfo braille_info = {
|
||||
.product_desc = "QEMU USB Braille",
|
||||
.qdev.name = "QEMU USB Braille",
|
||||
.qdev.alias = "usb-braille",
|
||||
.qdev.name = "usb-braille",
|
||||
.qdev.size = sizeof(USBSerialState),
|
||||
.init = usb_serial_initfn,
|
||||
.handle_packet = usb_generic_handle_packet,
|
||||
|
@ -1111,12 +1111,12 @@ static int usb_uhci_piix4_initfn(PCIDevice *dev)
|
||||
|
||||
static PCIDeviceInfo uhci_info[] = {
|
||||
{
|
||||
.qdev.name = "PIIX3 USB-UHCI",
|
||||
.qdev.name = "piix3-usb-uhci",
|
||||
.qdev.size = sizeof(UHCIState),
|
||||
.qdev.vmsd = &vmstate_uhci,
|
||||
.init = usb_uhci_piix3_initfn,
|
||||
},{
|
||||
.qdev.name = "PIIX4 USB-UHCI",
|
||||
.qdev.name = "piix4-usb-uhci",
|
||||
.qdev.size = sizeof(UHCIState),
|
||||
.qdev.vmsd = &vmstate_uhci,
|
||||
.init = usb_uhci_piix4_initfn,
|
||||
@ -1133,10 +1133,10 @@ device_init(uhci_register);
|
||||
|
||||
void usb_uhci_piix3_init(PCIBus *bus, int devfn)
|
||||
{
|
||||
pci_create_simple(bus, devfn, "PIIX3 USB-UHCI");
|
||||
pci_create_simple(bus, devfn, "piix3-usb-uhci");
|
||||
}
|
||||
|
||||
void usb_uhci_piix4_init(PCIBus *bus, int devfn)
|
||||
{
|
||||
pci_create_simple(bus, devfn, "PIIX4 USB-UHCI");
|
||||
pci_create_simple(bus, devfn, "piix4-usb-uhci");
|
||||
}
|
||||
|
@ -410,8 +410,8 @@ static int usb_wacom_initfn(USBDevice *dev)
|
||||
|
||||
static struct USBDeviceInfo wacom_info = {
|
||||
.product_desc = "QEMU PenPartner Tablet",
|
||||
.qdev.name = "QEMU PenPartner Tablet",
|
||||
.qdev.alias = "wacom-tablet",
|
||||
.qdev.name = "usb-wacom-tablet",
|
||||
.qdev.desc = "QEMU PenPartner Tablet",
|
||||
.usbdevice_name = "wacom-tablet",
|
||||
.qdev.size = sizeof(USBWacomState),
|
||||
.init = usb_wacom_initfn,
|
||||
|
@ -1196,11 +1196,11 @@ static int pci_vmsvga_initfn(PCIDevice *dev)
|
||||
|
||||
void pci_vmsvga_init(PCIBus *bus)
|
||||
{
|
||||
pci_create_simple(bus, -1, "QEMUware SVGA");
|
||||
pci_create_simple(bus, -1, "vmware-svga");
|
||||
}
|
||||
|
||||
static PCIDeviceInfo vmsvga_info = {
|
||||
.qdev.name = "QEMUware SVGA",
|
||||
.qdev.name = "vmware-svga",
|
||||
.qdev.size = sizeof(struct pci_vmsvga_state_s),
|
||||
.qdev.vmsd = &vmstate_vmware_vga,
|
||||
.init = pci_vmsvga_initfn,
|
||||
|
@ -361,7 +361,7 @@ USBDevice *usb_host_device_open(const char *devname)
|
||||
goto fail;
|
||||
}
|
||||
|
||||
d = usb_create(NULL /* FIXME */, "USB Host Device");
|
||||
d = usb_create(NULL /* FIXME */, "usb-host");
|
||||
dev = DO_UPCAST(USBHostDevice, dev, d);
|
||||
|
||||
if (dev_info.udi_speed == 1)
|
||||
@ -394,7 +394,7 @@ fail:
|
||||
|
||||
static struct USBDeviceInfo usb_host_dev_info = {
|
||||
.product_desc = "USB Host Device",
|
||||
.qdev.name = "USB Host Device",
|
||||
.qdev.name = "usb-host",
|
||||
.qdev.size = sizeof(USBHostDevice),
|
||||
.init = usb_host_initfn,
|
||||
.handle_packet = usb_generic_handle_packet,
|
||||
|
@ -980,8 +980,7 @@ static int usb_host_initfn(USBDevice *dev)
|
||||
|
||||
static struct USBDeviceInfo usb_host_dev_info = {
|
||||
.product_desc = "USB Host Device",
|
||||
.qdev.name = "USB Host Device",
|
||||
.qdev.alias = "usb-host",
|
||||
.qdev.name = "usb-host",
|
||||
.qdev.size = sizeof(USBHostDevice),
|
||||
.init = usb_host_initfn,
|
||||
.handle_packet = usb_host_handle_packet,
|
||||
@ -1011,7 +1010,7 @@ USBDevice *usb_host_device_open(const char *devname)
|
||||
USBHostDevice *s;
|
||||
char *p;
|
||||
|
||||
dev = usb_create(NULL /* FIXME */, "USB Host Device");
|
||||
dev = usb_create(NULL /* FIXME */, "usb-host");
|
||||
s = DO_UPCAST(USBHostDevice, dev, dev);
|
||||
|
||||
if (strstr(devname, "auto:")) {
|
||||
|
Loading…
Reference in New Issue
Block a user