On Fri, 20 Mar 2015 20:51:47 +0300 Alexey Dobriyan <adobri...@gmail.com> wrote:

> /proc/$PID/cmdline truncates output at PAGE_SIZE. It is easy to see with
> 
>       $ cat /proc/self/cmdline $(seq 1037) 2>/dev/null
> 
> However, command line size was never limited to PAGE_SIZE but to 128 KB and
> relatively recently limitation was removed altogether.
> 
> seq file interface is not OK, because it kmalloc's for whole output and
> open + read(, 1) + sleep will pin arbitrary amounts of kernel memory.
> To not do that, limit must be imposed which is incompatible with
> arbitrary sized command lines.
> 
> I apologize for hairy code, but this it direct consequence of command line
> layout in memory and hacks to support things like "init [3]".
> 
> The loops are "unrolled" otherwise it is either macros which hide
> control flow or functions with 7-8 arguments with equal line count.
> 
> There should be real setproctitle(2) or something.
>
> ...
>
> fs/proc/base.c |  203 
> ++++++++++++++++++++++++++++++++++++++++++++++++++++++---
> 1 file changed, 194 insertions(+), 9 deletions(-)
>

I'm desperately trying to think of a reason to not merge this patch :(

I haven't seen anyone complain about the PAGE_SIZE limit - can't we
pretend we didn't notice?  Or tell 'em to switch to powerpc so they
get 64k!
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to