Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1763758AbZFLN0d (ORCPT ); Fri, 12 Jun 2009 09:26:33 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1761308AbZFLNZn (ORCPT ); Fri, 12 Jun 2009 09:25:43 -0400 Received: from cantor.suse.de ([195.135.220.2]:41670 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1759988AbZFLNZl (ORCPT ); Fri, 12 Jun 2009 09:25:41 -0400 From: Petr Tesarik To: LKML Cc: Thomas Gleixner , Ingo Molnar , "H. Peter Anvin" , Andi Kleen , Roland McGrath , Petr Tesarik Subject: [PATCH 5/8] x86: mark altinstr-related sections in vDSO as broken Date: Fri, 12 Jun 2009 15:25:39 +0200 Message-Id: <5c072743e9c6ce70674b54b2a818d592ba715145.1244812577.git.ptesarik@suse.cz> X-Mailer: git-send-email 1.6.0.2 In-Reply-To: References: Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1836 Lines: 62 There are several reasons why this does not work for the vDSO. 1. The alt_instr records are not processed by anybody. The .altinstruction sections end up in the vDSO binary, which is then incorporated verbatim inside a completely different section, so it is not seen by the main kernel. There is no code to interpret them during vDSO setup either. 2. The pointers in the alt_instr records are wrong. They point to the instructions and replacements at the prelinked addresses, but that's neither where the vDSO blob is located at startup, nor where it is copied to by the vDSO setup. The .altinstr_replacement section is not broken per se, but it is useless dead code without the accompanying .alt_instr section. Signed-off-by: Petr Tesarik --- arch/x86/vdso/vdso-layout.lds.S | 12 +++++------- 1 files changed, 5 insertions(+), 7 deletions(-) diff --git a/arch/x86/vdso/vdso-layout.lds.S b/arch/x86/vdso/vdso-layout.lds.S index 23da4a1..2f0830f 100644 --- a/arch/x86/vdso/vdso-layout.lds.S +++ b/arch/x86/vdso/vdso-layout.lds.S @@ -54,13 +54,6 @@ SECTIONS *(.bss* .gnu.linkonce.b.*) } - .altinstructions : { - *(.altinstructions) - } - .altinstr_replacement : { - *(.altinstr_replacement) - } - /* * Align the actual code well away from the non-instruction data. * This is the best thing for the I-cache. @@ -78,6 +71,11 @@ SECTIONS * if they get used by accident. */ .broken : { + /* The vDSO setup code does not handle alternative + * instructions. + */ + *(.altinstructions) + *(.altinstr_replacement) } } -- 1.6.0.2 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/