From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-pj1-f74.google.com (mail-pj1-f74.google.com [209.85.216.74]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 19F6022578A for ; Mon, 11 Aug 2025 18:25:22 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.216.74 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1754936724; cv=none; b=dY8fUzbRAppNtLLrTjYlq1O32Uv0WhHSKjIhVAh3jEpX+rDHUh3w0SOAByFxFxvKsG7c6URYbwBOtOdeV+A0jUCfaaO+Oc7TRtQ0uTT+t0XBrXup5p7A9sqTALoPYnHZ3G/o8yIO+AspaztJgKeEK4CpnJjK5Y5jXEXJml4Yeto= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1754936724; c=relaxed/simple; bh=+RaoGEfqODQpjds3+pa5hzUvYCotn9nVbr9q7E3jVBQ=; h=Date:In-Reply-To:Mime-Version:References:Message-ID:Subject:From: To:Cc:Content-Type; b=XclA6YPxXhj2bonUd7bKVWcL2QwA2uehUbMiZMx+0Qi/nGmWK5hwx3vXmu23zKh/j97sktompIUirEW2fJrR9u0XTXbL+ITdoQEbkKmh9VOTsXg6hxqJ0P3fx1n2AnxUgLxLuKJDjEG68lHo7dbTPe9uSoYwsXAVxZ6T8MTWAyE= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=google.com; spf=pass smtp.mailfrom=flex--seanjc.bounces.google.com; dkim=pass (2048-bit key) header.d=google.com header.i=@google.com header.b=Pu7u48aC; arc=none smtp.client-ip=209.85.216.74 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=google.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=flex--seanjc.bounces.google.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=google.com header.i=@google.com header.b="Pu7u48aC" Received: by mail-pj1-f74.google.com with SMTP id 98e67ed59e1d1-31f2a98d91eso4441029a91.3 for ; Mon, 11 Aug 2025 11:25:22 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20230601; t=1754936722; x=1755541522; darn=vger.kernel.org; h=cc:to:from:subject:message-id:references:mime-version:in-reply-to :date:from:to:cc:subject:date:message-id:reply-to; bh=GkymeW9oJwqBHxAPtMhP6NoKFqSvnGj/TBIK2S4XTUo=; b=Pu7u48aChQ7x3AINRl4vlr1YlUJa3elREij6oAYsxdM3mPq5g4/wZGB9WWgJhbRxi7 B+CvxTPfX+xM5e8WeLqQJvNZ48UfZ4kkOQyfdYjSGbX0h+F1hKF12Xt8lWeuY56wxdOD ijelmJC8G9NA+klOXh6Iq74Ww39uk2cpqjM0rc9J4sSgEVVtNkaB0rZ/D1lrA5IVaZGS oKTmavfw7gH2kSarBfkLCjxnnaZwn9C+RFCS5J5FV3Fbrxd5b/Jv4Tm2UvGSFApTztc5 U+phlYpAUhgTnHvtO4AEUncwi+qaeVqhdsNrImcKXoAaU3i3Ho2bzyio1dxBT2nnpNuI EAwA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1754936722; x=1755541522; h=cc:to:from:subject:message-id:references:mime-version:in-reply-to :date:x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=GkymeW9oJwqBHxAPtMhP6NoKFqSvnGj/TBIK2S4XTUo=; b=t9jfVEcnfyHim4dNaiocBm9nItS1ipjyUJWPV4aB97LT43aADM7Q7zPlT0qPkc9fz2 3BTJSbkKCVn5nRmGQqasCNYHzxJ5xa0eUEgr/K/XVeaW8uvz2unzzTuJJqD2W0RTBKv1 7OMmY7+bd4YdmzaFUpwsr1tWa8lmUk0+lSfhZonRFDw/k6pWLgTPS2aTaLHmU27WwHfV XuBpE3njak2OtZWzWLaAS8dByhS3KSJLpS/+oF5xRwdad0qJb/XmReOQa0/h4nEllT1z 6iTYJA3xfxre4fskzUKwyLgG+JUXG07cgjaWjK0l8y0c3Bu99cLkJY8341axv4wJLq7D 1a4Q== X-Forwarded-Encrypted: i=1; AJvYcCVX15Hh/J+F/QPc195LHQv5swOjFSYbDou9kIddTUu04xlqcnm/u54K+jQAlHhR4HN0LxQ=@vger.kernel.org X-Gm-Message-State: AOJu0YyGfryjI7OQY2O/Wc1emsUht4T9nCArTV2jKVOXbU08hFBsbVdz lz73uqCItPSGqxTzucdVnZ83abYhwKoAkQHR9D400OSSh1qO+3ZKF0R7wshaYu3CqOXog/BgHip k199MDA== X-Google-Smtp-Source: AGHT+IHhf+u8DAgFU8Tb7yj1qaPeuXMKCvgtRgZ1OiwVl9wM0oGpeZSCJHlG1M98vl/B3sySbxtqsUMXd2U= X-Received: from pjbsj7.prod.google.com ([2002:a17:90b:2d87:b0:31f:232:1fae]) (user=seanjc job=prod-delivery.src-stubby-dispatcher) by 2002:a17:90a:fc4d:b0:312:e6f1:c05d with SMTP id 98e67ed59e1d1-321c09df627mr727122a91.2.1754936722399; Mon, 11 Aug 2025 11:25:22 -0700 (PDT) Date: Mon, 11 Aug 2025 11:25:20 -0700 In-Reply-To: <20250807201628.1185915-5-sagis@google.com> Precedence: bulk X-Mailing-List: kvm@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: Mime-Version: 1.0 References: <20250807201628.1185915-1-sagis@google.com> <20250807201628.1185915-5-sagis@google.com> Message-ID: Subject: Re: [PATCH v8 04/30] KVM: selftests: Add vCPU descriptor table initialization utility From: Sean Christopherson To: Sagi Shahar Cc: linux-kselftest@vger.kernel.org, Paolo Bonzini , Shuah Khan , Ackerley Tng , Ryan Afranji , Andrew Jones , Isaku Yamahata , Erdem Aktas , Rick Edgecombe , Roger Wang , Binbin Wu , Oliver Upton , "Pratik R. Sampat" , Reinette Chatre , Ira Weiny , linux-kernel@vger.kernel.org, kvm@vger.kernel.org Content-Type: text/plain; charset="us-ascii" On Thu, Aug 07, 2025, Sagi Shahar wrote: > From: Ackerley Tng > > Turn vCPU descriptor table initialization into a utility for use by tests > needing finer control, for example for TDX TD creation. NAK. "needing finer control" is not a sufficient explanation for why _this_ patch is necessary. There's also zero argument made throughout any of these patches as to why this pattern: vm = td_create(); td_initialize(vm, VM_MEM_SRC_ANONYMOUS, 0); vcpu = td_vcpu_add(vm, 0, guest_io_writes); td_finalize(vm); is the best approach. IMO it is NOT the best approach. I would much rather we structure things so that creating TDs can use APIs like this: static inline struct kvm_vm *td_create_with_vcpus(uint32_t nr_vcpus, void *guest_code, struct kvm_vcpu *vcpus[]) { return __vm_create_with_vcpus(VM_SHAPE_TDX, nr_vcpus, 0, guest_code, vcpus); } instead of open coding an entirely different set of APIs for creating TDs, which is not maintanable.