Kernel TLS

Jeffrey Walton noloader at gmail.com
Fri Nov 29 14:57:51 EST 2019


On Fri, Nov 29, 2019 at 2:48 PM Valentin Vidić
<vvidic at valentin-vidic.from.hr> wrote:
>
> On Fri, Nov 29, 2019 at 02:36:10PM -0500, Jeffrey Walton wrote:
> > I'm trying to run through the example at
> > https://www.kernel.org/doc/html/latest/networking/tls.html#kernel-tls
> > .
> >
> > I'm working on Fedora 31 x86_64 (fully patched). Running my program results in:
> >
> >     $ ./ktls
> >     setsockopt failed, 2, No such file or directory
> >
> > I observed:
> >
> >     $ cat /proc/sys/net/ipv4/tcp_available_ulp
> >     $
> >
> > Is there a way to enable ULP at boot? Or is this a kernel config
> > option? Or maybe I am doing something else wrong?
>
> strace gives me:
>
> ...
> socket(AF_INET, SOCK_STREAM, IPPROTO_IP) = 3
> setsockopt(3, SOL_TCP, TCP_ULP, [7564404], 4) = -1 ENOENT (No such file or directory)
> fstat(1, {st_mode=S_IFCHR|0620, st_rdev=makedev(0x88, 0x2), ...}) = 0
> brk(NULL)                               = 0x55d76b14e000
> brk(0x55d76b16f000)                     = 0x55d76b16f000
> write(1, "setsockopt failed, 2, No such fi"..., 48setsockopt failed, 2, No such file or directory
> ) = 48
> exit_group(1)                           = ?
> +++ exited with 1 +++
>
> $ grep TLS /boot/config-4.19.0-6-amd64
> CONFIG_HAVE_COPY_THREAD_TLS=y
> # CONFIG_TLS is not set
> # CONFIG_VIDEO_IVTV_DEPRECATED_IOCTLS is not set
>
> So you probably need to rebuild the kernel with CONFIG_TLS to get this working.

Thanks Valentin.

Here's what I am seeing:

    $ grep TLS /boot/config-5.3.12-300.fc31.x86_64
    CONFIG_HAVE_COPY_THREAD_TLS=y
    CONFIG_TLS=m
    ...

I believe the 'm' means a loadable module. But:

    $ insmod tls
    insmod: ERROR: could not load module tls: No such file or directory

Jeff



More information about the Kernelnewbies mailing list