From: Bill Davidsen <davidsen@tmr.com>
To: Taro Okumichi <tarookumichi@gmail.com>
Cc: linux-kernel@vger.kernel.org
Subject: Re: visibility of linux source
Date: Tue, 29 Sep 2009 16:11:00 -0400 [thread overview]
Message-ID: <4AC269D4.4040605@tmr.com> (raw)
In-Reply-To: <25a94d2a0909281502u2bb383aemdb44f4af8ffdc9e7@mail.gmail.com>
Taro Okumichi wrote:
> I have written a gcc-tracer and html-formatter that shows
> Linux's init/main.c formatted as dynamic-html including:
> o expand macros by clicking on them
> o expand include directives
> o traverse c-structs
> Address:
> http://cfw.sourceforge.net/htmltag/init/main.c.pinfo.html
> I have only processed init/main.c (50mb mysql content)
> As far as I understand (maybe I am wrong) this kind of
> visibility is not achieved till now.
> Note:
> I tested firefox (3.5) and konqueror. The first page takes ~
> 10 Seconds to load, therefore be patient until the right
> side init/main.c content is shown (ajax fetch from a mysql db).
>
Just for the record, I tried seamonkey 1.1.17 and it works well there, as well.
I'll try the daily test version, but unless I find a problem assume it works,
using much code from Firefox{recent}.
I'd like to try with Chrome, I suspect it will be faster there.
> o Complete Preprocessor Trace:
> All Macro expansions where traced and can be clicked
> open to see how they expand and where the macro was
> defined.
> - to open a macro expansion: click the macro marked
> with a white box,
> + after the macro has been expanded you can:
> + click the macro name to get the macro definition location
> + a "<" link appears at the end of the macro expansion,
> click it to close the macro expansion again.
> - #ifdef etc. preprocessor directives
> can also be expanded. Blocks that are inactive are
> marked grey.
> - #include directives can be clicked to expand to the
> included file
>
> o Variable/function declares are Trace:
> Full struct type layout is traced and when a struct
> types is used you can click on the type declarator,
>
> To get going:
> 1. Browse to the end of init/main.c page:
> 2. click on
> "param_check_bool" it will expand to:
> param_check_bool __param_check ( initcall_debug , & (
> initcall_debug ) , int )[<]
> Click on param_check_bool again, it will sow the definition pos of
> the macro, click on "<" and it will close the expansion,
> You can recursively ascend into for instance expanding __param_check etc...
>
>
> I thought to share this link to inspire some real gcc experts
> or kernel hackers to implement this kind of feature in the production
> gcc, I was using gcc-4.2.1 to output a cpp and c-parse trace
> however the code is that kind of messy and would be of no
> use, easier to implement newly, I guess that it should be obvious
> what to do for for the right person. After getting the trace I use
> a simple perl script (also messy code that I'm kind of ashamed to
> publish) to format html.
>
> Implementation note:
>
> Using a ajax request to retrieve the html, the Mysql db
> content is ~ 50 mb for the whole of main.c. No optimization
> is done, so this includes lots of redundant entries.
>
> The left index frame should not be used, the javascript code
> is kind of buggy, so only use the right frame where the code
> is shown.
>
> Also: There is a bug in when closing a "include" directive section:
> (At least in firefox) A new windows will pop up (I didnt find out
> why this is the case). Click the window to the back and continue
> (not closing it otherwise the next #include directive opens it again...
>
> Have fun
> -- Tkokum
--
Bill Davidsen <davidsen@tmr.com>
"We have more to fear from the bungling of the incompetent than from
the machinations of the wicked." - from Slashdot
prev parent reply other threads:[~2009-09-29 20:11 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-09-28 22:02 visibility of linux source Taro Okumichi
2009-09-29 0:22 ` Florian Mickler
2009-09-29 2:07 ` Américo Wang
2009-09-29 20:11 ` Bill Davidsen [this message]
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=4AC269D4.4040605@tmr.com \
--to=davidsen@tmr.com \
--cc=linux-kernel@vger.kernel.org \
--cc=tarookumichi@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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox