All of lore.kernel.org
 help / color / mirror / Atom feed
From: Masami Hiramatsu <mhiramat@redhat.com>
To: Frederic Weisbecker <fweisbec@gmail.com>
Cc: "Ingo Molnar" <mingo@elte.hu>,
	"Steven Rostedt" <rostedt@goodmis.org>,
	lkml <linux-kernel@vger.kernel.org>,
	systemtap <systemtap@sources.redhat.com>,
	kvm <kvm@vger.kernel.org>,
	DLE <dle-develop@lists.sourceforge.net>,
	"Jim Keniston" <jkenisto@us.ibm.com>,
	"H. Peter Anvin" <hpa@zytor.com>,
	"Ananth N Mavinakayanahalli" <ananth@in.ibm.com>,
	"Avi Kivity" <avi@redhat.com>, "Andi Kleen" <ak@linux.intel.com>,
	"Christoph Hellwig" <hch@infradead.org>,
	"Frank Ch. Eigler" <fche@redhat.com>,
	"Jason Baron" <jbaron@redhat.com>,
	"K.Prasad" <prasad@linux.vnet.ibm.com>,
	"Lai Jiangshan" <laijs@cn.fujitsu.com>,
	"Li Zefan" <lizf@cn.fujitsu.com>,
	PrzemysławPawełczyk <przemyslaw@pawelczyk.it>,
	"Roland McGrath" <roland@redhat.com>,
	"Sam Ravnborg" <sam@ravnborg.org>,
	"Srikar Dronamraju" <srikar@linux.vnet.ibm.com>,
	"Tom Zanussi" <tzanussi@gmail.com>,
	"Vegard Nossum" <vegard.nossum@gmail.com>
Subject: Re: [PATCH -tip v14 01/12] x86: instruction decoder API
Date: Thu, 20 Aug 2009 15:01:25 -0400	[thread overview]
Message-ID: <4A8D9D85.50809@redhat.com> (raw)
In-Reply-To: <20090820180737.GA6229@nowhere>

Frederic Weisbecker wrote:
> On Thu, Aug 20, 2009 at 12:16:05PM -0400, Masami Hiramatsu wrote:
>> Frederic Weisbecker wrote:
>>> On Thu, Aug 20, 2009 at 11:03:40AM -0400, Masami Hiramatsu wrote:
>>>> Frederic Weisbecker wrote:
>>>>> On Thu, Aug 20, 2009 at 01:42:31AM +0200, Frederic Weisbecker wrote:
>>>>>> On Thu, Aug 13, 2009 at 04:34:13PM -0400, Masami Hiramatsu wrote:
>>>>>>> Add x86 instruction decoder to arch-specific libraries. This decoder
>>>>>>> can decode x86 instructions used in kernel into prefix, opcode, modrm,
>>>>>>> sib, displacement and immediates. This can also show the length of
>>>>>>> instructions.
>>>>>>>
>>>>>>> This version introduces instruction attributes for decoding instructions.
>>>>>>> The instruction attribute tables are generated from the opcode map file
>>>>>>> (x86-opcode-map.txt) by the generator script(gen-insn-attr-x86.awk).
>>>>>>>
>>>>>>> Currently, the opcode maps are based on opcode maps in Intel(R) 64 and
>>>>>>> IA-32 Architectures Software Developers Manual Vol.2: Appendix.A,
>>>>>>> and consist of below two types of opcode tables.
>>>>>>>
>>>>>>> 1-byte/2-bytes/3-bytes opcodes, which has 256 elements, are
>>>>>>> written as below;
>>>>>>>
>>>>>>>     Table: table-name
>>>>>>>     Referrer: escaped-name
>>>>>>>     opcode: mnemonic|GrpXXX [operand1[,operand2...]] [(extra1)[,(extra2)...] [| 2nd-mnemonic ...]
>>>>>>>      (or)
>>>>>>>     opcode: escape # escaped-name
>>>>>>>     EndTable
>>>>>>>
>>>>>>> Group opcodes, which has 8 elements, are written as below;
>>>>>>>
>>>>>>>     GrpTable: GrpXXX
>>>>>>>     reg:  mnemonic [operand1[,operand2...]] [(extra1)[,(extra2)...] [| 2nd-mnemonic ...]
>>>>>>>     EndTable
>>>>>>>
>>>>>>> These opcode maps include a few SSE and FP opcodes (for setup), because
>>>>>>> those opcodes are used in the kernel.
>>>>>>>
>>>>>>
>>>>>>
>>>>>> I'm getting the following build error on an old K7 box:
>>>>>>
>>>>>> arch/x86/lib/inat.c: In function ‘inat_get_opcode_attribute’:
>>>>>> arch/x86/lib/inat.c:29: erreur: ‘inat_primary_table’ undeclared (first use in this function)
>>>>>> arch/x86/lib/inat.c:29: erreur: (Each undeclared identifier is reported only once
>>>>>> arch/x86/lib/inat.c:29: erreur: for each function it appears in.)
>>>>>>
>>>>>>
>>>>>> I've attached my config. I haven't such problem on a dual x86-64 box.
>>>>>
>>>>>
>>>>> Actually I have the same problem in x86-64
>>>>> The content of my arch/x86/lib/inat-tables.c:
>>>>>
>>>>> /* x86 opcode map generated from x86-opcode-map.txt */
>>>>> /* Do not change this code. */
>>>>> /* Table: one byte opcode */
>>>>> /* Escape opcode map array */
>>>>> const insn_attr_t const *inat_escape_tables[INAT_ESC_MAX + 1][INAT_LPREFIX_MAX + 1] = {
>>>>> };
>>>>>
>>>>> /* Group opcode map array */
>>>>> const insn_attr_t const *inat_group_tables[INAT_GRP_MAX + 1][INAT_LPREFIX_MAX + 1] = {
>>>>> };
>>>>>
>>>>>
>>>>> I guess there is a problem with the generation of this file.
>>>>
>>>> Aah, you may use mawk on Ubuntu 9.04, right?
>>>> If so, unfortunately, mawk is still under development.
>>>>
>>>> http://invisible-island.net/mawk/CHANGES
>>>
>>>
>>>
>>> Aargh...
>>>
>>>
>>>>> 20090727
>>>>> 	add check/fix to prevent gsub from recurring to modify on a substring
>>>>> 	of the current line when the regular expression is anchored to the
>>>>> 	beginning of the line; fixes gawk's anchgsub testcase.
>>>>>
>>>>> 	add check for implicit concatenation mistaken for exponent; fixes
>>>>> 	gawk's hex testcase.
>>>>>
>>>>> 	add character-classes to built-in regular expressions.
>>>>           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
>>>> Look, this means we can't use char-class expressions like
>>>> [:lower:] until this version...
>>>>
>>>> And I've found another bug in mawk-1.3.3-20090728(the latest one).
>>>> it almost works, but;
>>>>
>>>> $ mawk 'BEGIN {printf("0x%x\n", 0)}'
>>>> 0x1
>>>
>>>
>>> Ouch, indeed.
>>>
>>>
>>>
>>>> $ gawk 'BEGIN {printf("0x%x\n", 0)}'
>>>> 0x0
>>>>
>>>> This bug skips an array element index 0x0 in inat-tables.c :(
>>>>
>>>> So, I recommend you to install gawk instead mawk until that
>>>> supports all posix-awk features, since I don't think it is
>>>> good idea to avoid all those bugs which depends on
>>>> implementation (not specification).
>>>>
>>>>
>>>> Thank you,
>>>
>>>
>>>
>>> Yeah, indeed. May be add a warning (or build error) in case the user uses
>>> mawk?
>>
>> Hmm, it is possible that mawk will fix those bugs and catch up soon,
>> so, I think checking mawk is not a good idea.
>> (and since there will be other awk implementations, it's not fair.)
>>
>> I think what all I can do now is reporting bugs to
>> mawk and ubuntu people.:-)
>
>
>
> Yeah, but without your tip I couldn't be able to find the origin
> before some time.
> And the kernel couldn't build anyway.
>
> At least we should do something with this version of mawk.

Hm, indeed.
Maybe, we can run additional sanity check script before using
awk, like this;

---
res=`echo a | $AWK '/[[:lower:]]+/{print "OK"}'`
[ "$res" != "OK" ] && exit 1

res=`$AWK 'BEGIN {printf("%x", 0)}'`
[ "$res" != "0" ] && exit 1

exit 0
---

Thanks,

-- 
Masami Hiramatsu

Software Engineer
Hitachi Computer Products (America), Inc.
Software Solutions Division

e-mail: mhiramat@redhat.com


WARNING: multiple messages have this Message-ID (diff)
From: Masami Hiramatsu <mhiramat@redhat.com>
To: Frederic Weisbecker <fweisbec@gmail.com>
Cc: "Ingo Molnar" <mingo@elte.hu>,
	"Steven Rostedt" <rostedt@goodmis.org>,
	lkml <linux-kernel@vger.kernel.org>,
	systemtap <systemtap@sources.redhat.com>,
	kvm <kvm@vger.kernel.org>,
	DLE <dle-develop@lists.sourceforge.net>,
	"Jim Keniston" <jkenisto@us.ibm.com>,
	"H. Peter Anvin" <hpa@zytor.com>,
	"Ananth N Mavinakayanahalli" <ananth@in.ibm.com>,
	"Avi Kivity" <avi@redhat.com>, "Andi Kleen" <ak@linux.intel.com>,
	"Christoph Hellwig" <hch@infradead.org>,
	"Frank Ch. Eigler" <fche@redhat.com>,
	"Jason Baron" <jbaron@redhat.com>,
	"K.Prasad" <prasad@linux.vnet.ibm.com>,
	"Lai Jiangshan" <laijs@cn.fujitsu.com>,
	"Li Zefan" <lizf@cn.fujitsu.com>,
	PrzemysławPawełczyk <przemyslaw@pawelczyk.it>
Subject: Re: [PATCH -tip v14 01/12] x86: instruction decoder API
Date: Thu, 20 Aug 2009 15:01:25 -0400	[thread overview]
Message-ID: <4A8D9D85.50809@redhat.com> (raw)
In-Reply-To: <20090820180737.GA6229@nowhere>

Frederic Weisbecker wrote:
> On Thu, Aug 20, 2009 at 12:16:05PM -0400, Masami Hiramatsu wrote:
>> Frederic Weisbecker wrote:
>>> On Thu, Aug 20, 2009 at 11:03:40AM -0400, Masami Hiramatsu wrote:
>>>> Frederic Weisbecker wrote:
>>>>> On Thu, Aug 20, 2009 at 01:42:31AM +0200, Frederic Weisbecker wrote:
>>>>>> On Thu, Aug 13, 2009 at 04:34:13PM -0400, Masami Hiramatsu wrote:
>>>>>>> Add x86 instruction decoder to arch-specific libraries. This decoder
>>>>>>> can decode x86 instructions used in kernel into prefix, opcode, modrm,
>>>>>>> sib, displacement and immediates. This can also show the length of
>>>>>>> instructions.
>>>>>>>
>>>>>>> This version introduces instruction attributes for decoding instructions.
>>>>>>> The instruction attribute tables are generated from the opcode map file
>>>>>>> (x86-opcode-map.txt) by the generator script(gen-insn-attr-x86.awk).
>>>>>>>
>>>>>>> Currently, the opcode maps are based on opcode maps in Intel(R) 64 and
>>>>>>> IA-32 Architectures Software Developers Manual Vol.2: Appendix.A,
>>>>>>> and consist of below two types of opcode tables.
>>>>>>>
>>>>>>> 1-byte/2-bytes/3-bytes opcodes, which has 256 elements, are
>>>>>>> written as below;
>>>>>>>
>>>>>>>     Table: table-name
>>>>>>>     Referrer: escaped-name
>>>>>>>     opcode: mnemonic|GrpXXX [operand1[,operand2...]] [(extra1)[,(extra2)...] [| 2nd-mnemonic ...]
>>>>>>>      (or)
>>>>>>>     opcode: escape # escaped-name
>>>>>>>     EndTable
>>>>>>>
>>>>>>> Group opcodes, which has 8 elements, are written as below;
>>>>>>>
>>>>>>>     GrpTable: GrpXXX
>>>>>>>     reg:  mnemonic [operand1[,operand2...]] [(extra1)[,(extra2)...] [| 2nd-mnemonic ...]
>>>>>>>     EndTable
>>>>>>>
>>>>>>> These opcode maps include a few SSE and FP opcodes (for setup), because
>>>>>>> those opcodes are used in the kernel.
>>>>>>>
>>>>>>
>>>>>>
>>>>>> I'm getting the following build error on an old K7 box:
>>>>>>
>>>>>> arch/x86/lib/inat.c: In function ‘inat_get_opcode_attribute’:
>>>>>> arch/x86/lib/inat.c:29: erreur: ‘inat_primary_table’ undeclared (first use in this function)
>>>>>> arch/x86/lib/inat.c:29: erreur: (Each undeclared identifier is reported only once
>>>>>> arch/x86/lib/inat.c:29: erreur: for each function it appears in.)
>>>>>>
>>>>>>
>>>>>> I've attached my config. I haven't such problem on a dual x86-64 box.
>>>>>
>>>>>
>>>>> Actually I have the same problem in x86-64
>>>>> The content of my arch/x86/lib/inat-tables.c:
>>>>>
>>>>> /* x86 opcode map generated from x86-opcode-map.txt */
>>>>> /* Do not change this code. */
>>>>> /* Table: one byte opcode */
>>>>> /* Escape opcode map array */
>>>>> const insn_attr_t const *inat_escape_tables[INAT_ESC_MAX + 1][INAT_LPREFIX_MAX + 1] = {
>>>>> };
>>>>>
>>>>> /* Group opcode map array */
>>>>> const insn_attr_t const *inat_group_tables[INAT_GRP_MAX + 1][INAT_LPREFIX_MAX + 1] = {
>>>>> };
>>>>>
>>>>>
>>>>> I guess there is a problem with the generation of this file.
>>>>
>>>> Aah, you may use mawk on Ubuntu 9.04, right?
>>>> If so, unfortunately, mawk is still under development.
>>>>
>>>> http://invisible-island.net/mawk/CHANGES
>>>
>>>
>>>
>>> Aargh...
>>>
>>>
>>>>> 20090727
>>>>> 	add check/fix to prevent gsub from recurring to modify on a substring
>>>>> 	of the current line when the regular expression is anchored to the
>>>>> 	beginning of the line; fixes gawk's anchgsub testcase.
>>>>>
>>>>> 	add check for implicit concatenation mistaken for exponent; fixes
>>>>> 	gawk's hex testcase.
>>>>>
>>>>> 	add character-classes to built-in regular expressions.
>>>>           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
>>>> Look, this means we can't use char-class expressions like
>>>> [:lower:] until this version...
>>>>
>>>> And I've found another bug in mawk-1.3.3-20090728(the latest one).
>>>> it almost works, but;
>>>>
>>>> $ mawk 'BEGIN {printf("0x%x\n", 0)}'
>>>> 0x1
>>>
>>>
>>> Ouch, indeed.
>>>
>>>
>>>
>>>> $ gawk 'BEGIN {printf("0x%x\n", 0)}'
>>>> 0x0
>>>>
>>>> This bug skips an array element index 0x0 in inat-tables.c :(
>>>>
>>>> So, I recommend you to install gawk instead mawk until that
>>>> supports all posix-awk features, since I don't think it is
>>>> good idea to avoid all those bugs which depends on
>>>> implementation (not specification).
>>>>
>>>>
>>>> Thank you,
>>>
>>>
>>>
>>> Yeah, indeed. May be add a warning (or build error) in case the user uses
>>> mawk?
>>
>> Hmm, it is possible that mawk will fix those bugs and catch up soon,
>> so, I think checking mawk is not a good idea.
>> (and since there will be other awk implementations, it's not fair.)
>>
>> I think what all I can do now is reporting bugs to
>> mawk and ubuntu people.:-)
>
>
>
> Yeah, but without your tip I couldn't be able to find the origin
> before some time.
> And the kernel couldn't build anyway.
>
> At least we should do something with this version of mawk.

Hm, indeed.
Maybe, we can run additional sanity check script before using
awk, like this;

---
res=`echo a | $AWK '/[[:lower:]]+/{print "OK"}'`
[ "$res" != "OK" ] && exit 1

res=`$AWK 'BEGIN {printf("%x", 0)}'`
[ "$res" != "0" ] && exit 1

exit 0
---

Thanks,

-- 
Masami Hiramatsu

Software Engineer
Hitachi Computer Products (America), Inc.
Software Solutions Division

e-mail: mhiramat@redhat.com

  reply	other threads:[~2009-08-20 18:59 UTC|newest]

Thread overview: 79+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-08-13 20:34 [PATCH -tip v14 00/12] tracing: kprobe-based event tracer and x86 instruction decoder Masami Hiramatsu
2009-08-13 20:34 ` Masami Hiramatsu
2009-08-13 20:34 ` [PATCH -tip v14 01/12] x86: instruction decoder API Masami Hiramatsu
2009-08-13 20:34   ` Masami Hiramatsu
2009-08-19 23:42   ` Frederic Weisbecker
2009-08-20  0:21     ` Frederic Weisbecker
2009-08-20 15:03       ` Masami Hiramatsu
2009-08-20 15:03         ` Masami Hiramatsu
2009-08-20 15:25         ` Frederic Weisbecker
2009-08-20 16:16           ` Masami Hiramatsu
2009-08-20 16:16             ` Masami Hiramatsu
2009-08-20 18:07             ` Frederic Weisbecker
2009-08-20 19:01               ` Masami Hiramatsu [this message]
2009-08-20 19:01                 ` Masami Hiramatsu
2009-08-20 20:14                 ` Frederic Weisbecker
2009-08-20 14:42     ` Masami Hiramatsu
2009-08-20 14:42       ` Masami Hiramatsu
2009-08-20 14:46       ` Frederic Weisbecker
2009-08-13 20:34 ` [PATCH -tip v14 02/12] x86: x86 instruction decoder build-time selftest Masami Hiramatsu
2009-08-13 20:34   ` Masami Hiramatsu
2009-08-13 20:34 ` [PATCH -tip v14 03/12] kprobes: checks probe address is instruction boudary on x86 Masami Hiramatsu
2009-08-13 20:34   ` Masami Hiramatsu
2009-08-18 23:03   ` Frederic Weisbecker
2009-08-18 23:17     ` Masami Hiramatsu
2009-08-18 23:17       ` Masami Hiramatsu
2009-08-18 23:43       ` Frederic Weisbecker
2009-08-19  0:19         ` Masami Hiramatsu
2009-08-19  0:19           ` Masami Hiramatsu
2009-08-19  0:46           ` Frederic Weisbecker
2009-08-13 20:34 ` [PATCH -tip v14 04/12] kprobes: cleanup fix_riprel() using insn decoder " Masami Hiramatsu
2009-08-13 20:34   ` Masami Hiramatsu
2009-08-13 20:34 ` [PATCH -tip v14 05/12] x86: add pt_regs register and stack access APIs Masami Hiramatsu
2009-08-13 20:34   ` Masami Hiramatsu
2009-08-13 20:34   ` Masami Hiramatsu
2009-08-13 20:34   ` Masami Hiramatsu
2009-08-13 20:34 ` [PATCH -tip v14 06/12] tracing: ftrace dynamic ftrace_event_call support Masami Hiramatsu
2009-08-13 20:34   ` Masami Hiramatsu
2009-08-13 20:35 ` [PATCH -tip v14 07/12] tracing: Introduce TRACE_FIELD_ZERO() macro Masami Hiramatsu
2009-08-13 20:35   ` Masami Hiramatsu
2009-08-19  1:09   ` Frederic Weisbecker
2009-08-19  2:20     ` Masami Hiramatsu
2009-08-19  2:20       ` Masami Hiramatsu
2009-08-19 13:58       ` Frederic Weisbecker
2009-08-13 20:35 ` [PATCH -tip v14 08/12] tracing: add kprobe-based event tracer Masami Hiramatsu
2009-08-13 20:35   ` Masami Hiramatsu
2009-08-19  1:23   ` Frederic Weisbecker
2009-08-13 20:35 ` [PATCH -tip v14 09/12] tracing: Kprobe-tracer supports more than 6 arguments Masami Hiramatsu
2009-08-13 20:35   ` Masami Hiramatsu
2009-08-13 20:35 ` [PATCH -tip v14 10/12] tracing: Generate names for each kprobe event automatically Masami Hiramatsu
2009-08-13 20:35   ` Masami Hiramatsu
2009-08-13 20:35 ` [PATCH -tip v14 11/12] tracing: Kprobe tracer assigns new event ids for each event Masami Hiramatsu
2009-08-13 20:35   ` Masami Hiramatsu
2009-08-13 20:35 ` [PATCH -tip v14 12/12] tracing: Add kprobes event profiling interface Masami Hiramatsu
2009-08-13 20:35   ` Masami Hiramatsu
2009-08-13 20:57 ` [TOOL] kprobestest : Kprobe stress test tool Masami Hiramatsu
2009-08-13 20:57   ` Masami Hiramatsu
2009-08-20 18:43   ` Frederic Weisbecker
2009-08-20 19:45     ` Masami Hiramatsu
2009-08-20 19:45       ` Masami Hiramatsu
2009-08-21  0:01       ` Frederic Weisbecker
2009-08-21  1:00         ` Masami Hiramatsu
2009-08-21  1:00           ` Masami Hiramatsu
2009-08-21 19:43         ` [PATCH tracing/kprobes 1/4] x86: Fix x86 instruction decoder selftest to check only .text Masami Hiramatsu
2009-08-21 19:43           ` Masami Hiramatsu
2009-08-23 19:34           ` Frederic Weisbecker
2009-08-21 19:43         ` [PATCH tracing/kprobes 2/4] x86: Check awk features before generating inat-tables.c Masami Hiramatsu
2009-08-21 19:43           ` Masami Hiramatsu
2009-08-21 19:43         ` [PATCH tracing/kprobes 3/4] tracing/kprobes: Fix format typo in trace_kprobes Masami Hiramatsu
2009-08-21 19:43           ` Masami Hiramatsu
2009-08-21 19:43         ` [PATCH tracing/kprobes 4/4] tracing/kprobes: Change trace_arg to probe_arg Masami Hiramatsu
2009-08-21 19:43           ` Masami Hiramatsu
2009-08-13 20:59 ` [TOOL] c2kpe: C expression to kprobe event format converter Masami Hiramatsu
2009-08-13 20:59   ` Masami Hiramatsu
2009-08-13 21:05   ` Christoph Hellwig
2009-08-13 21:05     ` Christoph Hellwig
2009-08-30 19:50   ` Frederic Weisbecker
2009-08-31  4:14     ` Masami Hiramatsu
2009-08-31  4:14       ` Masami Hiramatsu
2009-08-31 22:14       ` Frederic Weisbecker

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=4A8D9D85.50809@redhat.com \
    --to=mhiramat@redhat.com \
    --cc=ak@linux.intel.com \
    --cc=ananth@in.ibm.com \
    --cc=avi@redhat.com \
    --cc=dle-develop@lists.sourceforge.net \
    --cc=fche@redhat.com \
    --cc=fweisbec@gmail.com \
    --cc=hch@infradead.org \
    --cc=hpa@zytor.com \
    --cc=jbaron@redhat.com \
    --cc=jkenisto@us.ibm.com \
    --cc=kvm@vger.kernel.org \
    --cc=laijs@cn.fujitsu.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=lizf@cn.fujitsu.com \
    --cc=mingo@elte.hu \
    --cc=prasad@linux.vnet.ibm.com \
    --cc=przemyslaw@pawelczyk.it \
    --cc=roland@redhat.com \
    --cc=rostedt@goodmis.org \
    --cc=sam@ravnborg.org \
    --cc=srikar@linux.vnet.ibm.com \
    --cc=systemtap@sources.redhat.com \
    --cc=tzanussi@gmail.com \
    --cc=vegard.nossum@gmail.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.