Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 2 Jul 2004 19:48:05 +0000
From:      Bosko Milekic <bmilekic@FreeBSD.org>
To:        Brian Fundakowski Feldman <green@FreeBSD.org>
Cc:        current@FreeBSD.org
Subject:   Re: UMA zinit/zctor function error returning
Message-ID:  <20040702194805.GA18025@freefall.freebsd.org>

next in thread | raw e-mail | index | archive | help

Brian Fundakowski Feldman wrote:
>These are the only two places that can call uz_ctor, aren't they?
>
>uma_core.c:
>                        if (zone->uz_ctor) {
>                                if (zone->uz_ctor(item, zone->uz_keg->uk_size,
>                                    udata, flags) != 0) {
>                                        uma_zfree_internal(zone, item, udata,
>                                            SKIP_DTOR);
>                                        return (NULL);
>                                }
>                        }
>                        ...
>        if (zone->uz_ctor != NULL) {
>                if (zone->uz_ctor(item, keg->uk_size, udata, flags) != 0) {
>                        uma_zfree_internal(zone, item, udata, SKIP_DTOR);
>                        return (NULL);
>                }
>        }

  Yes, I guess you're right in this case.  We have to be careful, though,
  because in some cases the ctor might bring the object to a half-ctor'd
  state, in which case the failure path needs to know how to rewind the
  state prior to returning the error, as UMA will skip the dtor on that
  free.

>Well, I only did that because there were no places that called for
>a keg init being used in the first place (no calls to the
>uma_zone_set_init() function).

[VM]->keg_init->[keg(slabs)]->zone_init->[zone(buckets)]->zone_ctor->...

  By default, when you create a zone, the init you provide is hooked
  in as the _keg_init_, not the zone_init.  The zone_init is set
  with uma_zone_set_zinit(), and the keg init by uma_zone_set_init().
  As I said, when you create the zone, the init you provide is hooked
  in as the keg_init.  If you create a secondary zone, THEN you get to
  use the zone_init if you need to/want to.  So the keg_init has the
  same behavior as the OLD pre-extended-UMA zoneinit.

  Therefore, it is important for the keg_init to know how to fail,
  even if it only seems like it's for completeness right now, it
  is the most used init out there.  Once you allow the keginit to
  fail too (and receive the how argument), then you don't need to
  split up the keginit/zoneinit types and they can stay the same.

>> - the uma_dbg.c changes call the ctor explicitly from the fini.
>>   I forget the exact reason this is, but now that we're expecting
>>   the ctor to return something, if you are ignoring the return
>>   value, please cast void explicitly here (STYLE).  Alternately,
>>   make both keg and zone inits able to fail and propagate the failure,
>>   if any, upwards.
>
>I'm not sure what you mean here.  There are no return values I see ignored,
>but a couple functions with similar names (trash_ctor()/mtrash_ctor()).

  I'm talking about mtrash_fini() explicitly calling mtrash_ctor().
  There it should cast the call (void) since it doesn't check its
  return value or, when the fini is shown how to fail, return whatever
  mtrash_ctor() returns.

-Bosko



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20040702194805.GA18025>