Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp695810ybb; Wed, 8 Apr 2020 08:13:25 -0700 (PDT) X-Google-Smtp-Source: APiQypJG9S4LWRc47RrH+B+tsMlBxjd0FLhtZQYh1Cm6+mJXoiQv98x1EmLrZXhIQT/7/Br8uvLH X-Received: by 2002:a05:6830:1ad0:: with SMTP id r16mr6095734otc.183.1586358804446; Wed, 08 Apr 2020 08:13:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586358804; cv=none; d=google.com; s=arc-20160816; b=X3nNXfH9FaTPfuKkuuQGD1Ut3XTmgmKfL04hVmpN8U1Hwu27wC+Ak1+wXg492ISYr1 0pwQgQjlYkPUJKR7/fLNd8NNQorlSwGzk4iWGbRqV7SzqVQ0LUScRyeTaTidsLSSi+8+ e7dcdsa8xNVTwU1FHHCmsniNICAUB6nMomh22Ii0dUcBbqyybaQMBkphSvLNe720v3Yd bbIvLKR5lOrViQt16mnuTy1BztbZjklHtcX0fC6m5UlorN0xYERmRWkA3enT+r+En48b FkNP/8XqSNrKioGEj5BfdhAh+rh7KGeFpwCknVSz45MIwgaXlzJb+rOHZQFV4csFHJmS HHLA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:references:cc:to:from:subject:dkim-signature; bh=hWI6KSBJwhLBPRk58QK/JNaKG+agLjuCHca2NgnWmtI=; b=Tf78wKEj3QqqwqNY/BWIkEbnLWpd6I406m8/ox5WJm2JRKL18shtcQZy92t7DRNszT Yd8YR4JnwfAc+A8lSixf+WSXj3fAjwtdS1HbcoihYj5VOIqTRSNJ2uK6Tr2qnvTRDpPe YfZ9C40oIBToKc4Me0nVi9+KQ3p+hdBR0+XKzWh9iaqwc6062EGcdQ+tkXnXy7uzv0hZ RtK2h0O5WVYLf63rzlhdlkAsG57gqWElac3wWxGSkxmyREsFAMTOqzIdZ60PCdvRkP5y dphQpn8Mnt8uh2o6MM4nbSrrX0V+8XFxBPZ61kxpOvWxd8+0dntLqC0gX74CkWcF0EDN ZWHQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@oracle.com header.s=corp-2020-01-29 header.b="kV/HOgs3"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=oracle.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t13si1026525oih.136.2020.04.08.08.13.08; Wed, 08 Apr 2020 08:13:24 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@oracle.com header.s=corp-2020-01-29 header.b="kV/HOgs3"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=oracle.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727851AbgDHOET (ORCPT + 99 others); Wed, 8 Apr 2020 10:04:19 -0400 Received: from userp2130.oracle.com ([156.151.31.86]:42796 "EHLO userp2130.oracle.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727226AbgDHOET (ORCPT ); Wed, 8 Apr 2020 10:04:19 -0400 Received: from pps.filterd (userp2130.oracle.com [127.0.0.1]) by userp2130.oracle.com (8.16.0.42/8.16.0.42) with SMTP id 038Dw6X1087445; Wed, 8 Apr 2020 14:03:57 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oracle.com; h=subject : from : to : cc : references : message-id : date : mime-version : in-reply-to : content-type : content-transfer-encoding; s=corp-2020-01-29; bh=hWI6KSBJwhLBPRk58QK/JNaKG+agLjuCHca2NgnWmtI=; b=kV/HOgs3XEXgeSot3ajlmAUJGkvf3xT/Zf0t0BerQVQ+0s3KEm4tg6TqPsmpSsIM0HVC 8JLJLnIh9Ei1/mnO1hwoXtdDpRxW/VgHTGWrBRBV4qj42oq76/Y3QmGZYYIIX8OiIuyE jRlCdbZ3T7UmIeorA85EY3U/d5MfnDxRtbac6yC1ABt03qaXTzQMKnGRbBz1YJKqdoaZ rKPO3yOavaIewE3vuLsWs+JgBNhsRafqdjPHFqnc16+maF5GJ3A2+o/JTFsA4XKpE/+J fZnnZs0UB4cSIU6EHZA+3I2mA8CKrz/l4nt9VUW64JXsae6DqQMWAkOnR52glrD/EnrA sw== Received: from userp3020.oracle.com (userp3020.oracle.com [156.151.31.79]) by userp2130.oracle.com with ESMTP id 3091m3br14-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Wed, 08 Apr 2020 14:03:57 +0000 Received: from pps.filterd (userp3020.oracle.com [127.0.0.1]) by userp3020.oracle.com (8.16.0.42/8.16.0.42) with SMTP id 038DuYkf107015; Wed, 8 Apr 2020 14:01:57 GMT Received: from userv0121.oracle.com (userv0121.oracle.com [156.151.31.72]) by userp3020.oracle.com with ESMTP id 3099v92rv8-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Wed, 08 Apr 2020 14:01:55 +0000 Received: from abhmp0002.oracle.com (abhmp0002.oracle.com [141.146.116.8]) by userv0121.oracle.com (8.14.4/8.13.8) with ESMTP id 038E1qLg002863; Wed, 8 Apr 2020 14:01:53 GMT Received: from linux-1.home (/92.157.90.160) by default (Oracle Beehive Gateway v4.0) with ESMTP ; Wed, 08 Apr 2020 07:01:52 -0700 Subject: Re: [PATCH V2 5/9] objtool: Add support for intra-function calls From: Alexandre Chartre To: Peter Zijlstra Cc: x86@kernel.org, linux-kernel@vger.kernel.org, jpoimboe@redhat.com, jthierry@redhat.com, tglx@linutronix.de References: <20200407073142.20659-1-alexandre.chartre@oracle.com> <20200407073142.20659-6-alexandre.chartre@oracle.com> <20200407130729.GZ20730@hirez.programming.kicks-ass.net> <40b19a8e-ae5e-623e-fb3f-261f9fec2ea5@oracle.com> Message-ID: <7ba6d4c9-c1dc-fa83-2ade-b7d3fba9e7fb@oracle.com> Date: Wed, 8 Apr 2020 16:06:18 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.2.0 MIME-Version: 1.0 In-Reply-To: <40b19a8e-ae5e-623e-fb3f-261f9fec2ea5@oracle.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit X-Proofpoint-Virus-Version: vendor=nai engine=6000 definitions=9584 signatures=668685 X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 malwarescore=0 adultscore=0 mlxscore=0 mlxlogscore=999 bulkscore=0 spamscore=0 phishscore=0 suspectscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2003020000 definitions=main-2004080116 X-Proofpoint-Virus-Version: vendor=nai engine=6000 definitions=9584 signatures=668685 X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 spamscore=0 adultscore=0 impostorscore=0 malwarescore=0 lowpriorityscore=0 mlxlogscore=999 priorityscore=1501 clxscore=1015 bulkscore=0 phishscore=0 mlxscore=0 suspectscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2003020000 definitions=main-2004080116 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 4/7/20 3:28 PM, Alexandre Chartre wrote: > > On 4/7/20 3:07 PM, Peter Zijlstra wrote: >> On Tue, Apr 07, 2020 at 09:31:38AM +0200, Alexandre Chartre wrote: >> >>> index a62e032863a8..7ee1561bf7ad 100644 >>> --- a/tools/objtool/arch/x86/decode.c >>> +++ b/tools/objtool/arch/x86/decode.c >>> @@ -497,3 +497,15 @@ void arch_initial_func_cfi_state(struct cfi_state *state) >>>       state->regs[16].base = CFI_CFA; >>>       state->regs[16].offset = -8; >>>   } >>> + >>> + >>> +void arch_configure_intra_function_call(struct stack_op *op) >>> +{ >>> +    /* >>> +     * For the impact on the stack, make an intra-function >>> +     * call behaves like a push of an immediate value (the >>> +     * return address). >>> +     */ >>> +    op->src.type = OP_SRC_CONST; >>> +    op->dest.type = OP_DEST_PUSH; >>> +} >> >> An alternative is to always set up stack ops for CALL/RET on decode, but >> conditionally run update_insn_state() for them. >> >> Not sure that makes more logical sense, but the patch would be simpler I >> think. > > Right, this would avoid adding a new arch dependent function and the patch > will be simpler. This probably makes sense as the stack impact is the same > for all calls (but objtool will use it only for intra-function calls). > Actually the processing of the ret instruction is more complicated than I anticipated with intra-function calls, and so my implementation is not complete at the moment. The issue is to correctly handle how the ret is going to behave depending how the stack (or register on arm) is modified before the ret. Adjusting the stack offset makes the stack state correct, but objtool still needs to correctly figure out where the ret is going to return and where the code flow continues. alex.