From: Frank Rowand <frowand.list-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
To: David Gibson <david-xT8FGy+AXnRB3Ne2BGzF6laj5H9X9Tb+@public.gmane.org>
Cc: jdl-CYoMK+44s/E@public.gmane.org,
devicetree-compiler-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
Subject: Re: [RFC PATCH v6 2/3] dtc: dts source location annotation
Date: Tue, 06 Oct 2015 23:58:22 -0700 [thread overview]
Message-ID: <5614C28E.9080708@gmail.com> (raw)
In-Reply-To: <20151007053246.GS3861-RXTfZT5YzpxwFLYp8hBm2A@public.gmane.org>
On 10/6/2015 10:32 PM, David Gibson wrote:
> On Tue, Oct 06, 2015 at 12:45:34AM -0700, Frank Rowand wrote:
>> On 10/5/2015 9:56 PM, David Gibson wrote:
>>> On Fri, Oct 02, 2015 at 09:52:48PM -0700, Frank Rowand wrote:
>>>> From: Frank Rowand <frank.rowand-/MT0OVThwyLZJqsBc5GL+g@public.gmane.org>
>>>>
>>>> Proof of concept patch.
>>>>
>>>> Annotates input source file and line number of nodes and properties
>>>> as comments in output .dts file when --annotate flag is supplied.
>>
>> < snip >
>>
>>
>>>> Index: b/srcpos.c
>>>> ===================================================================
>>>> --- a/srcpos.c
>>>> +++ b/srcpos.c
>>>> @@ -246,6 +246,41 @@ srcpos_copy(struct srcpos *pos)
>>>> return pos_new;
>>>> }
>>>>
>>>> +struct srcpos *
>>>> +srcpos_copy_all(struct srcpos *pos)
>>>> +{
>>>> + struct srcpos *pos_new;
>>>> + struct srcfile_state *srcfile_state;
>>>> +
>>>> + if (!pos)
>>>> + return NULL;
>>>> +
>>>> + pos_new = srcpos_copy(pos);
>>>> +
>>>> + if (pos_new) {
>>>> + /* allocate without free */
>>>> + srcfile_state = xmalloc(sizeof(struct srcfile_state));
>>>> + memcpy(srcfile_state, pos->file, sizeof(struct srcfile_state));
>>>> +
>>>> + pos_new->file = srcfile_state;
>>>> + }
>>>> +
>>>> + return pos_new;
>>>> +}
>>>
>>> You still don't need this function. srcfile_states have unlimited
>>> lifetime.
>>
>> My observation about this is buried in a late reply to v5, so
>> copying here:
>>
>> If I don't allocate a new copy of pos->file, then the file names are
>> incorrect. I'm not sure why. I can dig into this deeper to try to
>> understand what is going on if you want me to.
>>
>> It sounds like I do need to debug this.
>
> That's weird. Yeah, we need to debug this.
OK, I will dig into this.
> Btw, I was thinking about the filenames - in particular the way the
> current draft will give you very unwield full paths. I was thinking
> about a different approach which should shorten those without
> requiring different invocation or hand hacking:
> * For the "base" dts file (the one passed on the command line),
> always use just the basename (i.e. final piece of the file path)
> * For all other files, print the relative path from the directory
> of the base file
>
> /include/ directives already open files relative to the directory of
> the file including the /include/ so we have some of the mechanisms for
> this already.
>
> I think this will require a moderate amount of extra work, so I
> wouldn't suggest it for the first cut, but does it sound like a good
> approach in principle to you?
Yes, I think that is a great way to approach it. I'll take a look at
how much work this is, and if small enough I will add another patch
to the end of the series to do this.
-Frank
next prev parent reply other threads:[~2015-10-07 6:58 UTC|newest]
Thread overview: 14+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-10-03 4:44 [RFC PATCH v6 0/2] dtc: dts source location annotation Frank Rowand
[not found] ` <560F5D15.9060606-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2015-10-03 4:49 ` [RFC PATCH v6 1/3] dtc: protect against null pointer dereference in srcpos_string() Frank Rowand
[not found] ` <560F5E44.9080006-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2015-10-06 4:10 ` David Gibson
[not found] ` <20151006041000.GI3861-RXTfZT5YzpxwFLYp8hBm2A@public.gmane.org>
2015-10-06 7:32 ` Frank Rowand
[not found] ` <56137904.9080203-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2015-10-06 10:46 ` David Gibson
2015-10-03 4:52 ` [RFC PATCH v6 2/3] dtc: dts source location annotation Frank Rowand
[not found] ` <560F5F20.30709-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2015-10-06 4:56 ` David Gibson
[not found] ` <20151006045607.GK3861-RXTfZT5YzpxwFLYp8hBm2A@public.gmane.org>
2015-10-06 7:38 ` Frank Rowand
[not found] ` <56137A6B.6080805-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2015-10-07 5:27 ` David Gibson
2015-10-06 7:45 ` Frank Rowand
[not found] ` <56137C1E.8060005-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2015-10-07 5:32 ` David Gibson
[not found] ` <20151007053246.GS3861-RXTfZT5YzpxwFLYp8hBm2A@public.gmane.org>
2015-10-07 6:58 ` Frank Rowand [this message]
[not found] ` <560F5FB5.3020602@gmail.com>
[not found] ` <560F5FB5.3020602-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2015-10-06 5:01 ` [RFC PATCH v6 3/3] dtc: dts source location annotation, short location format David Gibson
[not found] ` <20151006050114.GL3861-RXTfZT5YzpxwFLYp8hBm2A@public.gmane.org>
2015-10-06 7:32 ` Frank Rowand
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=5614C28E.9080708@gmail.com \
--to=frowand.list-re5jqeeqqe8avxtiumwx3w@public.gmane.org \
--cc=david-xT8FGy+AXnRB3Ne2BGzF6laj5H9X9Tb+@public.gmane.org \
--cc=devicetree-compiler-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=jdl-CYoMK+44s/E@public.gmane.org \
/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.