From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 86726C433FE for ; Thu, 6 Oct 2022 17:11:49 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230469AbiJFRLs (ORCPT ); Thu, 6 Oct 2022 13:11:48 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48084 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229991AbiJFRLr (ORCPT ); Thu, 6 Oct 2022 13:11:47 -0400 Received: from mail-pl1-x649.google.com (mail-pl1-x649.google.com [IPv6:2607:f8b0:4864:20::649]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id CB869A50F0 for ; Thu, 6 Oct 2022 10:11:45 -0700 (PDT) Received: by mail-pl1-x649.google.com with SMTP id n10-20020a170902e54a00b001782663dcaeso1643741plf.18 for ; Thu, 06 Oct 2022 10:11:45 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20210112; h=cc:to:from:subject:message-id:mime-version:date:from:to:cc:subject :date:message-id:reply-to; bh=ouKg7TyCIdZkg1NWdjg7eNYnq70p2SefFVvR7Lkt1MY=; b=LssfsNIxBXo//o5yVMpFCPXp+s4z3rqFTTa669U5mPMzlNHICB64lUNvNe2dsITMFw Z5hy0+V+8v4FKM8yFtcVVvkWpPtswWD5EMQnlhlhQmliDwqu9nWpoSs3oVntKTtNlVK5 9TzY1wkzZalAmv6/Oe50AJ9w0mAjdMlr6oBlB7k16G2pchn7DbKsf0GBGbMe1RsFpyTc up1t/pAmu5noZthukMGLO0MJNofNCloCccV1pR7c52mjQKAVhjuzpZjm1CZKttXKHx6d /mwzVXVwGBx2kV5rTzDBBFFmd4gNQuY6dctEY+knF5wbKyxswe1Xwn9yXI7/t0u9ActV wfVA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=cc:to:from:subject:message-id:mime-version:date:x-gm-message-state :from:to:cc:subject:date:message-id:reply-to; bh=ouKg7TyCIdZkg1NWdjg7eNYnq70p2SefFVvR7Lkt1MY=; b=37PUcXr1T4/eIZcl2goxSYKQmi5+M2S9McWO3tirGUHplrmk+KhjN0Jqqp6Vad7Jip ucqF4UhIItEVy+bPwSCZ9ByyN8Ln4JLPpI/yaL05hVQ+9h2SM3HW/WpKyggxae4lIa4l 2OsmKhTW2bLk+EAg2/WQxVEuGInT3Opd/kLsmB8rgevM4VW2eNTBlGx8xvpEU78Yl/He isH/z1DQV3+rdHf/xGWVH1lzHdIoolVvNmFPyIfXq9N5yGwQctaK2RMU2dQIzmlhO5EY +8nADcPfmjGhIO4nr6ppNjD6y+RsYSxzFhCcqaFEgA2ZmuhkqUs8uF9Shnig3cFvwNJX cqYQ== X-Gm-Message-State: ACrzQf18JCT4D9mRj9aJcMzqTh2wMoEZ3R7eBP+wvbe0soOB0GX5n0RI ZGvAJwiFCH4gXBvhlx8ZHAB8sY5gaXkt X-Google-Smtp-Source: AMsMyM5NlmMkkHSBr8WvNftrIAfxFk5zNKvA9HEit+kXRza0IekpWLMYKZSPowHl+OOxBmujtveTRzWRdHky X-Received: from vipin.c.googlers.com ([fda3:e722:ac3:cc00:7f:e700:c0a8:479f]) (user=vipinsh job=sendgmr) by 2002:a05:6a00:1808:b0:542:f4f2:86aa with SMTP id y8-20020a056a00180800b00542f4f286aamr478984pfa.28.1665076305334; Thu, 06 Oct 2022 10:11:45 -0700 (PDT) Date: Thu, 6 Oct 2022 10:11:28 -0700 Mime-Version: 1.0 X-Mailer: git-send-email 2.38.0.rc1.362.ged0d419d3c-goog Message-ID: <20221006171133.372359-1-vipinsh@google.com> Subject: [PATCH v4 0/4] dirty_log_perf_test CPU pinning From: Vipin Sharma To: seanjc@google.com, pbonzini@redhat.com, dmatlack@google.com Cc: andrew.jones@linux.dev, kvm@vger.kernel.org, linux-kernel@vger.kernel.org, Vipin Sharma Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: kvm@vger.kernel.org Pin vcpus to a host physical cpus in dirty_log_perf_test and optionally pin the main application thread to a physical cpu if provided. All tests based on perf_test_util framework can take advantage of it if needed. While at it, I changed atoi() to atoi_paranoid() in other tests, sorted command line options alphabetically, and added break between -e and -g which was missed in original commit. v4: - Moved boolean to check vCPUs pinning from perf_test_vcpu_args to perf_test_args. - Changed assert statements to make error more descriptive. - Modified break statement between 'e' and 'g' option in v3 by not copying dirty_log_manual_caps = 0 to 'e'. v3: https://lore.kernel.org/lkml/20220826184500.1940077-1-vipinsh@google.com - Moved atoi_paranoid() to test_util.c and replaced all atoi() usage with atoi_paranoid() - Sorted command line options alphabetically. - Instead of creating a vcpu thread on a specific pcpu the thread will migrate to the provided pcpu after its creation. - Decoupled -e and -g option. v2: https://lore.kernel.org/lkml/20220819210737.763135-1-vipinsh@google.com/ - Removed -d option. - One cpu list passed as option, cpus for vcpus, followed by application thread cpu. - Added paranoid cousin of atoi(). v1: https://lore.kernel.org/lkml/20220817152956.4056410-1-vipinsh@google.com Vipin Sharma (4): KVM: selftests: Add missing break between 'e' and 'g' option in dirty_log_perf_test KVM: selftests: Put command line options in alphabetical order in dirty_log_perf_test KVM: selftests: Add atoi_paranoid() to catch errors missed by atoi() KVM: selftests: Run dirty_log_perf_test on specific CPUs .../selftests/kvm/aarch64/arch_timer.c | 8 +-- .../testing/selftests/kvm/aarch64/vgic_irq.c | 6 +- .../selftests/kvm/access_tracking_perf_test.c | 2 +- .../selftests/kvm/demand_paging_test.c | 2 +- .../selftests/kvm/dirty_log_perf_test.c | 64 +++++++++++++------ .../selftests/kvm/include/perf_test_util.h | 6 ++ .../testing/selftests/kvm/include/test_util.h | 2 + .../selftests/kvm/kvm_page_table_test.c | 2 +- .../selftests/kvm/lib/perf_test_util.c | 58 ++++++++++++++++- tools/testing/selftests/kvm/lib/test_util.c | 18 ++++++ .../selftests/kvm/max_guest_memory_test.c | 6 +- .../kvm/memslot_modification_stress_test.c | 4 +- .../testing/selftests/kvm/memslot_perf_test.c | 10 +-- .../selftests/kvm/set_memory_region_test.c | 2 +- .../selftests/kvm/x86_64/nx_huge_pages_test.c | 4 +- 15 files changed, 149 insertions(+), 45 deletions(-) -- 2.38.0.rc1.362.ged0d419d3c-goog