Re: [PATCH] builtin/receive-pack: dead initializer for retval in check_nonce

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Sat, Oct 20, 2018 at 9:45 AM Torsten Bögershausen <tboegi@xxxxxx> wrote:
>
> The motivation feels a little bit weak, at least to me.

I have to admit, I was sitting on this patch for a while for the same reason
but I should had made a more compelling commit message either way and
will definitely fix that with v2.

the point was that setting the variable to BAD originally seemed to be legacy
from the original version of the code, specially considering that the newer
version was setting it to SLOB at the last "else".

the code was written in a way that would make all those assignments to BAD
explicit (even if it wasn't needed, since it was initialized to that
value) and so
it would seem better IMHO to use the compiler to remind us that this variable
MUST be set to the right value than setting the most likely value by default.

> Initializing a variable to "BAD" in the beginning can be a good thing
> for two reasons:
> - There is a complex if-elseif chain, which should set retval
>   in any case, this is at least what I expect taking a very quick look at the
>   code:
>         const char *retval = NONCE_BAD;
>
>         if (!nonce) {
>                 retval = NONCE_MISSING;
>                 goto leave;
>         } else if (!push_cert_nonce) {
>                 retval = NONCE_UNSOLICITED;
>                 goto leave;
>         } else if (!strcmp(push_cert_nonce, nonce)) {
>                 retval = NONCE_OK;
>                 goto leave;
>         }
>         # And here I started to wonder if we should have an else or not.
>         # Having retval NONCE_BAD set to NONCE:BAD in the beginning makes
>         # it clear, that we are save without the else.
>         # As an alternative, we could have coded like this:
>
>         const char *retval;
>
>         if (!nonce) {
>                 retval = NONCE_MISSING;
>                 goto leave;
>         } else if (!push_cert_nonce) {
>                 retval = NONCE_UNSOLICITED;
>                 goto leave;
>         } else if (!strcmp(push_cert_nonce, nonce)) {
>                 retval = NONCE_OK;
>                 goto leave;
>         } else {
>                 /* Set to BAD, until we know better further down */
>                 retval = NONCE_BAD;
>         }
>
> # The second reason is that some compilers don't understand this complex
> # stuff either, and through out a warning, like
> # "retval may be uninitialized" or something in that style.
> # This is very compiler dependent.

FWIW I did test with gcc (from 4.9 to 8) and clang 7 (linux) and 10
(macos) and didn't
trigger any warning.

> So yes, the current code may seem to be over-eager and ask for optimization,
> but we don't gain more that a couple of nano-seconds or so.
> The good thing is that  we have the code a little bit more robust, when changes are done
> in the future.

on the other hand was able to trigger a warning if the code was changed so some
path will leave retval uninitialized (after adding
-Wmaybe-uninitialized to gcc and -Wsometimes-uninitialized to clang)
since there was no longer a default of BAD (probably incorrectly) that
would be returned in case setting retval to the
right value was forgotten.

Carlo




[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux