From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751899AbcF3JKg (ORCPT ); Thu, 30 Jun 2016 05:10:36 -0400 Received: from prv-mh.provo.novell.com ([137.65.248.74]:57566 "EHLO prv-mh.provo.novell.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751601AbcF3JK2 convert rfc822-to-8bit (ORCPT ); Thu, 30 Jun 2016 05:10:28 -0400 Message-Id: <5774FE1302000078000F9FED@prv-mh.provo.novell.com> X-Mailer: Novell GroupWise Internet Agent 14.2.0 Date: Thu, 30 Jun 2016 03:10:11 -0600 From: "Jan Beulich" To: "Andrew Cooper" , "Vitaly Kuznetsov" Cc: "David Vrabel" , "Stefano Stabellini" , , "Thomas Gleixner" , , "Boris Ostrovsky" , "Ingo Molnar" , "Juergen Gross" , , "H. Peter Anvin" Subject: Re: [Xen-devel] [PATCH linux 2/8] xen: introduce xen_vcpu_id mapping References: <1467132449-1030-1-git-send-email-vkuznets@redhat.com> <1467132449-1030-3-git-send-email-vkuznets@redhat.com> <87shvwur5p.fsf@vitty.brq.redhat.com> <689743e6-0b0e-9935-58e1-2dfa257c7bf8@citrix.com> <87oa6kupko.fsf@vitty.brq.redhat.com> <87k2h8ufw0.fsf@vitty.brq.redhat.com> <5040c916-279f-c350-383a-583ec1700686@citrix.com> In-Reply-To: <5040c916-279f-c350-383a-583ec1700686@citrix.com> Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 8BIT Content-Disposition: inline Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org >>> On 29.06.16 at 18:27, wrote: > On 29/06/16 17:19, Vitaly Kuznetsov wrote: >> To explain better what I'm trying to suggest here please take a look at >> the attached patch. If we can guarantee long term that ACPI id always >> equals to Xen's idea of vCPU id this is probably the easiest way. >> >> -- Vitaly > > The code in hvmloader which sets up the MADT does: > > for ( i = 0; i < hvm_info->nr_vcpus; i++ ) > { > memset(lapic, 0, sizeof(*lapic)); > lapic->type = ACPI_PROCESSOR_LOCAL_APIC; > lapic->length = sizeof(*lapic); > /* Processor ID must match processor-object IDs in the DSDT. */ > lapic->acpi_processor_id = i; > lapic->apic_id = LAPIC_ID(i); > lapic->flags = (test_bit(i, hvm_info->vcpu_online) > ? ACPI_LOCAL_APIC_ENABLED : 0); > lapic++; > } > > So relying on the acpi_processor_id does look to be reliable. That code > hasn't changed since 2007, and that was only a bugfix. I would go so > far as to say it is reasonable for us to guarantee this in the guest ABI. In fact - is there any other way a guest could learn the vCPU IDs of its CPUs in a reliable way? I don't think so, and hence this de facto already is part of the ABI; we should of course spell it out somewhere. Jan