Received: by 2002:ac0:a581:0:0:0:0:0 with SMTP id m1-v6csp3070328imm; Sun, 1 Jul 2018 11:33:08 -0700 (PDT) X-Google-Smtp-Source: AAOMgpfubx0l0Xci4g8yOm/nBYlcBxMZavwww3hDbmqotPafGTq/O0dsSxp/FTh34i/P2KHj/MOX X-Received: by 2002:a62:b94:: with SMTP id 20-v6mr22029957pfl.234.1530469988212; Sun, 01 Jul 2018 11:33:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1530469988; cv=none; d=google.com; s=arc-20160816; b=qOm2JU9H+3r38E/SQ4raXFMDNJlqex1Q4BdgrZQVY/IRMa/qLUAMfUagjQD1b13lTQ InV+ZS/g9ywUGCh3ZCx8xLMo6dkg9E0eDjj5g+6WmCnKqtAE6xVY8/Q6HkbH8YvLEAKI 9p4QdJh31cUSWnkb7SvW8RpwJUo6z58Oh4nD6HvXoV3sdYfalvJwEmWjOYa3aLPooiHx 0yKT/rKieOezpUPJ9NyaatvLWeQ1xVQ/5BCBQ1mscSRIwksDYPYi2gVa3iVw8iAHi3J9 Ndy890TlyUbDuCqSZkp7WRYpkIyOhLSqDNQ1yXbGmmk/NHxcnllc/tR7FGqclrW0MSWv iQCw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=J3W33c0cByRpxAQlEJSgkQJvfRgrXaLjxWx2bt+c14I=; b=CcydjxLodkeqJYI+2jVPMpWDlWuQUA4SGHmJ7npsXQKQ7qTu1Fcx3uuGQAsWUsBiw6 orGPBHwZ4EA+EmD7Iq6UlKw3ZNr6UqygWjoxeGNu5cSuDlujWZt0v9Xs9+pJ2ejOyuHS S5sk7+A60CMOv181TtwbbGCwjiR1Hzq/U0sjdTSare7EasuLI56b2sPtRmjWua94xG4W iJcrCiPt7c3U8e7MTxK0Z60fKKXFQLm7gI4kfnnoDdyUGmIyDFsGYBVeXzICM94R0CHZ S8cRD1SY02WjeBbmAJWsd971uI5FSZczHxvEurzhlwNh8CsVwWXEKxziw8wtPtEY4ID4 Cmbw== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l15-v6si5874105pgf.451.2018.07.01.11.32.53; Sun, 01 Jul 2018 11:33:08 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S964811AbeGAScS (ORCPT + 99 others); Sun, 1 Jul 2018 14:32:18 -0400 Received: from mail.linuxfoundation.org ([140.211.169.12]:60888 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753192AbeGAQQt (ORCPT ); Sun, 1 Jul 2018 12:16:49 -0400 Received: from localhost (LFbn-1-12247-202.w90-92.abo.wanadoo.fr [90.92.61.202]) by mail.linuxfoundation.org (Postfix) with ESMTPSA id 0238F49B; Sun, 1 Jul 2018 16:16:47 +0000 (UTC) From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Matthias Schiffer , Matt Redfearn , Paul Burton Subject: [PATCH 4.4 036/105] mips: ftrace: fix static function graph tracing Date: Sun, 1 Jul 2018 18:01:46 +0200 Message-Id: <20180701153151.842354969@linuxfoundation.org> X-Mailer: git-send-email 2.18.0 In-Reply-To: <20180701153149.382300170@linuxfoundation.org> References: <20180701153149.382300170@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.4-stable review patch. If anyone has any objections, please let me know. ------------------ From: Matthias Schiffer commit 6fb8656646f996d1eef42e6d56203c4915cb9e08 upstream. ftrace_graph_caller was never run after calling ftrace_trace_function, breaking the function graph tracer. Fix this, bringing it in line with the x86 implementation. While we're at it, also streamline the control flow of _mcount a bit to reduce the number of branches. This issue was reported before: https://www.linux-mips.org/archives/linux-mips/2014-11/msg00295.html Signed-off-by: Matthias Schiffer Tested-by: Matt Redfearn Patchwork: https://patchwork.linux-mips.org/patch/18929/ Signed-off-by: Paul Burton Cc: stable@vger.kernel.org # v3.17+ Signed-off-by: Greg Kroah-Hartman --- arch/mips/kernel/mcount.S | 27 ++++++++++++--------------- 1 file changed, 12 insertions(+), 15 deletions(-) --- a/arch/mips/kernel/mcount.S +++ b/arch/mips/kernel/mcount.S @@ -116,10 +116,20 @@ ftrace_stub: NESTED(_mcount, PT_SIZE, ra) PTR_LA t1, ftrace_stub PTR_L t2, ftrace_trace_function /* Prepare t2 for (1) */ - bne t1, t2, static_trace + beq t1, t2, fgraph_trace nop + MCOUNT_SAVE_REGS + + move a0, ra /* arg1: self return address */ + jalr t2 /* (1) call *ftrace_trace_function */ + move a1, AT /* arg2: parent's return address */ + + MCOUNT_RESTORE_REGS + +fgraph_trace: #ifdef CONFIG_FUNCTION_GRAPH_TRACER + PTR_LA t1, ftrace_stub PTR_L t3, ftrace_graph_return bne t1, t3, ftrace_graph_caller nop @@ -128,24 +138,11 @@ NESTED(_mcount, PT_SIZE, ra) bne t1, t3, ftrace_graph_caller nop #endif - b ftrace_stub -#ifdef CONFIG_32BIT - addiu sp, sp, 8 -#else - nop -#endif - -static_trace: - MCOUNT_SAVE_REGS - - move a0, ra /* arg1: self return address */ - jalr t2 /* (1) call *ftrace_trace_function */ - move a1, AT /* arg2: parent's return address */ - MCOUNT_RESTORE_REGS #ifdef CONFIG_32BIT addiu sp, sp, 8 #endif + .globl ftrace_stub ftrace_stub: RETURN_BACK