D4997: Support for long running kcheckpass supporting multiple authentications

Tobias C. Berner tcberner at freebsd.org
Fri May 12 18:36:22 UTC 2017


Hi

We could probably do something with kqueue/EVFILT_SIGNAL:
    https://www.freebsd.org/cgi/man.cgi?query=kqueue&sektion=2

     EVFILT_SIGNAL Takes the signal number to monitor as the identifier
                                  and returns when the given signal is
delivered to the
                                 process.  This coexists with the signal() and
                                 sigaction() facilities, and has a
lower precedence.
                                 The filter will record all attempts
to deliver a sig-
                                 nal to a process, even if the signal
has been marked
                                 as SIG_IGN, except for the SIGCHLD
signal, which, if
                                 ignored, won't be recorded by the
filter.  Event
                                 notification happens after normal
signal delivery
                                 processing.  data returns the number
of times the
                                 signal has occurred since the last
call to kevent().
                                 This filter automatically sets the
EV_CLEAR flag
                                 internally.


-- kqueue should be supported on all other *BSD and OSX too.



mfg Tobias

On 12 May 2017 at 15:55, Martin Flöser <mgraesslin at kde.org> wrote:
> Am 2017-05-12 09:18, schrieb Tobias C. Berner:
>>
>> Hi there
>>
>> I think this review introduced some Linux-only features: signalfd() is
>> only present on Linux.
>> So this breaks kcheckpass on FreeBSD (and probably everything non-Linux
>> too).
>>
>> Would it be possible to have the long-running auth stuff hidden behind a
>>   check_include_file("sys/signalfd.h" HAVE_SIGNALFD_H)
>> check?
>
>
> Just confirming what David already wrote. The code is built around signalfd
> and without it kcheckpass is broken. Also in the non-long running kcheckpass
> case signalfd is used.
>
> At the moment I do not see a solution. Sorry for creating the problem, I did
> not expect that this is linux specific.
>
> As we are in feature freeze and this is security relevant code I don't
> really have an idea to move forward. Especially as it's pointless to have
> any linux dev work on this as we might just break it again. We are in low
> level c code in kcheckpass which is totally ugly and all designed for the
> case of running as setuid root.
>
> Cheers
> Martin
>
>
>>
>>
>> mfg Tobias
>>
>> On 19 April 2017 at 17:44, Martin Gräßlin <noreply at phabricator.kde.org>
>> wrote:
>>>
>>> This revision was automatically updated to reflect the committed changes.
>>> Closed by commit R133:07d38ba65adc: Support for long running kcheckpass
>>> supporting multiple authentications (authored by graesslin). View
>>> Revision
>>>
>>> REPOSITORY
>>> R133 KScreenLocker
>>>
>>> CHANGES SINCE LAST UPDATE
>>> https://phabricator.kde.org/D4997?vs=13188&id=13603
>>>
>>> REVISION DETAIL
>>> https://phabricator.kde.org/D4997
>>>
>>> AFFECTED FILES
>>> greeter/authenticator.cpp
>>> greeter/authenticator.h
>>> greeter/autotests/authenticatortest.cpp
>>> greeter/greeterapp.cpp
>>> kcheckpass/kcheckpass-enums.h
>>> kcheckpass/kcheckpass.c
>>> tests/kcheckpass_test.cpp
>>>
>>> To: graesslin, Plasma
>>> Cc: subdiff, plasma-devel, spstarr, progwolff, lesliezhai, ali-mohamed,
>>> jensreuterberg, abetts, sebas, apol


More information about the Plasma-devel mailing list