From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:35448) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1bzcFI-0008Jv-Au for qemu-devel@nongnu.org; Thu, 27 Oct 2016 00:24:55 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1bzcFF-0007FK-Tc for qemu-devel@nongnu.org; Thu, 27 Oct 2016 00:24:52 -0400 Date: Thu, 27 Oct 2016 13:38:24 +1100 From: David Gibson Message-ID: <20161027023824.GF19918@umbus.fritz.box> References: <1477519165-30974-1-git-send-email-mdroth@linux.vnet.ibm.com> MIME-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha256; protocol="application/pgp-signature"; boundary="Y/WcH0a6A93yCHGr" Content-Disposition: inline In-Reply-To: <1477519165-30974-1-git-send-email-mdroth@linux.vnet.ibm.com> Subject: Re: [Qemu-devel] [PATCH v2 0/6] spapr: dedicated hotplug events and memory unplug support List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Michael Roth Cc: qemu-devel@nongnu.org, qemu-ppc@nongnu.org, bharata@linux.vnet.ibm.com, nfont@linux.vnet.ibm.com, jallen@linux.vnet.ibm.com --Y/WcH0a6A93yCHGr Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Content-Transfer-Encoding: quoted-printable On Wed, Oct 26, 2016 at 04:59:19PM -0500, Michael Roth wrote: > This series is based on David's ppc-for-2.8 branch, and is also available= from: >=20 > https://github.com/mdroth/qemu/commits/spapr-hotplug-event-update Applied to ppc-for-2.8. >=20 > Changes since v1: > * Rebased on latest ppc-for-2.8 > * Dropped patches relating to option vector manipulation (now merged) > * Moved patch introducing modern-hotplug-events option to come after > that actual implementation of modern-hotplug-events support. (David) > * Removed uneeded source name string from sPAPREventSource in favor of > manual lookup of the name when creating DT. (David) > * Don't split function return signatures across lines (David) > * Add comment to clarify hotplug events being enabled regardless > of CAS-negotiation. > * Avoid unecessary initialization of hotplug_ctrl in > spapr_lmb_release. (David) >=20 > Changes since RFC: > * Rebased on latest ppc-for-2.8 (with DT refactoring) > * Submitting as v1 now that PAPR Hotplug ACR is committed > * address Patchew warnings > * add comments to clarify spapr->ov5/ov5_cas usage. (David) > * revise comment to clarify intent when setting spapr->ov5 > OV5_HP_EVT bit. (Bharata) > * drop internal usage of spapr_ovec_from_bitmap() in favor of > directly assigning bitmap to sPAPROptionVector instances. (David) > * standardize meaning of 'vector_len' variable through spapr_ovec_* > functions to be the byte-wise length of option vectors entries, > and not including the preceeding length byte itself. (David) > * fix spapr_ovec_populate_dt() to parse up to OV_MAXBITS bits > rather than OV_MAXBITS - 1. (David) > * fix spapr_ovec_populate_dt() encode the minimum of 1 option > vector byte instead of the max of OV_MAXBYTES in cases where > no option bits are set. (David) > * add some comments to spapr_ovec_populate_dt() to clarify what > is being encoded into length byte of ibm,architecture-vec-5 > * switch 'legacy-hotplug-events' option to > 'modern-hotplug-events' (David) > * modify rtas_event_log_to_source() to check for OV5_HP_EVT > option rather than relying on whether the hotplug source is > specifically enabled. Assert the latter in cases where > OV5_HP_EVT is set. (Bharata) > * drop global EventSource list in favor of an sPAPREventSource > list field within sPAPRMachineState (David) > * add CPU unplug hook in mc->unplug_request (Bharata) >=20 >=20 > Patches 1-4 add support for an updated event format for hotplug events, > which includes a new way to specify a range of DRCs/LMBs to hotplug/unplug > using a starting position and count, which is necessary for memory unplug. >=20 > Patches 5-6 add support for memory unplug using the new event format. >=20 > In addition to kernel 4.8 or later, there are a number of patches required > to enable support on the guest kernel side. I've including the minimum set > of patches in my branch here: >=20 > https://github.com/mdroth/linux/commits/spapr-hotplug-event-update >=20 > *powerpc/pseries: advertise Hot Plug Event support to firmware > powerpc/pseries: Implement indexed-count hotplug memory remove > powerpc/pseries: Implement indexed-count hotplug memory add >=20 > Note that there is currently an issue that arises when attempting to > offline an LMB that was onlined using a guest kernel's auto-onlining > mechanism, which can prevent full completion of memory unplug requests. > This is being investigated, but for the purposes of testing this can > be worked around currently by disabling auto-onlining in guests via: >=20 > "echo offline >/sys/devices/system/memory/auto_online_blocks" >=20 > and instead onlining the blocks manually or via udev. >=20 > docs/specs/ppc-spapr-hotplug.txt | 55 +++++++++++++++++++++++++++------ > hw/ppc/spapr.c | 178 +++++++++++++++++++++++++++++++++= ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++----- > hw/ppc/spapr_drc.c | 17 +++++++++++ > hw/ppc/spapr_events.c | 278 +++++++++++++++++++++++++++++++++= +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++= +++++++++++++++++++++++++++------------------------------- > include/hw/ppc/spapr.h | 10 ++++-- > include/hw/ppc/spapr_ovec.h | 1 + > 6 files changed, 469 insertions(+), 70 deletions(-) >=20 --=20 David Gibson | I'll have my music baroque, and my code david AT gibson.dropbear.id.au | minimalist, thank you. NOT _the_ _other_ | _way_ _around_! http://www.ozlabs.org/~dgibson --Y/WcH0a6A93yCHGr Content-Type: application/pgp-signature; name="signature.asc" -----BEGIN PGP SIGNATURE----- Version: GnuPG v2 iQIbBAEBCAAGBQJYEWidAAoJEGw4ysog2bOST84P+KvT6WEQvwgvst4MMLeAZ2OM 4aPKZS/Qrscv+T5ivEZxaE7sEk4CA/IhxbZRdHoA4sJDcRxftNKtEZOeiiVSozZn b0qXhC/fWjbUJigbi6jR6Jzty2oCNcDFvER5kPX+l1GB5vVhNPgtOtmFOR1JwSUV 9VsRthTH1FFybMGhUxFhoCs81nd57LXFZNTkSKrwXLIiWxNeW8qROsZZZ54EEn6U mpUfvB4sAEWys3AGAtTt8KDFovRlILGPdfYykftHbTAlzHHLkTvnEyIQ7uMMhzuA yJCexbImzhPQGeG0L+6bKFkclW1WB5gUPja2R3kYYtbyiFAUqNt2hNWWgOw1Z6Rg N0y30cYGGEmK/MKHZzIjC9+Ua8OjcvNx2vxT6Z4Og9tWIhMjtBa6CqNzTGUXUGeL AszmgRGhSzeHFJlL9VmkebPOoH34SaMr+7M0zO7Gpdegj3mf8bnGPvxrdrIf5cbH PRptk3VONoETEwKH4ew3MZIsl0bVu9WAgGkR69aOGKCOiTw3+i4I7gab7/qpi/F/ F9+VtTcNjqZm1q5RED51Q3KU9tNdW6wXSadstbEHhG3UGJlZ4XKr0ABaIK8OYbkv 2z05h8yDzZAvMTyANTogi7GnVvD99h+0/uYaqiM1ecEmuNF5MdNqCNp0khN4XsXT E1IFpStmaA8q20k/AEQ= =hH2k -----END PGP SIGNATURE----- --Y/WcH0a6A93yCHGr--