[PATCH v11 1/7] ARM: probes: move all probe code to dedicate directory

Wang Nan wangnan0 at huawei.com
Tue Dec 2 21:28:41 PST 2014


On 2014/12/3 12:38, Masami Hiramatsu wrote:
> (2014/12/02 19:23), Wang Nan wrote:
>> On 2014/12/2 12:59, Masami Hiramatsu wrote:
>>> (2014/12/01 17:48), Wang Nan wrote:
>>>> In discussion on LKML (https://lkml.org/lkml/2014/11/28/158), Russell
>>>> King suggest to move all probe related code to arch/arm/probes. This
>>>> patch do the work. Due to dependency on 'arch/arm/kernel/patch.h', this
>>>> patch also move patch.h to 'arch/arm/include/asm/patch.h', and related
>>>> '#include' directive are also midified to '#include <asm/patch.h>'.
>>>
>>> Moving is good to me, but renaming files are also required I think.
>>>
>>>> Signed-off-by: Wang Nan <wangnan0 at huawei.com>
>>>> ---
>>>>  arch/arm/Makefile                                |  1 +
>>>>  arch/arm/{kernel => include/asm}/patch.h         |  0
>>>>  arch/arm/kernel/Makefile                         | 16 ++--------------
>>>>  arch/arm/kernel/jump_label.c                     |  2 +-
>>>>  arch/arm/kernel/patch.c                          |  3 +--
>>>>  arch/arm/probes/Makefile                         | 15 +++++++++++++++
>>>>  arch/arm/{kernel => probes}/kprobes-arm.c        |  0
>>>>  arch/arm/{kernel => probes}/kprobes-common.c     |  0
>>>>  arch/arm/{kernel => probes}/kprobes-test-arm.c   |  0
>>>>  arch/arm/{kernel => probes}/kprobes-test-thumb.c |  0
>>>>  arch/arm/{kernel => probes}/kprobes-test.c       |  0
>>>>  arch/arm/{kernel => probes}/kprobes-test.h       |  0
>>>>  arch/arm/{kernel => probes}/kprobes-thumb.c      |  0
>>>>  arch/arm/{kernel => probes}/kprobes.c            |  2 +-
>>>>  arch/arm/{kernel => probes}/kprobes.h            |  0
>>>>  arch/arm/{kernel => probes}/probes-arm.c         |  0
>>>>  arch/arm/{kernel => probes}/probes-arm.h         |  0
>>>>  arch/arm/{kernel => probes}/probes-thumb.c       |  0
>>>>  arch/arm/{kernel => probes}/probes-thumb.h       |  0
>>>>  arch/arm/{kernel => probes}/probes.c             |  0
>>>>  arch/arm/{kernel => probes}/probes.h             |  0
>>>>  arch/arm/{kernel => probes}/uprobes-arm.c        |  0
>>>>  arch/arm/{kernel => probes}/uprobes.c            |  0
>>>>  arch/arm/{kernel => probes}/uprobes.h            |  0
>>>
>>> As I did on x86, these would be better renamed as expressing what they do.
>>> I guess most of the files may have emulate-*.c or decode-*.c :)
>>>
>>> Thank you,
>>>
>>
>> OK. I posted another patch in this thread. The directory tree is as follow:
>>
>> arch/arm/probes/
>> |-- Makefile
>> |-- decode-arm.c
>> |-- decode-arm.h
>> |-- decode-thumb.c
>> |-- decode-thumb.h
>> |-- decode.c
>> |-- decode.h
>> |-- kprobes
>> |   |-- actions-arm.c
>> |   |-- actions-common.c
>> |   |-- actions-thumb.c
>> |   |-- kprobes.c
>> |   |-- kprobes.h
>> |   |-- test-arm.c
>> |   |-- test-core.c
>> |   |-- test-core.h
>> |   `-- test-thumb.c
>> `-- uprobes
>>     |-- actions-arm.c
>>     |-- uprobes.c
>>     `-- uprobes.h
>>
>> 2 directories, 19 files
>>
>> What do you think?
> 
> Yeah, that looks better :)
> 
> Btw, if you introduce probes/{kprobes,uprobes}/, *probes.c should be core.c too,
> since the directories already show its name. And also, both dirs should have its
> own Makefile.
> 

Seprated Makefile may introduce extra complexity. Think about someone try to compile
kprobe as a module (currently it is impossible due to dependencies between kprobe and
kernel core, but decoupling is possible), seprated Makefiles may force him to
create at least 3 modules for kprobe, even if one module is enough.

Anyway, there may some features in kernel build system can help him. I'll post
v12 patch series based on your suggestion.

Thank you.

> Thank you,
> 
> 





More information about the linux-arm-kernel mailing list