From patchwork Fri Oct 25 11:39:21 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Richard Henderson X-Patchwork-Id: 177725 Delivered-To: patch@linaro.org Received: by 2002:a92:409a:0:0:0:0:0 with SMTP id d26csp3574071ill; Fri, 25 Oct 2019 04:46:13 -0700 (PDT) X-Google-Smtp-Source: APXvYqyhA4UubFTUT/iPetgyS0p2xCHeuVkLvZC+t2k6GwQKqK52RbYKtfT4rKryxTdRo03DIxHg X-Received: by 2002:ac8:34a3:: with SMTP id w32mr2606592qtb.9.1572003973422; Fri, 25 Oct 2019 04:46:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1572003973; cv=none; d=google.com; s=arc-20160816; b=lwgetm0DyuY5FxfjYdr30HTzxvM0eUmOgqlu480wu5TiI3V5jXFdWrU9t9BBFKuN96 mLRPIMVc2xmK9pK4+NXQYEwWvJ6ajgrLPcft/IjS8uVKfGCSp0gh2kreOuPFDptbu/n0 nhNRG1n/EdjTc3PV6pxV4jV/Vhr/R0bWZtyDHkb7/9cpBdDahizsQd7/sbMlQuq/g8/7 fRh3CSC2JqonAHxAfYR7lEKOGKyfpkZ8kKvV0lyRczKahBTMcjukQUTjlkrCYQiHwCU7 keV2Q7ll/1Z5bOb4BDYozwiIwNSXaI3CbUYive9WWGQZuIn5mgvFDI9w6P2DzOWf6Prr AYQw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:cc:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:references:in-reply-to :message-id:date:subject:to:from:dkim-signature; bh=gyTalvpUNKSJ73L+c2LcfOwC3yCRl3XSXEKw11FCS20=; b=X3R62CD2/bg7duwzETe/5rspQu6RqC60307uMOyxEa2pm7hADm2X+MCDspztmT2Kkr XHNsL8qAgzqDz2vkgrkzJNbCYVi8BXep8K3LLjgdtZONMOYi3ReW86hsKiMH8+NU8uje JNO8PILyfTmjxxIXPFUZZ4UFmRAawK/DgxQ9kSlLN9FsjdfB84G1pCZIknC4IVsrDx9P cQyEh4sWSzfkLG1JN6C3oBNbvLdXH0K+3zWW2+sTaId+CQddmNaVANQ0FgFwct8VVDyU ZxivRQK/H4jg4tsct5U+sFooe5y6o2KKW6hKpvGhzNmmCoKMdUlxta1f8p7hdyz8tRSw uv3Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linaro.org header.s=google header.b=tARXIZaf; 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=fail (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 v10si1140022qtj.160.2019.10.25.04.46.13 for (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Fri, 25 Oct 2019 04:46:13 -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=fail header.i=@linaro.org header.s=google header.b=tARXIZaf; 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=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from localhost ([::1]:58988 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1iNy2m-0008AP-5Z for patch@linaro.org; Fri, 25 Oct 2019 07:46:12 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:45130) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1iNxwV-0006qW-UM for qemu-devel@nongnu.org; Fri, 25 Oct 2019 07:39:44 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1iNxwQ-0006gc-Pw for qemu-devel@nongnu.org; Fri, 25 Oct 2019 07:39:41 -0400 Received: from mail-qk1-x742.google.com ([2607:f8b0:4864:20::742]:39897) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1iNxwP-0006fB-1v for qemu-devel@nongnu.org; Fri, 25 Oct 2019 07:39:37 -0400 Received: by mail-qk1-x742.google.com with SMTP id 15so1401379qkh.6 for ; Fri, 25 Oct 2019 04:39:37 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=gyTalvpUNKSJ73L+c2LcfOwC3yCRl3XSXEKw11FCS20=; b=tARXIZaf6JD0O9SZZCu7GP4auGvVhv7DjA+9hKeRokTMaCXYJDGn31BbcZXum3Y+cO diDAadMmFfFRj2KDve28ON0J+vUV4+qm51pB1rYwTMYLJI8mIcUtA/icikTKVzd2rd0P j0S9QZ6v5PC2En32z4VLUhrNkaONv89wWwXsAyQXyX5aXL5t0ricm3bfU5SYF3cq1M1x qErQJGO0312iSn8lfYidXV/OKJkkTVJFijsRoeewtqNbC9F6OQ1MuP2bujEaN97oaGla ZXiR/R9bG5DHRODjU+SB2UflrnuJwTyERG6RQ4tSW3XFjHrAk6FwzhLAQYsbG6GSNbgD YHNw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=gyTalvpUNKSJ73L+c2LcfOwC3yCRl3XSXEKw11FCS20=; b=bhSNrpy+MSYOUBYJyUa1yE1ocs45vjNe7ltvZEmRh2gGhqb8o286m0cTQpvAmTkjHv BSQYaOnMlM4BnVfY6yRhEiikJjOnDwAClZSspIvpBM6fii7YFX6m45+uPlOJWcdYdNbW HdtqsPGyGG7melgbJwcgL9tvIcha0raJgojNv+JJ6QFJFHbZiQO80BvFNkOAMr1BSBd3 gCMeckd8TG1xHB8EIFN2HZkMqXZMwmghbYydt7RKTRw1KgCDneRoHxyiTxdgCVE2yPDO 7MCEIVBs/8xjVTUX+1rOnCfQWs7FVKEqBIiJvkO8B5Nws6SFxgUCplMctv2OWvKskkum 6U4Q== X-Gm-Message-State: APjAAAU54oEDSiEBFvTh4xK1SKugZ97stJ6NLJg9gG3SQKxOCtOcjgMx 8xRGUShmrbhafhSpU211xyOD8H2x8Qo= X-Received: by 2002:a37:507:: with SMTP id 7mr2378216qkf.107.1572003576108; Fri, 25 Oct 2019 04:39:36 -0700 (PDT) Received: from localhost.localdomain (rrcs-172-254-253-50.nyc.biz.rr.com. [172.254.253.50]) by smtp.gmail.com with ESMTPSA id x38sm1473335qtc.64.2019.10.25.04.39.35 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 25 Oct 2019 04:39:35 -0700 (PDT) From: Richard Henderson To: qemu-devel@nongnu.org Subject: [PATCH v2 12/12] linux-user/alpha: Set r20 secondary return value Date: Fri, 25 Oct 2019 07:39:21 -0400 Message-Id: <20191025113921.9412-13-richard.henderson@linaro.org> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20191025113921.9412-1-richard.henderson@linaro.org> References: <20191025113921.9412-1-richard.henderson@linaro.org> X-detected-operating-system: by eggs.gnu.org: Genre and OS details not recognized. X-Received-From: 2607:f8b0:4864:20::742 X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: alex.bennee@linaro.org, laurent@vivier.eu Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" This value is not, as far as I know, used by any linux software, but it is set by the kernel and is part of the ABI. Signed-off-by: Richard Henderson --- v2: Do not set the parent secondary return if SETTLS. --- linux-user/alpha/target_cpu.h | 9 +++++++++ 1 file changed, 9 insertions(+) -- 2.17.1 Reviewed-by: Laurent Vivier diff --git a/linux-user/alpha/target_cpu.h b/linux-user/alpha/target_cpu.h index dd25e18f47..ad408ab5cc 100644 --- a/linux-user/alpha/target_cpu.h +++ b/linux-user/alpha/target_cpu.h @@ -27,10 +27,19 @@ static inline void cpu_clone_regs_child(CPUAlphaState *env, target_ulong newsp, } env->ir[IR_V0] = 0; env->ir[IR_A3] = 0; + env->ir[IR_A4] = 1; /* OSF/1 secondary return: child */ } static inline void cpu_clone_regs_parent(CPUAlphaState *env, unsigned flags) { + /* + * OSF/1 secondary return: parent + * Note that the kernel does not do this if SETTLS, because the + * settls argument register is still live after copy_thread. + */ + if (!(flags & CLONE_SETTLS)) { + env->ir[IR_A4] = 0; + } } static inline void cpu_set_tls(CPUAlphaState *env, target_ulong newtls)