Blame source/vdo/base/slabDepotInternals.h

Packit Service 7e342f
/*
Packit Service 7e342f
 * Copyright (c) 2020 Red Hat, Inc.
Packit Service 7e342f
 *
Packit Service 7e342f
 * This program is free software; you can redistribute it and/or
Packit Service 7e342f
 * modify it under the terms of the GNU General Public License
Packit Service 7e342f
 * as published by the Free Software Foundation; either version 2
Packit Service 7e342f
 * of the License, or (at your option) any later version.
Packit Service 7e342f
 * 
Packit Service 7e342f
 * This program is distributed in the hope that it will be useful,
Packit Service 7e342f
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 7e342f
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit Service 7e342f
 * GNU General Public License for more details.
Packit Service 7e342f
 * 
Packit Service 7e342f
 * You should have received a copy of the GNU General Public License
Packit Service 7e342f
 * along with this program; if not, write to the Free Software
Packit Service 7e342f
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
Packit Service 7e342f
 * 02110-1301, USA. 
Packit Service 7e342f
 *
Packit Service 7e342f
 * $Id: //eng/vdo-releases/aluminum/src/c++/vdo/base/slabDepotInternals.h#13 $
Packit Service 7e342f
 */
Packit Service 7e342f
Packit Service 7e342f
#ifndef SLAB_DEPOT_INTERNALS_H
Packit Service 7e342f
#define SLAB_DEPOT_INTERNALS_H
Packit Service 7e342f
Packit Service 7e342f
#include "slabDepot.h"
Packit Service 7e342f
Packit Service 7e342f
#include "atomic.h"
Packit Service 7e342f
Packit Service 7e342f
#include "actionManager.h"
Packit Service 7e342f
Packit Service 7e342f
struct slabDepot {
Packit Service 7e342f
  ZoneCount             zoneCount;
Packit Service 7e342f
  ZoneCount             oldZoneCount;
Packit Service 7e342f
  SlabConfig            slabConfig;
Packit Service 7e342f
  SlabSummary          *slabSummary;
Packit Service 7e342f
  ReadOnlyNotifier     *readOnlyNotifier;
Packit Service 7e342f
  ActionManager        *actionManager;
Packit Service 7e342f
Packit Service 7e342f
  PhysicalBlockNumber   firstBlock;
Packit Service 7e342f
  PhysicalBlockNumber   lastBlock;
Packit Service 7e342f
  PhysicalBlockNumber   origin;
Packit Service 7e342f
Packit Service 7e342f
  /** slabSize == (1 << slabSizeShift) */
Packit Service 7e342f
  unsigned int          slabSizeShift;
Packit Service 7e342f
Packit Service 7e342f
  /** Determines how slabs should be queued during load */
Packit Service 7e342f
  SlabDepotLoadType     loadType;
Packit Service 7e342f
Packit Service 7e342f
  /** The state for notifying slab journals to release recovery journal */
Packit Service 7e342f
  SequenceNumber        activeReleaseRequest;
Packit Service 7e342f
  SequenceNumber        newReleaseRequest;
Packit Service 7e342f
Packit Service 7e342f
  /** The completion for scrubbing */
Packit Service 7e342f
  VDOCompletion         scrubbingCompletion;
Packit Service 7e342f
  Atomic32              zonesToScrub;
Packit Service 7e342f
Packit Service 7e342f
  /** Cached journal pointer for slab creation */
Packit Service 7e342f
  RecoveryJournal      *journal;
Packit Service 7e342f
Packit Service 7e342f
  /** Array of pointers to individually allocated slabs */
Packit Service 7e342f
  Slab                **slabs;
Packit Service 7e342f
  /** The number of slabs currently allocated and stored in 'slabs' */
Packit Service 7e342f
  SlabCount             slabCount;
Packit Service 7e342f
Packit Service 7e342f
  /** Array of pointers to a larger set of slabs (used during resize) */
Packit Service 7e342f
  Slab                **newSlabs;
Packit Service 7e342f
  /** The number of slabs currently allocated and stored in 'newSlabs' */
Packit Service 7e342f
  SlabCount             newSlabCount;
Packit Service 7e342f
  /** The size that 'newSlabs' was allocated for */
Packit Service 7e342f
  BlockCount            newSize;
Packit Service 7e342f
Packit Service 7e342f
  /** The last block before resize, for rollback */
Packit Service 7e342f
  PhysicalBlockNumber   oldLastBlock;
Packit Service 7e342f
  /** The last block after resize, for resize */
Packit Service 7e342f
  PhysicalBlockNumber   newLastBlock;
Packit Service 7e342f
Packit Service 7e342f
  /** The block allocators for this depot */
Packit Service 7e342f
  BlockAllocator       *allocators[];
Packit Service 7e342f
};
Packit Service 7e342f
Packit Service 7e342f
/**
Packit Service 7e342f
 * Destroy a slab.
Packit Service 7e342f
 *
Packit Service 7e342f
 * @param slab  The slab to destroy
Packit Service 7e342f
 **/
Packit Service 7e342f
void destroySlab(Slab *slab);
Packit Service 7e342f
Packit Service 7e342f
/**
Packit Service 7e342f
 * Inform a slab's depot that the slab has been created.
Packit Service 7e342f
 *
Packit Service 7e342f
 * @param slab  The slab to register
Packit Service 7e342f
 **/
Packit Service 7e342f
void registerSlabWithDepot(Slab *slab);
Packit Service 7e342f
Packit Service 7e342f
/**
Packit Service 7e342f
 * Notify a slab depot that one of its allocators has finished scrubbing slabs.
Packit Service 7e342f
 * This method should only be called if the scrubbing was successful. This
Packit Service 7e342f
 * callback is registered by each block allocator in
Packit Service 7e342f
 * scrubAllUnrecoveredSlabsInZone().
Packit Service 7e342f
 *
Packit Service 7e342f
 * @param completion  A completion whose parent must be a slab depot
Packit Service 7e342f
 **/
Packit Service 7e342f
void notifyZoneFinishedScrubbing(VDOCompletion *completion);
Packit Service 7e342f
Packit Service 7e342f
/**
Packit Service 7e342f
 * Check whether two depots are equivalent (i.e. represent the same
Packit Service 7e342f
 * state and have the same reference counter). This method is used for unit
Packit Service 7e342f
 * testing.
Packit Service 7e342f
 *
Packit Service 7e342f
 * @param depotA The first depot to compare
Packit Service 7e342f
 * @param depotB The second depot to compare
Packit Service 7e342f
 *
Packit Service 7e342f
 * @return true if the two depots are equivalent
Packit Service 7e342f
 **/
Packit Service 7e342f
bool areEquivalentDepots(SlabDepot *depotA, SlabDepot *depotB)
Packit Service 7e342f
  __attribute__((warn_unused_result));
Packit Service 7e342f
Packit Service 7e342f
/**
Packit Service 7e342f
 * Start allocating from the highest numbered slab in each zone.
Packit Service 7e342f
 *
Packit Service 7e342f
 * @param depot   The depot
Packit Service 7e342f
 **/
Packit Service 7e342f
void allocateFromLastSlab(SlabDepot *depot);
Packit Service 7e342f
Packit Service 7e342f
#endif /* SLAB_DEPOT_INTERNALS_H */