From: Alex Williamson <alex.williamson@redhat.com>
To: Abhishek Sahu <abhsahu@nvidia.com>
Cc: Jason Gunthorpe <jgg@nvidia.com>,
Cornelia Huck <cohuck@redhat.com>,
Yishai Hadas <yishaih@nvidia.com>,
Shameer Kolothum <shameerali.kolothum.thodi@huawei.com>,
Kevin Tian <kevin.tian@intel.com>,
"Rafael J . Wysocki" <rafael@kernel.org>,
Max Gurtovoy <mgurtovoy@nvidia.com>,
Bjorn Helgaas <bhelgaas@google.com>,
linux-kernel@vger.kernel.org, kvm@vger.kernel.org,
linux-pm@vger.kernel.org, linux-pci@vger.kernel.org
Subject: Re: [PATCH v5 1/5] vfio: Add the device features for the low power entry and exit
Date: Mon, 1 Aug 2022 12:42:53 -0600 [thread overview]
Message-ID: <20220801124253.11c24d91.alex.williamson@redhat.com> (raw)
In-Reply-To: <f903e2b9-f85b-a4c8-4706-f463919723a3@nvidia.com>
On Wed, 27 Jul 2022 11:37:02 +0530
Abhishek Sahu <abhsahu@nvidia.com> wrote:
> On 7/26/2022 10:53 PM, Jason Gunthorpe wrote:
> > On Tue, Jul 26, 2022 at 06:17:18PM +0530, Abhishek Sahu wrote:
> >> Thanks Alex for your thorough review of uAPI.
> >> I have incorporated all the suggestions.
> >> Following is the updated uAPI.
> >>
> >> /*
> >> * Upon VFIO_DEVICE_FEATURE_SET, allow the device to be moved into a low power
> >> * state with the platform-based power management. Device use of lower power
> >> * states depends on factors managed by the runtime power management core,
> >> * including system level support and coordinating support among dependent
> >> * devices. Enabling device low power entry does not guarantee lower power
> >> * usage by the device, nor is a mechanism provided through this feature to
> >> * know the current power state of the device. If any device access happens
> >> * (either from the host or through the vfio uAPI) when the device is in the
> >> * low power state, then the host will move the device out of the low power
> >> * state as necessary prior to the access. Once the access is completed, the
> >> * device may re-enter the low power state. For single shot low power support
> >> * with wake-up notification, see
> >> * VFIO_DEVICE_FEATURE_LOW_POWER_ENTRY_WITH_WAKEUP below. Access to mmap'd
> >> * device regions is disabled on LOW_POWER_ENTRY and may only be resumed after
> >> * calling LOW_POWER_EXIT.
> >> */
> >> #define VFIO_DEVICE_FEATURE_LOW_POWER_ENTRY 3
> >>
> >> /*
> >> * This device feature has the same behavior as
> >> * VFIO_DEVICE_FEATURE_LOW_POWER_ENTRY with the exception that the user
> >> * provides an eventfd for wake-up notification.
> >
> > It feels like this should be one entry point instead of two.
> >
> > A flag "automatic re-sleep" and an optional eventfd (-1 means not
> > provided) seems to capture both of these behaviors in a bit clearer
> > and extendable way.
I think the mutual exclusion between re-entrant mode and one-shot is
quite a bit more subtle in the version below, so I don't particularly
find this cleaner. Potentially we could have variant drivers support
one w/o the other in the previously proposed model as well. It's
interesting to see this suggestion since since we seem to have a theme
of making features single purpose elsewhere. Thanks,
Alex
>
> We discussed about that in the earlier version of the patch series.
> Since we have different exit related handling, so to avoid confusion
> we proceeded with 2 separate variants for the low power entry. Also,
> we don't need any parameter for the first case.
>
> But, I can do the changes to make a single entry point, if we conclude
> for that.
>
> From my side, I have explored how the uAPI looks like if
> we go with this approach.
>
> /*
> * Upon VFIO_DEVICE_FEATURE_SET, allow the device to be moved into a low power
> * state with the platform-based power management. Device use of lower power
> * states depends on factors managed by the runtime power management core,
> * including system level support and coordinating support among dependent
> * devices. Enabling device low power entry does not guarantee lower power
> * usage by the device, nor is a mechanism provided through this feature to
> * know the current power state of the device. If any device access happens
> * (either from the host or through the vfio uAPI) when the device is in the
> * low power state, then the host will move the device out of the low power
> * state as necessary prior to the access. Once the access is completed, the
> * device re-entry to a low power state will be controlled through
> * VFIO_DEVICE_LOW_POWER_REENTERY_DISABLE flag.
> *
> * If LOW_POWER_REENTERY_DISABLE flag is not set, the device may re-enter the
> * low power state. Access to mmap'd device regions is disabled on
> * LOW_POWER_ENTRY and may only be resumed after calling LOW_POWER_EXIT.
> *
> * If LOW_POWER_REENTERY_DISABLE flag is set, then user needs to provide an
> * eventfd for wake-up notification. When the device moves out of the low
> * power state for the wake-up, the host will not allow the device to re-enter
> * a low power state without a subsequent user call to LOW_POWER_ENTRY.
> * Access to mmap'd device regions is disabled on LOW_POWER_ENTRY and may only
> * be resumed after the low power exit. The low power exit can happen either
> * through LOW_POWER_EXIT or through any other access (where the wake-up
> * notification has been generated). The access to mmap'd device regions will
> * not trigger low power exit.
> *
> * The notification through the provided eventfd will be generated only when
> * the device has entered and is resumed from a low power state after
> * calling this device feature IOCTL. A device that has not entered low power
> * state, as managed through the runtime power management core, will not
> * generate a notification through the provided eventfd on access. Calling the
> * LOW_POWER_EXIT feature is optional in the case where notification has been
> * signaled on the provided eventfd that a resume from low power has occurred.
> *
> * The wakeup_eventfd needs to be valid only if LOW_POWER_REENTERY_DISABLE
> * flag is set, otherwise, it will be ignored.
> */
> #define VFIO_DEVICE_FEATURE_LOW_POWER_ENTRY 3
>
> struct vfio_device_low_power_entry_with_wakeup {
> __u32 flags;
> #define VFIO_DEVICE_LOW_POWER_REENTERY_DISABLE (1 << 0)
> __s32 wakeup_eventfd;
> };
>
> /*
> * Upon VFIO_DEVICE_FEATURE_SET, disallow use of device low power states as
> * previously enabled via VFIO_DEVICE_FEATURE_LOW_POWER_ENTRY device feature.
> * This device feature IOCTL may itself generate a wakeup eventfd notification
> * if the device had previously entered a low power state with
> * VFIO_DEVICE_LOW_POWER_REENTERY_DISABLE flag set.
> */
> #define VFIO_DEVICE_FEATURE_LOW_POWER_EXIT 4
>
> Thanks,
> Abhishek
>
next prev parent reply other threads:[~2022-08-01 18:43 UTC|newest]
Thread overview: 26+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-07-19 12:15 [PATCH v5 0/5] vfio/pci: power management changes Abhishek Sahu
2022-07-19 12:15 ` [PATCH v5 1/5] vfio: Add the device features for the low power entry and exit Abhishek Sahu
2022-07-21 22:34 ` Alex Williamson
2022-07-25 14:40 ` Abhishek Sahu
2022-07-25 22:09 ` Alex Williamson
2022-07-26 12:47 ` Abhishek Sahu
2022-07-26 13:13 ` Cornelia Huck
2022-07-26 14:17 ` Alex Williamson
2022-07-26 17:23 ` Jason Gunthorpe
2022-07-27 6:07 ` Abhishek Sahu
2022-08-01 18:42 ` Alex Williamson [this message]
2022-08-02 14:04 ` Jason Gunthorpe
2022-08-02 15:41 ` Alex Williamson
2022-08-02 16:35 ` Jason Gunthorpe
2022-08-02 16:57 ` Alex Williamson
2022-08-02 17:01 ` Jason Gunthorpe
2022-08-03 6:32 ` Abhishek Sahu
2022-07-19 12:15 ` [PATCH v5 2/5] vfio: Increment the runtime PM usage count during IOCTL call Abhishek Sahu
2022-07-21 22:34 ` Alex Williamson
2022-07-19 12:15 ` [PATCH v5 3/5] vfio/pci: Mask INTx during runtime suspend Abhishek Sahu
2022-07-19 12:15 ` [PATCH v5 4/5] vfio/pci: Implement VFIO_DEVICE_FEATURE_LOW_POWER_ENTRY/EXIT Abhishek Sahu
2022-07-21 22:34 ` Alex Williamson
2022-07-25 14:48 ` Abhishek Sahu
2022-07-19 12:15 ` [PATCH v5 5/5] vfio/pci: Implement VFIO_DEVICE_FEATURE_LOW_POWER_ENTRY_WITH_WAKEUP Abhishek Sahu
2022-07-21 22:34 ` Alex Williamson
2022-07-25 15:04 ` Abhishek Sahu
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20220801124253.11c24d91.alex.williamson@redhat.com \
--to=alex.williamson@redhat.com \
--cc=abhsahu@nvidia.com \
--cc=bhelgaas@google.com \
--cc=cohuck@redhat.com \
--cc=jgg@nvidia.com \
--cc=kevin.tian@intel.com \
--cc=kvm@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-pci@vger.kernel.org \
--cc=linux-pm@vger.kernel.org \
--cc=mgurtovoy@nvidia.com \
--cc=rafael@kernel.org \
--cc=shameerali.kolothum.thodi@huawei.com \
--cc=yishaih@nvidia.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).