From patchwork Tue Oct 4 11:52:21 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: =?utf-8?q?Alex_Benn=C3=A9e?= X-Patchwork-Id: 612217 Delivered-To: patch@linaro.org Received: by 2002:a17:522:c983:b0:460:3032:e3c4 with SMTP id kr3csp114805pvb; Tue, 4 Oct 2022 04:53:29 -0700 (PDT) X-Google-Smtp-Source: AMsMyM77UKaxlvRW3VtsF61wcApX2jmjNbk/DayIzlNSP7qgzwMcUMdkuR5TIO7y22dX+iQHpsDV X-Received: by 2002:a05:622a:174a:b0:38b:fc2d:ba86 with SMTP id l10-20020a05622a174a00b0038bfc2dba86mr556876qtk.411.1664884409634; Tue, 04 Oct 2022 04:53:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1664884409; cv=none; d=google.com; s=arc-20160816; b=DjxxoRlbCYA/7hhpHyTjKdr2Khm93DyteGtIyKRR3ao2cpZqmioMq2ZeQdqJ4g8YlR 4qmF2m6iYRPVzKK+S7xdoIdM0Pl/C6m2wO/L6rXXcanVuu+mK/MzYbVWomSgmlfxV91t e6Uu2iYPoyZHvPO3LXCJ5gQwaOZ9A2eiJAU5PRS6bCSWMNq1zSeI/aBnVigVkSdc3mBJ FIq2TNF8NoE+4BhyPGUuga0SjAs59kWq799/ckQqE48/OrS4j6A6UAjkXolmJdbeHOn4 /yFNVEbeRf4BZjL9hzuAShgi1I1B6gTa8n4rHl2hyeU+YSISAbWGZH1uzLwRPe9ZIqTB eozQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:content-transfer-encoding :mime-version:message-id:date:subject:cc:to:from:dkim-signature; bh=Fhd1uL9cZ5nuv6sVBgm7UzbxQkwvwqsikXE40wb1KsU=; b=OvYNJKnMhHRGJ3n73Jq0m6uHpjzSiCLHSkZC3cC7iCsS9tA3FCRt1NYWDuYT74rsi+ JkBcjl5X5FKajzv8T5rGrAWHaeEntwe8IKx2ycbldjliISImsidhZPofrFW6gApt71Nh U++qnkTWnBF0NI9QouWgWmBEdK0Jgc05EmdTkPw9mcsnxq16Op9lpBMjnyt3wly8ZB7x r5yAwG1MrqGx3v//MruTnU1e40n9nd8YCa0OB7YUen+cwZggeKojwtz5L7ixwYzC6Qas Fzl3YZYg6GdNw3yhcO46+kuDUaafQd/GVKTdX2q3eqKjci0us8J2fza+tBi5QM0ZNSrS Czpw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=XXMkw5mJ; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from lists.gnu.org (lists.gnu.org. [209.51.188.17]) by mx.google.com with ESMTPS id a1-20020ac86101000000b00342f62eebe1si5684734qtm.421.2022.10.04.04.53.29 for (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Tue, 04 Oct 2022 04:53:29 -0700 (PDT) Received-SPF: pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=XXMkw5mJ; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from localhost ([::1]:44542 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1ofgUL-0006Sc-7U for patch@linaro.org; Tue, 04 Oct 2022 07:53:29 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:38182) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1ofgTR-0006ST-Nx for qemu-devel@nongnu.org; Tue, 04 Oct 2022 07:52:33 -0400 Received: from mail-wm1-x32d.google.com ([2a00:1450:4864:20::32d]:37864) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1ofgTP-0001qO-I0 for qemu-devel@nongnu.org; Tue, 04 Oct 2022 07:52:33 -0400 Received: by mail-wm1-x32d.google.com with SMTP id z13-20020a7bc7cd000000b003b5054c6f9bso10687426wmk.2 for ; Tue, 04 Oct 2022 04:52:27 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date; bh=Fhd1uL9cZ5nuv6sVBgm7UzbxQkwvwqsikXE40wb1KsU=; b=XXMkw5mJZerKefwBia+4xbDzuU59en4EMjcsadz1BxAFS+vT10Qby68ud81ZwvDs+H ufwAHUnXwdOM8dwPuAFKAO+Z1DYJW6RB82ztiOz7+1mRtbFCOmf0sET7VDdNMBTMYOG7 wX6FaNDdXTZ5IyUC9LnhUQyXY+itjbTomE64h4rZbjoy9Tz09k5yupu/l28J7cRttAYp qxwdyoVZhu0Bcze6Q6ALA+3VLD8tSnhaj9hIp5/9peF8NoNM7xsr/N+F1BrGGefrNyeL AzT7W4v4Y0vHTkby4VJUF5U7KjS21gYO4r6UwdU44k44Dw6+ziHCdNMTfp+uSluwiHgM VacQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-message-state:from:to:cc:subject:date; bh=Fhd1uL9cZ5nuv6sVBgm7UzbxQkwvwqsikXE40wb1KsU=; b=UAhoC6YJhqfcMYiWJpVpeVaNJiAbfSnxTvBZWNlqtp39iW9ke0OuOT8K7wxV6CXzl4 8ccM0/U7zoKO+daTLL+MBsV8kkt5ihhdA4w5Xin31np6Bgxd4n4vp0ylkLwu3Hg+MXPo p9q0mxFn/EZyp62uOPSp7PIFQn+NqD45ar/UXgicA3SxRRPHFRO/GhU4XWsXpuh4SItj X/pmi80APTUWEkqPECjyORwbgjG1bYcAY6O8+ZllLxgXbyJMEmzRAaKkrzQ9RSro5Epf kqm+31DvqpkUSNkjvFEA9odTKObvyBXJsjfnMA8CCr3NNBcgLqEYETyYINULVtvLNKUt 3BVw== X-Gm-Message-State: ACrzQf2noZfy3FdP2rJgWB6aGxYdbH7a3HiVEboEnPnIBLhY2Kry0Xof faPr2gyh0gTtXEDTPHBuPJkBhg== X-Received: by 2002:a05:600c:43d3:b0:3b3:2f1c:f01c with SMTP id f19-20020a05600c43d300b003b32f1cf01cmr9868602wmn.152.1664884346078; Tue, 04 Oct 2022 04:52:26 -0700 (PDT) Received: from zen.linaroharston ([185.81.254.11]) by smtp.gmail.com with ESMTPSA id bn23-20020a056000061700b0022e55f40bc7sm1032962wrb.82.2022.10.04.04.52.25 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 04 Oct 2022 04:52:25 -0700 (PDT) Received: from zen.lan (localhost [127.0.0.1]) by zen.linaroharston (Postfix) with ESMTP id CE1BE1FFB7; Tue, 4 Oct 2022 12:52:24 +0100 (BST) From: =?utf-8?q?Alex_Benn=C3=A9e?= To: qemu-devel@nongnu.org Cc: berrange@redhat.com, ncopa@alpinelinux.org, =?utf-8?q?Alex_Benn=C3=A9e?= , Laurent Vivier , Alexandre Iooss , Mahmoud Mandour Subject: [RFC PATCH v2] plugins: add [pre|post]fork helpers to linux-user [!TESTED] Date: Tue, 4 Oct 2022 12:52:21 +0100 Message-Id: <20221004115221.2174499-1-alex.bennee@linaro.org> X-Mailer: git-send-email 2.34.1 MIME-Version: 1.0 Received-SPF: pass client-ip=2a00:1450:4864:20::32d; envelope-from=alex.bennee@linaro.org; helo=mail-wm1-x32d.google.com X-Spam_score_int: -20 X-Spam_score: -2.1 X-Spam_bar: -- X-Spam_report: (-2.1 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_DNSWL_NONE=-0.0001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" Special care needs to be taken in ensuring locks are in a consistent state across fork events. Add helpers so the plugin system can ensure that. Signed-off-by: Alex Bennée Fixes: https://gitlab.com/qemu-project/qemu/-/issues/358 --- v2 - fix null inline prototypes --- include/qemu/plugin.h | 24 ++++++++++++++++++++++++ linux-user/main.c | 2 ++ plugins/core.c | 20 ++++++++++++++++++++ 3 files changed, 46 insertions(+) diff --git a/include/qemu/plugin.h b/include/qemu/plugin.h index 145f8a221a..a772e14193 100644 --- a/include/qemu/plugin.h +++ b/include/qemu/plugin.h @@ -224,6 +224,23 @@ void qemu_plugin_disable_mem_helpers(CPUState *cpu); */ void qemu_plugin_user_exit(void); +/** + * qemu_plugin_user_prefork_lock(): take plugin lock before forking + * + * This is a user-mode only helper to take the internal plugin lock + * before a fork event. This is ensure a consistent lock state + */ +void qemu_plugin_user_prefork_lock(void); + +/** + * qemu_plugin_user_postfork(): reset the plugin lock + * @is_child: is this thread the child + * + * This user-mode only helper resets the lock state after a fork so we + * can continue using the plugin interface. + */ +void qemu_plugin_user_postfork(bool is_child); + #else /* !CONFIG_PLUGIN */ static inline void qemu_plugin_add_opts(void) @@ -287,6 +304,13 @@ static inline void qemu_plugin_disable_mem_helpers(CPUState *cpu) static inline void qemu_plugin_user_exit(void) { } + +static inline void qemu_plugin_user_prefork_lock(void) +{ } + +static inline void qemu_plugin_user_postfork(bool is_child) +{ } + #endif /* !CONFIG_PLUGIN */ #endif /* QEMU_PLUGIN_H */ diff --git a/linux-user/main.c b/linux-user/main.c index 88fccfe261..a17fed045b 100644 --- a/linux-user/main.c +++ b/linux-user/main.c @@ -142,10 +142,12 @@ void fork_start(void) start_exclusive(); mmap_fork_start(); cpu_list_lock(); + qemu_plugin_user_prefork_lock(); } void fork_end(int child) { + qemu_plugin_user_postfork(child); mmap_fork_end(child); if (child) { CPUState *cpu, *next_cpu; diff --git a/plugins/core.c b/plugins/core.c index c3ae284994..ccb770a485 100644 --- a/plugins/core.c +++ b/plugins/core.c @@ -526,6 +526,26 @@ void qemu_plugin_user_exit(void) qemu_plugin_atexit_cb(); } +/* + * Helpers for *-user to ensure locks are sane across fork() events. + */ + +void qemu_plugin_user_prefork_lock(void) +{ + qemu_rec_mutex_lock(&plugin.lock); +} + +void qemu_plugin_user_postfork(bool is_child) +{ + if (is_child) { + /* should we just reset via plugin_init? */ + qemu_rec_mutex_init(&plugin.lock); + } else { + qemu_rec_mutex_unlock(&plugin.lock); + } +} + + /* * Call this function after longjmp'ing to the main loop. It's possible that the * last instruction of a TB might have used helpers, and therefore the