* docbook: fix fatal error in linux/input.h
@ 2010-10-26 18:45 Randy Dunlap
2010-10-26 19:13 ` Mauro Carvalho Chehab
2010-10-29 17:56 ` [PATCH] scripts/kernel-doc: escape special characters for xml struct output Randy Dunlap
0 siblings, 2 replies; 12+ messages in thread
From: Randy Dunlap @ 2010-10-26 18:45 UTC (permalink / raw)
To: lkml; +Cc: Mauro Carvalho Chehab, Dmitry Torokhov
Hi,
Recent commit 8613e4c2872a87cc309a42de2c7091744dc54d0e:
Author: Mauro Carvalho Chehab <mchehab@redhat.com>
Date: Thu Sep 9 21:54:22 2010 -0700
Input: add support for large scancodes
causes a fatal error in docbook generation:
linux-2.6.36-git8/DOC1/Documentation/DocBook/device-drivers.xml:40690: parser error : StartTag: invalid element name
#define INPUT_KEYMAP_BY_INDEX (1 << 0)
^
I think that this message comes from xsltproc, but I'm not positive about that.
I also don't know of a really good fix for it. However, I did find 2 ways to
work around the error:
a/ move the #define value to after the end of the struct input_keymap_entry, like:
/* flags bits: */
#define INPUT_KEYMAP_BY_INDEX (1 << 0)
or
b/ don't use the "<< 0" (can leave the #define where it is in this case):
#define INPUT_KEYMAP_BY_INDEX (1)
I have tested both of these patches and they work OK.
Are you OK with either of them? or want to choose one?
thanks,
---
~Randy
*** Remember to use Documentation/SubmitChecklist when testing your code ***
^ permalink raw reply [flat|nested] 12+ messages in thread* Re: docbook: fix fatal error in linux/input.h 2010-10-26 18:45 docbook: fix fatal error in linux/input.h Randy Dunlap @ 2010-10-26 19:13 ` Mauro Carvalho Chehab 2010-10-26 19:17 ` Randy Dunlap 2010-10-29 17:56 ` [PATCH] scripts/kernel-doc: escape special characters for xml struct output Randy Dunlap 1 sibling, 1 reply; 12+ messages in thread From: Mauro Carvalho Chehab @ 2010-10-26 19:13 UTC (permalink / raw) To: Randy Dunlap; +Cc: lkml, Dmitry Torokhov Em 26-10-2010 16:45, Randy Dunlap escreveu: > Hi, > > Recent commit 8613e4c2872a87cc309a42de2c7091744dc54d0e: > Author: Mauro Carvalho Chehab <mchehab@redhat.com> > Date: Thu Sep 9 21:54:22 2010 -0700 > Input: add support for large scancodes > > causes a fatal error in docbook generation: > > linux-2.6.36-git8/DOC1/Documentation/DocBook/device-drivers.xml:40690: parser error : StartTag: invalid element name > #define INPUT_KEYMAP_BY_INDEX (1 << 0) > ^ > > I think that this message comes from xsltproc, but I'm not positive about that. > I also don't know of a really good fix for it. However, I did find 2 ways to > work around the error: > > a/ move the #define value to after the end of the struct input_keymap_entry, like: > > /* flags bits: */ > #define INPUT_KEYMAP_BY_INDEX (1 << 0) > > or > b/ don't use the "<< 0" (can leave the #define where it is in this case): > #define INPUT_KEYMAP_BY_INDEX (1) > > I have tested both of these patches and they work OK. > Are you OK with either of them? or want to choose one? Hmm... probably, the first one is not correct. I suspect that the right way is to use something like: #define INPUT_KEYMAP_BY_INDEX (1 << 0) Could you please test if this would fix the issue? Thanks, Mauro ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: docbook: fix fatal error in linux/input.h 2010-10-26 19:13 ` Mauro Carvalho Chehab @ 2010-10-26 19:17 ` Randy Dunlap 2010-10-26 20:08 ` Mauro Carvalho Chehab 2010-10-26 20:15 ` Mauro Carvalho Chehab 0 siblings, 2 replies; 12+ messages in thread From: Randy Dunlap @ 2010-10-26 19:17 UTC (permalink / raw) To: Mauro Carvalho Chehab; +Cc: lkml, Dmitry Torokhov On Tue, 26 Oct 2010 17:13:01 -0200 Mauro Carvalho Chehab wrote: > Em 26-10-2010 16:45, Randy Dunlap escreveu: > > Hi, > > > > Recent commit 8613e4c2872a87cc309a42de2c7091744dc54d0e: > > Author: Mauro Carvalho Chehab <mchehab@redhat.com> > > Date: Thu Sep 9 21:54:22 2010 -0700 > > Input: add support for large scancodes > > > > causes a fatal error in docbook generation: > > > > linux-2.6.36-git8/DOC1/Documentation/DocBook/device-drivers.xml:40690: parser error : StartTag: invalid element name > > #define INPUT_KEYMAP_BY_INDEX (1 << 0) > > ^ > > > > I think that this message comes from xsltproc, but I'm not positive about that. > > I also don't know of a really good fix for it. However, I did find 2 ways to > > work around the error: > > > > a/ move the #define value to after the end of the struct input_keymap_entry, like: > > > > /* flags bits: */ > > #define INPUT_KEYMAP_BY_INDEX (1 << 0) > > > > or > > b/ don't use the "<< 0" (can leave the #define where it is in this case): > > #define INPUT_KEYMAP_BY_INDEX (1) > > > > I have tested both of these patches and they work OK. > > Are you OK with either of them? or want to choose one? > > > Hmm... probably, the first one is not correct. Why not? All it does is move the line to after the end of the struct. > I suspect that the right way is to use something like: > > #define INPUT_KEYMAP_BY_INDEX (1 << 0) > > Could you please test if this would fix the issue? You are suggesting putting that into include/linux/input.h ?? That would make sense if some tool converted "<<" to "<<". And that may be where the problem is, but I don't know those tools. --- ~Randy *** Remember to use Documentation/SubmitChecklist when testing your code *** ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: docbook: fix fatal error in linux/input.h 2010-10-26 19:17 ` Randy Dunlap @ 2010-10-26 20:08 ` Mauro Carvalho Chehab 2010-10-26 20:15 ` Mauro Carvalho Chehab 1 sibling, 0 replies; 12+ messages in thread From: Mauro Carvalho Chehab @ 2010-10-26 20:08 UTC (permalink / raw) To: Randy Dunlap; +Cc: lkml, Dmitry Torokhov Em 26-10-2010 17:17, Randy Dunlap escreveu: > On Tue, 26 Oct 2010 17:13:01 -0200 Mauro Carvalho Chehab wrote: > >> Em 26-10-2010 16:45, Randy Dunlap escreveu: >>> Hi, >>> >>> Recent commit 8613e4c2872a87cc309a42de2c7091744dc54d0e: >>> Author: Mauro Carvalho Chehab <mchehab@redhat.com> >>> Date: Thu Sep 9 21:54:22 2010 -0700 >>> Input: add support for large scancodes >>> >>> causes a fatal error in docbook generation: >>> >>> linux-2.6.36-git8/DOC1/Documentation/DocBook/device-drivers.xml:40690: parser error : StartTag: invalid element name >>> #define INPUT_KEYMAP_BY_INDEX (1 << 0) >>> ^ >>> >>> I think that this message comes from xsltproc, but I'm not positive about that. >>> I also don't know of a really good fix for it. However, I did find 2 ways to >>> work around the error: >>> >>> a/ move the #define value to after the end of the struct input_keymap_entry, like: >>> >>> /* flags bits: */ >>> #define INPUT_KEYMAP_BY_INDEX (1 << 0) >>> >>> or >>> b/ don't use the "<< 0" (can leave the #define where it is in this case): >>> #define INPUT_KEYMAP_BY_INDEX (1) >>> >>> I have tested both of these patches and they work OK. >>> Are you OK with either of them? or want to choose one? >> >> >> Hmm... probably, the first one is not correct. > > Why not? All it does is move the line to after the end of the struct. > >> I suspect that the right way is to use something like: >> >> #define INPUT_KEYMAP_BY_INDEX (1 << 0) >> >> Could you please test if this would fix the issue? > > You are suggesting putting that into include/linux/input.h ?? > > That would make sense if some tool converted "<<" to "<<". > And that may be where the problem is, but I don't know those tools. Well, if you don't do it, you may have other problems ;) Letting characters like <, > or & source code may generate wrong xml files, and may be bad interpreted by the xml tools. Btw, that Makefile patch I did to auto-generate some media files[1] use this logic to generate such files: ESCAPE = \ -e "s/&/\\&/g" \ -e "s/</\\</g" \ -e "s/>/\\>/g" $(MEDIA_DIR)/videodev2.h.xml: $(srctree)/include/linux/videodev2.h $(MEDIA_DIR)/v4l2.xml @$($(quiet)gen_xml) @( \ echo "<programlisting>") > $@ @( \ expand --tabs=8 < $< | \ sed $(ESCAPE) $(DOCUMENTED) | \ sed 's/i\.e\./&ie;/') >> $@ @( \ echo "</programlisting>") >> $@ [1] https://patchwork.kernel.org/patch/267932/ ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: docbook: fix fatal error in linux/input.h 2010-10-26 19:17 ` Randy Dunlap 2010-10-26 20:08 ` Mauro Carvalho Chehab @ 2010-10-26 20:15 ` Mauro Carvalho Chehab 2010-10-26 20:51 ` Randy Dunlap 2010-10-26 20:59 ` Randy Dunlap 1 sibling, 2 replies; 12+ messages in thread From: Mauro Carvalho Chehab @ 2010-10-26 20:15 UTC (permalink / raw) To: Randy Dunlap; +Cc: lkml, Dmitry Torokhov Em 26-10-2010 17:17, Randy Dunlap escreveu: > On Tue, 26 Oct 2010 17:13:01 -0200 Mauro Carvalho Chehab wrote: > >> Em 26-10-2010 16:45, Randy Dunlap escreveu: >>> Hi, >>> >>> Recent commit 8613e4c2872a87cc309a42de2c7091744dc54d0e: >>> Author: Mauro Carvalho Chehab <mchehab@redhat.com> >>> Date: Thu Sep 9 21:54:22 2010 -0700 >>> Input: add support for large scancodes >>> >>> causes a fatal error in docbook generation: >>> >>> linux-2.6.36-git8/DOC1/Documentation/DocBook/device-drivers.xml:40690: parser error : StartTag: invalid element name >>> #define INPUT_KEYMAP_BY_INDEX (1 << 0) >>> ^ >>> >>> I think that this message comes from xsltproc, but I'm not positive about that. >>> I also don't know of a really good fix for it. However, I did find 2 ways to >>> work around the error: >>> >>> a/ move the #define value to after the end of the struct input_keymap_entry, like: >>> >>> /* flags bits: */ >>> #define INPUT_KEYMAP_BY_INDEX (1 << 0) >>> >>> or >>> b/ don't use the "<< 0" (can leave the #define where it is in this case): >>> #define INPUT_KEYMAP_BY_INDEX (1) >>> >>> I have tested both of these patches and they work OK. >>> Are you OK with either of them? or want to choose one? >> >> >> Hmm... probably, the first one is not correct. > > Why not? All it does is move the line to after the end of the struct. > >> I suspect that the right way is to use something like: >> >> #define INPUT_KEYMAP_BY_INDEX (1 << 0) >> >> Could you please test if this would fix the issue? > > You are suggesting putting that into include/linux/input.h ?? > > That would make sense if some tool converted "<<" to "<<". > And that may be where the problem is, but I don't know those tools. Hmm... such rule is already at DocBook/Makefile: %.xml: %.c @$($(quiet)gen_xml) @( \ echo "<programlisting>"; \ expand --tabs=8 < $< | \ sed -e "s/&/\\&/g" \ -e "s/</\\</g" \ -e "s/>/\\>/g"; \ echo "</programlisting>") > $@ Not sure why this didn't work. It should have replaced the < from the c file. Maybe some patch broke Makefile? Cheers, Mauro. ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: docbook: fix fatal error in linux/input.h 2010-10-26 20:15 ` Mauro Carvalho Chehab @ 2010-10-26 20:51 ` Randy Dunlap 2010-10-26 20:59 ` Randy Dunlap 1 sibling, 0 replies; 12+ messages in thread From: Randy Dunlap @ 2010-10-26 20:51 UTC (permalink / raw) To: Mauro Carvalho Chehab; +Cc: lkml, Dmitry Torokhov On Tue, 26 Oct 2010 18:15:10 -0200 Mauro Carvalho Chehab wrote: > Em 26-10-2010 17:17, Randy Dunlap escreveu: > > On Tue, 26 Oct 2010 17:13:01 -0200 Mauro Carvalho Chehab wrote: > > > >> Em 26-10-2010 16:45, Randy Dunlap escreveu: > >>> Hi, > >>> > >>> Recent commit 8613e4c2872a87cc309a42de2c7091744dc54d0e: > >>> Author: Mauro Carvalho Chehab <mchehab@redhat.com> > >>> Date: Thu Sep 9 21:54:22 2010 -0700 > >>> Input: add support for large scancodes > >>> > >>> causes a fatal error in docbook generation: > >>> > >>> linux-2.6.36-git8/DOC1/Documentation/DocBook/device-drivers.xml:40690: parser error : StartTag: invalid element name > >>> #define INPUT_KEYMAP_BY_INDEX (1 << 0) > >>> ^ > >>> > >>> I think that this message comes from xsltproc, but I'm not positive about that. > >>> I also don't know of a really good fix for it. However, I did find 2 ways to > >>> work around the error: > >>> > >>> a/ move the #define value to after the end of the struct input_keymap_entry, like: > >>> > >>> /* flags bits: */ > >>> #define INPUT_KEYMAP_BY_INDEX (1 << 0) > >>> > >>> or > >>> b/ don't use the "<< 0" (can leave the #define where it is in this case): > >>> #define INPUT_KEYMAP_BY_INDEX (1) > >>> > >>> I have tested both of these patches and they work OK. > >>> Are you OK with either of them? or want to choose one? > >> > >> > >> Hmm... probably, the first one is not correct. > > > > Why not? All it does is move the line to after the end of the struct. > > > >> I suspect that the right way is to use something like: > >> > >> #define INPUT_KEYMAP_BY_INDEX (1 << 0) > >> > >> Could you please test if this would fix the issue? > > > > You are suggesting putting that into include/linux/input.h ?? > > > > That would make sense if some tool converted "<<" to "<<". > > And that may be where the problem is, but I don't know those tools. > > > Hmm... such rule is already at DocBook/Makefile: > > %.xml: %.c > @$($(quiet)gen_xml) > @( \ > echo "<programlisting>"; \ > expand --tabs=8 < $< | \ > sed -e "s/&/\\&/g" \ > -e "s/</\\</g" \ > -e "s/>/\\>/g"; \ > echo "</programlisting>") > $@ > > Not sure why this didn't work. It should have replaced the < from the c file. > Maybe some patch broke Makefile? Thanks, I'll look into that. --- ~Randy *** Remember to use Documentation/SubmitChecklist when testing your code *** ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: docbook: fix fatal error in linux/input.h 2010-10-26 20:15 ` Mauro Carvalho Chehab 2010-10-26 20:51 ` Randy Dunlap @ 2010-10-26 20:59 ` Randy Dunlap 2010-10-26 21:07 ` Randy Dunlap 1 sibling, 1 reply; 12+ messages in thread From: Randy Dunlap @ 2010-10-26 20:59 UTC (permalink / raw) To: Mauro Carvalho Chehab; +Cc: lkml, Dmitry Torokhov On Tue, 26 Oct 2010 18:15:10 -0200 Mauro Carvalho Chehab wrote: > Em 26-10-2010 17:17, Randy Dunlap escreveu: > > On Tue, 26 Oct 2010 17:13:01 -0200 Mauro Carvalho Chehab wrote: > > > >> Em 26-10-2010 16:45, Randy Dunlap escreveu: > >>> Hi, > >>> > >>> Recent commit 8613e4c2872a87cc309a42de2c7091744dc54d0e: > >>> Author: Mauro Carvalho Chehab <mchehab@redhat.com> > >>> Date: Thu Sep 9 21:54:22 2010 -0700 > >>> Input: add support for large scancodes > >>> > >>> causes a fatal error in docbook generation: > >>> > >>> linux-2.6.36-git8/DOC1/Documentation/DocBook/device-drivers.xml:40690: parser error : StartTag: invalid element name > >>> #define INPUT_KEYMAP_BY_INDEX (1 << 0) > >>> ^ > >>> > >>> I think that this message comes from xsltproc, but I'm not positive about that. > >>> I also don't know of a really good fix for it. However, I did find 2 ways to > >>> work around the error: > >>> > >>> a/ move the #define value to after the end of the struct input_keymap_entry, like: > >>> > >>> /* flags bits: */ > >>> #define INPUT_KEYMAP_BY_INDEX (1 << 0) > >>> > >>> or > >>> b/ don't use the "<< 0" (can leave the #define where it is in this case): > >>> #define INPUT_KEYMAP_BY_INDEX (1) > >>> > >>> I have tested both of these patches and they work OK. > >>> Are you OK with either of them? or want to choose one? > >> > >> > >> Hmm... probably, the first one is not correct. > > > > Why not? All it does is move the line to after the end of the struct. > > > >> I suspect that the right way is to use something like: > >> > >> #define INPUT_KEYMAP_BY_INDEX (1 << 0) > >> > >> Could you please test if this would fix the issue? > > > > You are suggesting putting that into include/linux/input.h ?? > > > > That would make sense if some tool converted "<<" to "<<". > > And that may be where the problem is, but I don't know those tools. > > > Hmm... such rule is already at DocBook/Makefile: > > %.xml: %.c > @$($(quiet)gen_xml) > @( \ > echo "<programlisting>"; \ > expand --tabs=8 < $< | \ > sed -e "s/&/\\&/g" \ > -e "s/</\\</g" \ > -e "s/>/\\>/g"; \ > echo "</programlisting>") > $@ > > Not sure why this didn't work. It should have replaced the < from the c file. > Maybe some patch broke Makefile? Maybe that rule needs to apply to .h files also. Would %.xml: %.[hc] work? --- ~Randy *** Remember to use Documentation/SubmitChecklist when testing your code *** ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: docbook: fix fatal error in linux/input.h 2010-10-26 20:59 ` Randy Dunlap @ 2010-10-26 21:07 ` Randy Dunlap 2010-10-26 21:32 ` Randy Dunlap 0 siblings, 1 reply; 12+ messages in thread From: Randy Dunlap @ 2010-10-26 21:07 UTC (permalink / raw) To: lkml; +Cc: Mauro Carvalho Chehab, Dmitry Torokhov On Tue, 26 Oct 2010 13:59:57 -0700 Randy Dunlap wrote: > On Tue, 26 Oct 2010 18:15:10 -0200 Mauro Carvalho Chehab wrote: > > > Em 26-10-2010 17:17, Randy Dunlap escreveu: > > > On Tue, 26 Oct 2010 17:13:01 -0200 Mauro Carvalho Chehab wrote: > > > > > >> Em 26-10-2010 16:45, Randy Dunlap escreveu: > > >>> Hi, > > >>> > > >>> Recent commit 8613e4c2872a87cc309a42de2c7091744dc54d0e: > > >>> Author: Mauro Carvalho Chehab <mchehab@redhat.com> > > >>> Date: Thu Sep 9 21:54:22 2010 -0700 > > >>> Input: add support for large scancodes > > >>> > > >>> causes a fatal error in docbook generation: > > >>> > > >>> linux-2.6.36-git8/DOC1/Documentation/DocBook/device-drivers.xml:40690: parser error : StartTag: invalid element name > > >>> #define INPUT_KEYMAP_BY_INDEX (1 << 0) > > >>> ^ > > >>> > > >>> I think that this message comes from xsltproc, but I'm not positive about that. > > >>> I also don't know of a really good fix for it. However, I did find 2 ways to > > >>> work around the error: > > >>> > > >>> a/ move the #define value to after the end of the struct input_keymap_entry, like: > > >>> > > >>> /* flags bits: */ > > >>> #define INPUT_KEYMAP_BY_INDEX (1 << 0) > > >>> > > >>> or > > >>> b/ don't use the "<< 0" (can leave the #define where it is in this case): > > >>> #define INPUT_KEYMAP_BY_INDEX (1) > > >>> > > >>> I have tested both of these patches and they work OK. > > >>> Are you OK with either of them? or want to choose one? > > >> > > >> > > >> Hmm... probably, the first one is not correct. > > > > > > Why not? All it does is move the line to after the end of the struct. > > > > > >> I suspect that the right way is to use something like: > > >> > > >> #define INPUT_KEYMAP_BY_INDEX (1 << 0) > > >> > > >> Could you please test if this would fix the issue? > > > > > > You are suggesting putting that into include/linux/input.h ?? > > > > > > That would make sense if some tool converted "<<" to "<<". > > > And that may be where the problem is, but I don't know those tools. > > > > > > Hmm... such rule is already at DocBook/Makefile: > > > > %.xml: %.c > > @$($(quiet)gen_xml) > > @( \ > > echo "<programlisting>"; \ > > expand --tabs=8 < $< | \ > > sed -e "s/&/\\&/g" \ > > -e "s/</\\</g" \ > > -e "s/>/\\>/g"; \ > > echo "</programlisting>") > $@ > > > > Not sure why this didn't work. It should have replaced the < from the c file. > > Maybe some patch broke Makefile? > > Maybe that rule needs to apply to .h files also. > > Would > > %.xml: %.[hc] > > work? Doesn't work like that or as a separate rule for %.xml: %.h The gen_xml rule isn't firing at all AFAICT. --- ~Randy *** Remember to use Documentation/SubmitChecklist when testing your code *** ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: docbook: fix fatal error in linux/input.h 2010-10-26 21:07 ` Randy Dunlap @ 2010-10-26 21:32 ` Randy Dunlap 2010-10-26 21:41 ` Dmitry Torokhov 0 siblings, 1 reply; 12+ messages in thread From: Randy Dunlap @ 2010-10-26 21:32 UTC (permalink / raw) To: lkml; +Cc: Mauro Carvalho Chehab, Dmitry Torokhov On Tue, 26 Oct 2010 14:07:26 -0700 Randy Dunlap wrote: > On Tue, 26 Oct 2010 13:59:57 -0700 Randy Dunlap wrote: > > > On Tue, 26 Oct 2010 18:15:10 -0200 Mauro Carvalho Chehab wrote: > > > > > Em 26-10-2010 17:17, Randy Dunlap escreveu: > > > > On Tue, 26 Oct 2010 17:13:01 -0200 Mauro Carvalho Chehab wrote: > > > > > > > >> Em 26-10-2010 16:45, Randy Dunlap escreveu: > > > >>> Hi, > > > >>> > > > >>> Recent commit 8613e4c2872a87cc309a42de2c7091744dc54d0e: > > > >>> Author: Mauro Carvalho Chehab <mchehab@redhat.com> > > > >>> Date: Thu Sep 9 21:54:22 2010 -0700 > > > >>> Input: add support for large scancodes > > > >>> > > > >>> causes a fatal error in docbook generation: > > > >>> > > > >>> linux-2.6.36-git8/DOC1/Documentation/DocBook/device-drivers.xml:40690: parser error : StartTag: invalid element name > > > >>> #define INPUT_KEYMAP_BY_INDEX (1 << 0) > > > >>> ^ > > > >>> > > > >>> I think that this message comes from xsltproc, but I'm not positive about that. > > > >>> I also don't know of a really good fix for it. However, I did find 2 ways to > > > >>> work around the error: > > > >>> > > > >>> a/ move the #define value to after the end of the struct input_keymap_entry, like: > > > >>> > > > >>> /* flags bits: */ > > > >>> #define INPUT_KEYMAP_BY_INDEX (1 << 0) > > > >>> > > > >>> or > > > >>> b/ don't use the "<< 0" (can leave the #define where it is in this case): > > > >>> #define INPUT_KEYMAP_BY_INDEX (1) > > > >>> > > > >>> I have tested both of these patches and they work OK. > > > >>> Are you OK with either of them? or want to choose one? > > > >> > > > >> > > > >> Hmm... probably, the first one is not correct. > > > > > > > > Why not? All it does is move the line to after the end of the struct. > > > > > > > >> I suspect that the right way is to use something like: > > > >> > > > >> #define INPUT_KEYMAP_BY_INDEX (1 << 0) > > > >> > > > >> Could you please test if this would fix the issue? > > > > > > > > You are suggesting putting that into include/linux/input.h ?? > > > > > > > > That would make sense if some tool converted "<<" to "<<". > > > > And that may be where the problem is, but I don't know those tools. > > > > > > > > > Hmm... such rule is already at DocBook/Makefile: > > > > > > %.xml: %.c > > > @$($(quiet)gen_xml) > > > @( \ > > > echo "<programlisting>"; \ > > > expand --tabs=8 < $< | \ > > > sed -e "s/&/\\&/g" \ > > > -e "s/</\\</g" \ > > > -e "s/>/\\>/g"; \ > > > echo "</programlisting>") > $@ > > > > > > Not sure why this didn't work. It should have replaced the < from the c file. > > > Maybe some patch broke Makefile? > > > > Maybe that rule needs to apply to .h files also. > > > > Would > > > > %.xml: %.[hc] > > > > work? > > Doesn't work like that or as a separate rule for > %.xml: %.h > > The gen_xml rule isn't firing at all AFAICT. That rule was used for procfs_exmaple.c in 2.6.33 and earlier. It's no longer used/needed (but I'm in no hurry to delete it either). It appears that scripts/kernel-doc is the problem with not converting <,> to <, > etc. I'll look into that. --- ~Randy *** Remember to use Documentation/SubmitChecklist when testing your code *** ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: docbook: fix fatal error in linux/input.h 2010-10-26 21:32 ` Randy Dunlap @ 2010-10-26 21:41 ` Dmitry Torokhov 2010-10-26 21:58 ` Randy Dunlap 0 siblings, 1 reply; 12+ messages in thread From: Dmitry Torokhov @ 2010-10-26 21:41 UTC (permalink / raw) To: Randy Dunlap; +Cc: lkml, Mauro Carvalho Chehab On Tue, Oct 26, 2010 at 02:32:02PM -0700, Randy Dunlap wrote: > On Tue, 26 Oct 2010 14:07:26 -0700 Randy Dunlap wrote: > > > On Tue, 26 Oct 2010 13:59:57 -0700 Randy Dunlap wrote: > > > > > On Tue, 26 Oct 2010 18:15:10 -0200 Mauro Carvalho Chehab wrote: > > > > > > > Em 26-10-2010 17:17, Randy Dunlap escreveu: > > > > > On Tue, 26 Oct 2010 17:13:01 -0200 Mauro Carvalho Chehab wrote: > > > > > > > > > >> Em 26-10-2010 16:45, Randy Dunlap escreveu: > > > > >>> Hi, > > > > >>> > > > > >>> Recent commit 8613e4c2872a87cc309a42de2c7091744dc54d0e: > > > > >>> Author: Mauro Carvalho Chehab <mchehab@redhat.com> > > > > >>> Date: Thu Sep 9 21:54:22 2010 -0700 > > > > >>> Input: add support for large scancodes > > > > >>> > > > > >>> causes a fatal error in docbook generation: > > > > >>> > > > > >>> linux-2.6.36-git8/DOC1/Documentation/DocBook/device-drivers.xml:40690: parser error : StartTag: invalid element name > > > > >>> #define INPUT_KEYMAP_BY_INDEX (1 << 0) > > > > >>> ^ > > > > >>> > > > > >>> I think that this message comes from xsltproc, but I'm not positive about that. > > > > >>> I also don't know of a really good fix for it. However, I did find 2 ways to > > > > >>> work around the error: > > > > >>> > > > > >>> a/ move the #define value to after the end of the struct input_keymap_entry, like: > > > > >>> > > > > >>> /* flags bits: */ > > > > >>> #define INPUT_KEYMAP_BY_INDEX (1 << 0) > > > > >>> > > > > >>> or > > > > >>> b/ don't use the "<< 0" (can leave the #define where it is in this case): > > > > >>> #define INPUT_KEYMAP_BY_INDEX (1) > > > > >>> > > > > >>> I have tested both of these patches and they work OK. > > > > >>> Are you OK with either of them? or want to choose one? > > > > >> > > > > >> > > > > >> Hmm... probably, the first one is not correct. > > > > > > > > > > Why not? All it does is move the line to after the end of the struct. > > > > > > > > > >> I suspect that the right way is to use something like: > > > > >> > > > > >> #define INPUT_KEYMAP_BY_INDEX (1 << 0) > > > > >> > > > > >> Could you please test if this would fix the issue? > > > > > > > > > > You are suggesting putting that into include/linux/input.h ?? > > > > > > > > > > That would make sense if some tool converted "<<" to "<<". > > > > > And that may be where the problem is, but I don't know those tools. > > > > > > > > > > > > Hmm... such rule is already at DocBook/Makefile: > > > > > > > > %.xml: %.c > > > > @$($(quiet)gen_xml) > > > > @( \ > > > > echo "<programlisting>"; \ > > > > expand --tabs=8 < $< | \ > > > > sed -e "s/&/\\&/g" \ > > > > -e "s/</\\</g" \ > > > > -e "s/>/\\>/g"; \ > > > > echo "</programlisting>") > $@ > > > > > > > > Not sure why this didn't work. It should have replaced the < from the c file. > > > > Maybe some patch broke Makefile? > > > > > > Maybe that rule needs to apply to .h files also. > > > > > > Would > > > > > > %.xml: %.[hc] > > > > > > work? > > > > Doesn't work like that or as a separate rule for > > %.xml: %.h > > > > The gen_xml rule isn't firing at all AFAICT. > > That rule was used for procfs_exmaple.c in 2.6.33 and earlier. > It's no longer used/needed (but I'm in no hurry to delete it either). > > It appears that scripts/kernel-doc is the problem with not converting > <,> to <, > etc. I'll look into that. > Thnaks Randy. I'd prefer not to impose restrictions on the kernel code for the sake of kerneldoc tools. -- Dmitry ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: docbook: fix fatal error in linux/input.h 2010-10-26 21:41 ` Dmitry Torokhov @ 2010-10-26 21:58 ` Randy Dunlap 0 siblings, 0 replies; 12+ messages in thread From: Randy Dunlap @ 2010-10-26 21:58 UTC (permalink / raw) To: Dmitry Torokhov; +Cc: lkml, Mauro Carvalho Chehab On Tue, 26 Oct 2010 14:41:40 -0700 Dmitry Torokhov wrote: > On Tue, Oct 26, 2010 at 02:32:02PM -0700, Randy Dunlap wrote: > > On Tue, 26 Oct 2010 14:07:26 -0700 Randy Dunlap wrote: > > > > > On Tue, 26 Oct 2010 13:59:57 -0700 Randy Dunlap wrote: > > > > > > > On Tue, 26 Oct 2010 18:15:10 -0200 Mauro Carvalho Chehab wrote: > > > > > > > > > Em 26-10-2010 17:17, Randy Dunlap escreveu: > > > > > > On Tue, 26 Oct 2010 17:13:01 -0200 Mauro Carvalho Chehab wrote: > > > > > > > > > > > >> Em 26-10-2010 16:45, Randy Dunlap escreveu: > > > > > >>> Hi, > > > > > >>> > > > > > >>> Recent commit 8613e4c2872a87cc309a42de2c7091744dc54d0e: > > > > > >>> Author: Mauro Carvalho Chehab <mchehab@redhat.com> > > > > > >>> Date: Thu Sep 9 21:54:22 2010 -0700 > > > > > >>> Input: add support for large scancodes > > > > > >>> > > > > > >>> causes a fatal error in docbook generation: > > > > > >>> > > > > > >>> linux-2.6.36-git8/DOC1/Documentation/DocBook/device-drivers.xml:40690: parser error : StartTag: invalid element name > > > > > >>> #define INPUT_KEYMAP_BY_INDEX (1 << 0) > > > > > >>> ^ > > > > > >>> > > > > > >>> I think that this message comes from xsltproc, but I'm not positive about that. > > > > > >>> I also don't know of a really good fix for it. However, I did find 2 ways to > > > > > >>> work around the error: > > > > > >>> > > > > > >>> a/ move the #define value to after the end of the struct input_keymap_entry, like: > > > > > >>> > > > > > >>> /* flags bits: */ > > > > > >>> #define INPUT_KEYMAP_BY_INDEX (1 << 0) > > > > > >>> > > > > > >>> or > > > > > >>> b/ don't use the "<< 0" (can leave the #define where it is in this case): > > > > > >>> #define INPUT_KEYMAP_BY_INDEX (1) > > > > > >>> > > > > > >>> I have tested both of these patches and they work OK. > > > > > >>> Are you OK with either of them? or want to choose one? > > > > > >> > > > > > >> > > > > > >> Hmm... probably, the first one is not correct. > > > > > > > > > > > > Why not? All it does is move the line to after the end of the struct. > > > > > > > > > > > >> I suspect that the right way is to use something like: > > > > > >> > > > > > >> #define INPUT_KEYMAP_BY_INDEX (1 << 0) > > > > > >> > > > > > >> Could you please test if this would fix the issue? > > > > > > > > > > > > You are suggesting putting that into include/linux/input.h ?? > > > > > > > > > > > > That would make sense if some tool converted "<<" to "<<". > > > > > > And that may be where the problem is, but I don't know those tools. > > > > > > > > > > > > > > > Hmm... such rule is already at DocBook/Makefile: > > > > > > > > > > %.xml: %.c > > > > > @$($(quiet)gen_xml) > > > > > @( \ > > > > > echo "<programlisting>"; \ > > > > > expand --tabs=8 < $< | \ > > > > > sed -e "s/&/\\&/g" \ > > > > > -e "s/</\\</g" \ > > > > > -e "s/>/\\>/g"; \ > > > > > echo "</programlisting>") > $@ > > > > > > > > > > Not sure why this didn't work. It should have replaced the < from the c file. > > > > > Maybe some patch broke Makefile? > > > > > > > > Maybe that rule needs to apply to .h files also. > > > > > > > > Would > > > > > > > > %.xml: %.[hc] > > > > > > > > work? > > > > > > Doesn't work like that or as a separate rule for > > > %.xml: %.h > > > > > > The gen_xml rule isn't firing at all AFAICT. > > > > That rule was used for procfs_exmaple.c in 2.6.33 and earlier. > > It's no longer used/needed (but I'm in no hurry to delete it either). > > > > It appears that scripts/kernel-doc is the problem with not converting > > <,> to <, > etc. I'll look into that. > > > > Thnaks Randy. I'd prefer not to impose restrictions on the kernel code > for the sake of kerneldoc tools. Yes, I agree, it was just a matter of finding a way thru the maze. --- ~Randy *** Remember to use Documentation/SubmitChecklist when testing your code *** ^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH] scripts/kernel-doc: escape special characters for xml struct output 2010-10-26 18:45 docbook: fix fatal error in linux/input.h Randy Dunlap 2010-10-26 19:13 ` Mauro Carvalho Chehab @ 2010-10-29 17:56 ` Randy Dunlap 1 sibling, 0 replies; 12+ messages in thread From: Randy Dunlap @ 2010-10-29 17:56 UTC (permalink / raw) To: lkml, akpm; +Cc: Mauro Carvalho Chehab, Dmitry Torokhov From: Randy Dunlap <randy.dunlap@oracle.com> scripts/kernel-doc was leaving unescaped '<', '>', and '&' in generated xml output for structs. This causes xml parser errors. Convert these characters to "<", ">", and "&" as needed to prevent errors. Most of the conversion was already done; complete it just before output. Documentation/DocBook/device-drivers.xml:41883: parser error : StartTag: invalid element name #define INPUT_KEYMAP_BY_INDEX (1 << 0) Signed-off-by: Randy Dunlap <randy.dunlap@oracle.com> --- scripts/kernel-doc | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) --- linux-2.6.36-git13.orig/scripts/kernel-doc +++ linux-2.6.36-git13/scripts/kernel-doc @@ -5,7 +5,7 @@ use strict; ## Copyright (c) 1998 Michael Zucchi, All Rights Reserved ## ## Copyright (C) 2000, 1 Tim Waugh <twaugh@redhat.com> ## ## Copyright (C) 2001 Simon Huggins ## -## Copyright (C) 2005-2009 Randy Dunlap ## +## Copyright (C) 2005-2010 Randy Dunlap ## ## ## ## #define enhancements by Armin Kuster <akuster@mvista.com> ## ## Copyright (c) 2000 MontaVista Software, Inc. ## @@ -453,7 +453,7 @@ sub output_highlight { if ($output_mode eq "html" || $output_mode eq "xml") { $contents = local_unescape($contents); # convert data read & converted thru xml_escape() into &xyz; format: - $contents =~ s/\\\\\\/&/g; + $contents =~ s/\\\\\\/\&/g; } # print STDERR "contents b4:$contents\n"; eval $dohighlight; @@ -770,7 +770,11 @@ sub output_struct_xml(%) { print $args{'type'} . " " . $args{'struct'} . " {\n"; foreach $parameter (@{$args{'parameterlist'}}) { if ($parameter =~ /^#/) { - print "$parameter\n"; + my $prm = $parameter; + # convert data read & converted thru xml_escape() into &xyz; format: + # This allows us to have #define macros interspersed in a struct. + $prm =~ s/\\\\\\/\&/g; + print "$prm\n"; next; } @@ -1701,6 +1705,8 @@ sub push_parameter($$$) { } } + $param = xml_escape($param); + # strip spaces from $param so that it is one continous string # on @parameterlist; # this fixes a problem where check_sections() cannot find ^ permalink raw reply [flat|nested] 12+ messages in thread
end of thread, other threads:[~2010-10-29 17:58 UTC | newest] Thread overview: 12+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2010-10-26 18:45 docbook: fix fatal error in linux/input.h Randy Dunlap 2010-10-26 19:13 ` Mauro Carvalho Chehab 2010-10-26 19:17 ` Randy Dunlap 2010-10-26 20:08 ` Mauro Carvalho Chehab 2010-10-26 20:15 ` Mauro Carvalho Chehab 2010-10-26 20:51 ` Randy Dunlap 2010-10-26 20:59 ` Randy Dunlap 2010-10-26 21:07 ` Randy Dunlap 2010-10-26 21:32 ` Randy Dunlap 2010-10-26 21:41 ` Dmitry Torokhov 2010-10-26 21:58 ` Randy Dunlap 2010-10-29 17:56 ` [PATCH] scripts/kernel-doc: escape special characters for xml struct output Randy Dunlap
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox