Message ID | 70318cbf0909141027y69ddecc2y591ffb6aca300fca@mail.gmail.com (mailing list archive) |
---|---|
State | Mainlined, archived |
Headers | show |
On Monday 14 of September 2009 19:27:40 Christopher Li wrote: > On Fri, Aug 28, 2009 at 2:44 PM, Christopher Li <sparse@chrisli.org> wrote: > > Yes, no return is kind of useful. I think we need to do some thing about > > the MOD_XXX eventually. It is very easy to run out of bits there. > > Ah, the MOD_NORETURN is bigger than size of long in 32 bit systems. > I just get a few warning from GCC. > > I just relocate the MOD_NORETURN bits. Thanks! It makes sense to me. As for the long term solution, I don't think it's possible without breaking the current API/ABI. What about using a bitfield instead? I can see it solved this way in <gcc/tree.h>. Kamil -- To unsubscribe from this list: send the line "unsubscribe linux-sparse" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
On Mon, Sep 14, 2009 at 10:32 AM, Kamil Dudka <kdudka@redhat.com> wrote: > As for the long term solution, I don't think it's possible without breaking > the current API/ABI. What about using a bitfield instead? I can see it solved > this way in <gcc/tree.h>. I am actually not afraid of breaking current API/ABI because there is not enough sparse user application to worry about. Just recompile the apps should be fine. Please warn me if any one disagree. As for long term, here is my plan, it will go will with Al's replace same type with same type pointer plan as well. We need to have a different structure to support the extended attributes for ctype. Current "contexts" and "as" should go into that extended attribute as well. Then ctype should have one pointer for extended attributes. For most common case, the extended attribute pointer is just NULL. Because the extended attribute pointer is possibles to be shared between different ctypes. It is not allow to modify the extended attribute struct from ctype directly. Instead it should replace with a new one. We can even hash the extended attribute struct so same attribute struct will have the same pointer, just like ident. That will make comparing attribute is the same much easier. I try it before, it is hard to do because current code does implicit assign for the ctype. Chris -- To unsubscribe from this list: send the line "unsubscribe linux-sparse" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
On Monday 14 of September 2009 19:55:49 Christopher Li wrote: > On Mon, Sep 14, 2009 at 10:32 AM, Kamil Dudka <kdudka@redhat.com> wrote: > > As for the long term solution, I don't think it's possible without > > breaking the current API/ABI. What about using a bitfield instead? I can > > see it solved this way in <gcc/tree.h>. > > I am actually not afraid of breaking current API/ABI because there is not > enough sparse user application to worry about. Just recompile the apps > should be fine. Please warn me if any one disagree. > > As for long term, here is my plan, it will go will with Al's replace same > type with same type pointer plan as well. > > We need to have a different structure to support the extended attributes > for ctype. Current "contexts" and "as" should go into that extended > attribute as well. Then ctype should have one pointer for extended > attributes. For most common case, the extended attribute pointer is just > NULL. > > Because the extended attribute pointer is possibles to be shared between > different ctypes. It is not allow to modify the extended attribute struct > from ctype directly. Instead it should replace with a new one. > We can even hash the extended attribute struct so same attribute struct > will have the same pointer, just like ident. That will make comparing > attribute is the same much easier. > > I try it before, it is hard to do because current code does implicit > assign for the ctype. It sounds like a tough challenge to me :-) I am playing with the SPARSE API now. Any chance to pass in a unique ID to each symbol? (as equivalent to DECL_UID from <gcc/tree.h>) I can of course manage an ptr/ID mapping at application level. I am only curious if this is possible to place directly into SPARSE, so that other apps could gain from it. Please let me know if such functionality is already implemented in SPARSE. Kamil -- To unsubscribe from this list: send the line "unsubscribe linux-sparse" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
On Mon, Sep 14, 2009 at 12:44 PM, Kamil Dudka <kdudka@redhat.com> wrote: > It sounds like a tough challenge to me :-) > > I am playing with the SPARSE API now. Any chance to pass in a unique ID > to each symbol? (as equivalent to DECL_UID from <gcc/tree.h>) I can of course > manage an ptr/ID mapping at application level. I am only curious if this is Can you clarify why do you need to use the UID instead of the pointer of symbol? One reason I can see is that if you want to dump the AST tree into objects on disk. Other application can read it back and load into memory. If the symbol already exist in the memory, you should be able to use pointer directly. BTW, I have code to dump most of the struct into disk already. I think I send to the list before. Of course I can create a branch for it. Reading is not completed yet. Chris -- To unsubscribe from this list: send the line "unsubscribe linux-sparse" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
On Monday 14 of September 2009 22:47:40 Christopher Li wrote: > Can you clarify why do you need to use the UID instead of the pointer of > symbol? One reason I can see is that if you want to dump the AST tree > into objects on disk. Other application can read it back and load into > memory. If the symbol already exist in the memory, you should be able to > use pointer directly. The only reason (for now) is that I already use them with the gcc plug-in and the code_listener interace is based on them. I don't think it *needs* to be implemented in SPARSE since the workaround is easy. I've only raised the idea in hope such enumeration might be generally useful. Adding Petr Peringer to CC. He came with UID idea to our project and might be able to give us better clarification for that approach. > BTW, I have code to dump most of the struct into disk already. I think > I send to the list before. Of course I can create a branch for it. Reading > is not completed yet. Thanks! Good to know something like that is available. But I don't think our project can gain from this functionality right now. Kamil -- To unsubscribe from this list: send the line "unsubscribe linux-sparse" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
diff --git a/symbol.h b/symbol.h index 80ef363..9f5a32f 100644 --- a/symbol.h +++ b/symbol.h @@ -214,10 +214,10 @@ struct symbol { #define MOD_SAFE 0x8000000 // non-null/non-trapping pointer #define MOD_USERTYPE 0x10000000 +#define MOD_NORETURN 0x20000000 #define MOD_EXPLICITLY_SIGNED 0x40000000 #define MOD_BITWISE 0x80000000 -#define MOD_NORETURN 0x100000000 #define MOD_NONLOCAL (MOD_EXTERN | MOD_TOPLEVEL) #define MOD_STORAGE (MOD_AUTO | MOD_REGISTER | MOD_STATIC | MOD_EXTERN | MOD