Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp1350003yba; Sat, 6 Apr 2019 09:52:37 -0700 (PDT) X-Google-Smtp-Source: APXvYqz4TXleZvyTil0fAXaBg8NiECouHxGmrVRorlAt7kkWXr20Z9PcC88O3GgJBv9ETxMFgFpI X-Received: by 2002:a62:19c3:: with SMTP id 186mr20021939pfz.172.1554569557561; Sat, 06 Apr 2019 09:52:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1554569557; cv=none; d=google.com; s=arc-20160816; b=iKY7EzZM3vS4+vZBquz3MDcCLrt3IwfqTG1cGp7ca7g+jItpd23STbTuv7rva15AoK jjKQqiToF55kut3dQ2A0vKgwlEhtkmPKbpd/Y0IzqKUYMJ8lwS8NcHcOt+neA7L8Lp0P PxR1jT55NZbamfSKN0T70uMmGXPeC4ZgLPtW1oo1K7PO+W+14mCVXJIB1WNLHgb1lJSa KPUkuUJCZRhvxehWQG5Qr9XGOHToDUF/0DHnobGuDxaFyTv2h95CwLgIAIxgcJTdqJAL ZdDd72KogFTrYV0Rk2/wDQes4RMD7bH8sgOJj69H2anoX9Lo4qEpLKShxKiiT6NT+Eev xxtA== 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:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=KQi7/O0/S5TD77WmLAt9ftqw2MlthSJ2fzdI3yc/0/Q=; b=nzAslvRzkwXgJSrCvp1usaxRKtqsT2/hH19fZOBAn+tFAMAp4DT3Loa/pKZgD0rhFQ hbBvO9yOpiHEH+HGoear2gl4iW+aUZadFVZ4W9pIbuhrOJ1xISfJa1e3m39IUYRa5WU4 BWobvbX2TPySDoegMipu63yR45nfEJ37JU98TPlvp2kIG4YroXEar491Y1B7RdRaym2i amBSw2MkfaZQBqE9RHFr0IZXWcJM9vNzRmL5dlwyKc01JhbbRTmYsr9ZBZyU7pNeYsZF ZYPu+GJ3yaOTgk82Pt+wLMBiP3ThUwQZCJp11M9S2KAteorhNkWwZp2lLIGNZUq0HylE fOag== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@duncanthrax.net header.s=dkim header.b=qmOQ5jlW; 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 s9si22145140pgr.443.2019.04.06.09.52.20; Sat, 06 Apr 2019 09:52:37 -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=@duncanthrax.net header.s=dkim header.b=qmOQ5jlW; 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 S1726534AbfDFQ0g (ORCPT + 99 others); Sat, 6 Apr 2019 12:26:36 -0400 Received: from smtp.duncanthrax.net ([89.31.1.170]:49713 "EHLO smtp.duncanthrax.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726404AbfDFQ0g (ORCPT ); Sat, 6 Apr 2019 12:26:36 -0400 X-Greylist: delayed 1845 seconds by postgrey-1.27 at vger.kernel.org; Sat, 06 Apr 2019 12:26:34 EDT DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=duncanthrax.net; s=dkim; h=Content-Transfer-Encoding:MIME-Version: Message-Id:Date:Subject:Cc:To:From; bh=KQi7/O0/S5TD77WmLAt9ftqw2MlthSJ2fzdI3yc/0/Q=; b=qmOQ5jlW5bS24XNL715Murqp1b wHIpwT500FCwisAPAHyuu5Yw9NLPnnrR5zbQZ9Bdh1S5tj5/7wu7cRek9weQKpWY84mClmstzlXs2 EGXgSthmlgIHOaBd8y5E/eSybZpQ5pbrSwDEZ5c7/aRWjyfkii1Mh8phyD72pZsvA9hE=; Received: from [134.3.47.207] (helo=t470p.stackframe.org) by smtp.eurescom.eu with esmtpsa (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.86_2) (envelope-from ) id 1hCnfT-00083I-La; Sat, 06 Apr 2019 17:55:43 +0200 From: Sven Schnelle To: linux-kernel@vger.kernel.org Cc: Sven Schnelle , "Naveen N. Rao" , Anil S Keshavamurthy , "David S. Miller" , Masami Hiramatsu Subject: [PATCH] kprobes: fix compilation when KPROBE_EVENTS is enabled without kretpobes Date: Sat, 6 Apr 2019 17:55:43 +0200 Message-Id: <20190406155543.15353-1-svens@stackframe.org> X-Mailer: git-send-email 2.20.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org While implementing kprobes on PA-RISC (without kretprobes) compilation fails when CONFIG_KPROBE_EVENTS is enabled: kernel/trace/trace_kprobe.o: in function `trace_kprobe_create': kernel/trace/trace_kprobe.c:666: undefined reference to `kprobe_on_func_entry' kernel/trace/trace_kprobe.o: in function `trace_kprobe_on_func_entry': kernel/trace/trace_kprobe.c:167: undefined reference to `kprobe_on_func_entry' kernel/trace/trace_kprobe.c:167: undefined reference to `kprobe_on_func_entry' make: *** [Makefile:1029: vmlinux] Error 1 Given the fact that these functions have no dependencies on kretprobes i think they should be moved out of the #ifdef CONFIG_KRETPROBES block. Signed-off-by: Sven Schnelle Cc: "Naveen N. Rao" Cc: Anil S Keshavamurthy Cc: "David S. Miller" Cc: Masami Hiramatsu --- kernel/kprobes.c | 39 ++++++++++++++++++++------------------- 1 file changed, 20 insertions(+), 19 deletions(-) diff --git a/kernel/kprobes.c b/kernel/kprobes.c index c83e54727131..10a7e67fea67 100644 --- a/kernel/kprobes.c +++ b/kernel/kprobes.c @@ -1819,6 +1819,26 @@ unsigned long __weak arch_deref_entry_point(void *entry) return (unsigned long)entry; } +bool __weak arch_kprobe_on_func_entry(unsigned long offset) +{ + return !offset; +} + +bool kprobe_on_func_entry(kprobe_opcode_t *addr, const char *sym, + unsigned long offset) +{ + kprobe_opcode_t *kp_addr = _kprobe_addr(addr, sym, offset); + + if (IS_ERR(kp_addr)) + return false; + + if (!kallsyms_lookup_size_offset((unsigned long)kp_addr, NULL, &offset) || + !arch_kprobe_on_func_entry(offset)) + return false; + + return true; +} + #ifdef CONFIG_KRETPROBES /* * This kprobe pre_handler is registered with every kretprobe. When probe @@ -1875,25 +1895,6 @@ static int pre_handler_kretprobe(struct kprobe *p, struct pt_regs *regs) } NOKPROBE_SYMBOL(pre_handler_kretprobe); -bool __weak arch_kprobe_on_func_entry(unsigned long offset) -{ - return !offset; -} - -bool kprobe_on_func_entry(kprobe_opcode_t *addr, const char *sym, unsigned long offset) -{ - kprobe_opcode_t *kp_addr = _kprobe_addr(addr, sym, offset); - - if (IS_ERR(kp_addr)) - return false; - - if (!kallsyms_lookup_size_offset((unsigned long)kp_addr, NULL, &offset) || - !arch_kprobe_on_func_entry(offset)) - return false; - - return true; -} - int register_kretprobe(struct kretprobe *rp) { int ret = 0; -- 2.20.1