Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp3994825yba; Mon, 29 Apr 2019 11:55:51 -0700 (PDT) X-Google-Smtp-Source: APXvYqxsrNHbAfSYy3Z7qSRXkaZuyuhb6N9XyclS4bZhxvPG1lRovyIRci7Km6jDGIbinUsQBOM8 X-Received: by 2002:a17:902:2a03:: with SMTP id i3mr66278438plb.229.1556564151115; Mon, 29 Apr 2019 11:55:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1556564151; cv=none; d=google.com; s=arc-20160816; b=zMmB+AyqFELxDyks114f7xtkPGNXqpR612WsH5fQw+rbdoMfmHLdPHdGa2D8GaBB+7 URCm2Drn3epcaKOZiTs+iHRfHniS3MpZb6weQlDERfdHrtDYG6XFZDQdnpOOkhk6DCgY FlYUREQThl2kG6gV//Y2/qBIWqSp3Pcx4WLa88jqUOn+o9aT5RvxLZqmGEeDUq31/QrU AWJaSKh+jlMIBIUr0H3/8W1RksIMMX1G9PLWoAs61VoAUPRIHyOopUL4laM7Mseb0OyI va4YPIhLs6vNDF1AE4iziE7EXli9qs/Po/gL/tqp93FpGg9g97dZ5FdLqGMMqzFajcvi 4oSQ== 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 :references:in-reply-to:message-id:subject:cc:to:from:date; bh=nTy+/ThDMPLVLOvUHafJRCEDYkrPKUVX5R3M7dxswk8=; b=fRqTXOnbpI4Y/rSlT9qzlG8JA9kIfiJKn9mAEmGloYqkskR9SBOgn6YzsO8+gbKtfE kibkVOKvFLp+9cr+zPgm78RFfyvZ8ySEGyA0nLxFo/smsaP8p+EHnWPy3F5+/MkHpMyK Y1Z18zy4LpDg+Z+rtOrn8NL3RKjVl2IwZObzUtIw1Qdwbu/t6smDCM/NgzN2ezi8m6mZ JFK7LrMVr2MvSax4lO1XgIAKfnpKplYViCW00bZAuKr+8xAynf35yVj1uxp+yqC6mqDD 6Z6+1ASst34sE/EyI+IvNO9h6j3SiFFO3p3UcpQDnWX4uTrRjh6ZtlMwRI3mbnhOKQbi HbHw== 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 b6si14046495pfi.221.2019.04.29.11.55.35; Mon, 29 Apr 2019 11:55:51 -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 S1729241AbfD2Swy (ORCPT + 99 others); Mon, 29 Apr 2019 14:52:54 -0400 Received: from mail.kernel.org ([198.145.29.99]:50454 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729027AbfD2Swy (ORCPT ); Mon, 29 Apr 2019 14:52:54 -0400 Received: from gandalf.local.home (cpe-66-24-58-225.stny.res.rr.com [66.24.58.225]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 996AA2075E; Mon, 29 Apr 2019 18:52:51 +0000 (UTC) Date: Mon, 29 Apr 2019 14:52:50 -0400 From: Steven Rostedt To: Linus Torvalds Cc: Peter Zijlstra , Nicolai Stange , Thomas Gleixner , Ingo Molnar , Borislav Petkov , "H. Peter Anvin" , "the arch/x86 maintainers" , Josh Poimboeuf , Jiri Kosina , Miroslav Benes , Petr Mladek , Joe Lawrence , Shuah Khan , Konrad Rzeszutek Wilk , Tim Chen , Sebastian Andrzej Siewior , Mimi Zohar , Juergen Gross , Nick Desaulniers , Nayna Jain , Masahiro Yamada , Andy Lutomirski , Joerg Roedel , Linux List Kernel Mailing , live-patching@vger.kernel.org, "open list:KERNEL SELFTEST FRAMEWORK" Subject: Re: [PATCH 3/4] x86/ftrace: make ftrace_int3_handler() not to skip fops invocation Message-ID: <20190429145250.1a5da6ed@gandalf.local.home> In-Reply-To: References: <20190427100639.15074-1-nstange@suse.de> <20190427100639.15074-4-nstange@suse.de> <20190427102657.GF2623@hirez.programming.kicks-ass.net> <20190428133826.3e142cfd@oasis.local.home> X-Mailer: Claws Mail 3.17.3 (GTK+ 2.24.32; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 29 Apr 2019 11:06:58 -0700 Linus Torvalds wrote: > +void replace_call(void *addr, const void *opcode, size_t len, void *target) > +{ > + bp_int3_call_target = target; > + bp_int3_call_return = addr + len; > + bp_int3_handler_irqoff = emulate_call_irqoff; > + text_poke_bp(addr, opcode, len, emulate_call_irqon); > +} Note, the function tracer does not use text poke. It does it in batch mode. It can update over 40,000 calls in one go: add int3 breakpoint to all 40,000 call sites. sync() change the last four bytes of each of those call sites sync() remove int3 from the 40,000 call site with new call. It's a bit more intrusive than the static call updates we were discussing before. -- Steve