[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH v3 04/11] vpci/header: Add and remove register handlers dynamically
- To: Jan Beulich <jbeulich@xxxxxxxx>
- From: Oleksandr Andrushchenko <Oleksandr_Andrushchenko@xxxxxxxx>
- Date: Mon, 4 Oct 2021 05:58:20 +0000
- Accept-language: en-US
- Arc-authentication-results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=epam.com; dmarc=pass action=none header.from=epam.com; dkim=pass header.d=epam.com; arc=none
- Arc-message-signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=Or5bN5AFgnGV9W2xYcfJ1mgb0piJ8h17FuIPymu2rQo=; b=YuWSZPK4mb60ah32UWfKN2CXoTaEKv5KIzdU5qHCHmTX7n3m+nKUpUPYJVU4uXfgVqYZ9p/vkUyng+Z4uaJbSUfrz2P1NT0/egy65yLrazTBc/8f4fYULzBrg0uNxiPdeUhCR/qO7aJmr6HvSQjpdL97Hlq89jbUmWTE/ZLJkf2kRoEkdb0sRqPOJqd/kUVQukTxpxUsSe4LcjKHZZFP+Zogyp1+tl77iuAJQP/qBmndLgaG7s2+VyP3R9WP8csz8da5IGnvkBaOui3kFNAL8r95s9o94ZBOvAX+9T1fkSoW2/meXpJ0+buGDV8A7lkJaBbj+wSxFsh48L+rdSzq6A==
- Arc-seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=moWQp0X0lh74gaXilzCwfi4JBDX9c8aBFkhRzqF9yhmt+vqT51NwaD/ka2H6OGiajLmIp4U6rlU4MFhz3uw6e7OdxshRNUji+UAsLbdnT0jYqA7YlYupCNCG2m3iDwGIszyFRt5YkNFnWpZ4Q13XlcE7/QitGmU9pvJPh1tzM51hvvcQDQzj1Iv8Vyp0JJ9ESv3gu6eZUjMZzi61vGajEq5k2meqVSF835nJ009YrVMPQZbJb8996ldNPpqh1JwW5/5ohAsxzDyXVgZvIK/ShjAvUkdWW7GUD+gn+cYU1MV6zGfZtlT9zHp2jgWHhDb/5xVb/7BlIWYtd+JvNMy1qw==
- Authentication-results: suse.com; dkim=none (message not signed) header.d=none;suse.com; dmarc=none action=none header.from=epam.com;
- Cc: "julien@xxxxxxx" <julien@xxxxxxx>, "sstabellini@xxxxxxxxxx" <sstabellini@xxxxxxxxxx>, Oleksandr Tyshchenko <Oleksandr_Tyshchenko@xxxxxxxx>, Volodymyr Babchuk <Volodymyr_Babchuk@xxxxxxxx>, Artem Mygaiev <Artem_Mygaiev@xxxxxxxx>, "roger.pau@xxxxxxxxxx" <roger.pau@xxxxxxxxxx>, Bertrand Marquis <bertrand.marquis@xxxxxxx>, Rahul Singh <rahul.singh@xxxxxxx>, "xen-devel@xxxxxxxxxxxxxxxxxxxx" <xen-devel@xxxxxxxxxxxxxxxxxxxx>, Oleksandr Andrushchenko <Oleksandr_Andrushchenko@xxxxxxxx>
- Delivery-date: Mon, 04 Oct 2021 05:58:46 +0000
- List-id: Xen developer discussion <xen-devel.lists.xenproject.org>
- Thread-index: AQHXtdAhL3wGQmCTxkGG8eG4L2Ylc6u+JFCAgAQ5ugA=
- Thread-topic: [PATCH v3 04/11] vpci/header: Add and remove register handlers dynamically
On 01.10.21 16:26, Jan Beulich wrote:
> On 30.09.2021 09:52, Oleksandr Andrushchenko wrote:
>> @@ -445,14 +456,25 @@ static void rom_write(const struct pci_dev *pdev,
>> unsigned int reg,
>> rom->addr = val & PCI_ROM_ADDRESS_MASK;
>> }
>>
>> -static int add_bar_handlers(const struct pci_dev *pdev)
>> +static void guest_rom_write(const struct pci_dev *pdev, unsigned int reg,
>> + uint32_t val, void *data)
>> +{
>> +}
>> +
>> +static uint32_t guest_rom_read(const struct pci_dev *pdev, unsigned int reg,
>> + void *data)
>> +{
>> + return 0xffffffff;
>> +}
>> +
>> +static int add_bar_handlers(const struct pci_dev *pdev, bool is_hwdom)
> I remain unconvinced that this boolean is the best way to go here,
I can remove "bool is_hwdom" and have the checks like:
static int add_bar_handlers(const struct pci_dev *pdev)
{
...
if ( is_hardware_domain(pdev->domain) )
rc = vpci_add_register(pdev->vpci, vpci_hw_read16, cmd_write,
PCI_COMMAND, 2, header);
else
rc = vpci_add_register(pdev->vpci, vpci_hw_read16, guest_cmd_write,
PCI_COMMAND, 2, header);
Is this going to be better?
> but
> I'll leave the decision there to Roger. Just a couple of nits:
>
>> @@ -593,6 +625,30 @@ static int init_bars(struct pci_dev *pdev)
>> }
>> REGISTER_VPCI_INIT(init_bars, VPCI_PRIORITY_MIDDLE);
>>
>> +#ifdef CONFIG_HAS_VPCI_GUEST_SUPPORT
>> +int vpci_bar_add_handlers(const struct domain *d, const struct pci_dev
>> *pdev)
>> +{
>> + int rc;
>> +
>> + /* Remove previously added registers. */
>> + vpci_remove_device_registers(pdev);
>> +
>> + rc = add_bar_handlers(pdev, is_hardware_domain(d));
>> + if ( rc )
>> + gdprintk(XENLOG_ERR,
>> + "%pp: failed to add BAR handlers for dom%pd: %d\n",
> Only %pd please, as that already expands to d<num>.
Good catch, thank you!
>
>> + &pdev->sbdf, d, rc);
>> + return rc;
> Blank line please ahead of the main return statement of a function.
Will add
>
> Jan
>
Thank you,
Oleksandr
|