On Mon, Jul 16, 2018 at 12:23 PM, Firoz Khan firoz.khan@linaro.org wrote:
The goal of this patch series is to easily add/modify/delete a system call by changing entry in syscall.tbl file. No need to manually edit many files.
The another goal of this patch series is to to unify the system call implementation across all the architectures. ARM, s390 and x86 architecuture does have the similar support. I leverage their implementation to come up with a generic solution.
I have done the same support for work for ia64, m68k, microblaze, mips, parisc, powerpc, sh, sparc, and xtensa. But I started sending the patch for one architecuture for review. Below mentioned git repository contains more details. Git repo:- https://github.com/frzkhn/system_call_table_generator/
Finally, this is the ground work for solving the Y2038 issue. We need to change two dozen of system calls to solve Y2038 issue. So this implementation will help to easily modify from existing system call to Y2038 compatible system calls.
Thanks a lot Firoz for getting this started!
(adding Marcin to Cc)
I think doing this for all architectures will help in a number of ways. As we need to do a relatively complex conversion for the system calls for y2038 support (changing old calls into compat ones, and adding the new ones at the end), this will give us some confidence.
I also hope that this makes scripting easier when we can check which calls are implemented on which architecture, and maybe get to a common baseline again by adding the missing calls on all architectures that are rarely updated, now that we have thrown out the architectures that were simply unmaintained. (looking at the syscall table used to be a good way to see how well maintained an architecture is). Once the y2038 calls are added, glibc and others will have to set a new minimum version of kernel headers (e.g. changing from linux-3.2 to 4.20) to get the new calls, and that at that time, it would be great to have all the recently added calls available on all architectures, so a future glibc version that takes linux-4.20 as the minimum runtime version doesn't have to emulate those calls through older ones. In particular, this would be helpful for the new mount() API and the rseq() call that have recently been added.
We might run into a few problems on architectures while we transition to generated tables at the same as as adding new calls, we'll have to see how to deal with that.
Arnd