Blame source/vdo/kernel/deviceConfig.h

Packit Service 75d76b
/*
Packit Service 75d76b
 * Copyright (c) 2020 Red Hat, Inc.
Packit Service 75d76b
 *
Packit Service 75d76b
 * This program is free software; you can redistribute it and/or
Packit Service 75d76b
 * modify it under the terms of the GNU General Public License
Packit Service 75d76b
 * as published by the Free Software Foundation; either version 2
Packit Service 75d76b
 * of the License, or (at your option) any later version.
Packit Service 75d76b
 * 
Packit Service 75d76b
 * This program is distributed in the hope that it will be useful,
Packit Service 75d76b
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 75d76b
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit Service 75d76b
 * GNU General Public License for more details.
Packit Service 75d76b
 * 
Packit Service 75d76b
 * You should have received a copy of the GNU General Public License
Packit Service 75d76b
 * along with this program; if not, write to the Free Software
Packit Service 75d76b
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
Packit Service 75d76b
 * 02110-1301, USA. 
Packit Service 75d76b
 *
Packit Service 75d76b
 * $Id: //eng/vdo-releases/aluminum/src/c++/vdo/kernel/deviceConfig.h#11 $
Packit Service 75d76b
 */
Packit Service 75d76b
#ifndef DEVICE_CONFIG_H
Packit Service 75d76b
#define DEVICE_CONFIG_H
Packit Service 75d76b
Packit Service 75d76b
#include <linux/device-mapper.h>
Packit Service 75d76b
Packit Service 75d76b
#include "ringNode.h"
Packit Service 75d76b
Packit Service 75d76b
#include "kernelTypes.h"
Packit Service 75d76b
Packit Service 75d76b
// This structure is memcmp'd for equality. Keep it
Packit Service 75d76b
// packed and don't add any fields that are not
Packit Service 75d76b
// properly set in both extant and parsed configs.
Packit Service 75d76b
typedef struct {
Packit Service 75d76b
  int bioAckThreads;
Packit Service 75d76b
  int bioThreads;
Packit Service 75d76b
  int bioRotationInterval;
Packit Service 75d76b
  int cpuThreads;
Packit Service 75d76b
  int logicalZones;
Packit Service 75d76b
  int physicalZones;
Packit Service 75d76b
  int hashZones;
Packit Service 75d76b
} __attribute__((packed)) ThreadCountConfig;
Packit Service 75d76b
Packit Service 75d76b
typedef uint32_t TableVersion;
Packit Service 75d76b
Packit Service 75d76b
typedef struct {
Packit Service 75d76b
  struct dm_target  *owningTarget;
Packit Service 75d76b
  struct dm_dev     *ownedDevice;
Packit Service 75d76b
  KernelLayer       *layer;
Packit Service 75d76b
  /** All configs referencing a layer are kept on a ring in the layer */
Packit Service 75d76b
  RingNode           configNode;
Packit Service 75d76b
  char              *originalString;
Packit Service 75d76b
  TableVersion       version;
Packit Service 75d76b
  char              *parentDeviceName;
Packit Service 75d76b
  BlockCount         physicalBlocks;
Packit Service 75d76b
  unsigned int       logicalBlockSize;
Packit Service 75d76b
  WritePolicy        writePolicy;
Packit Service 75d76b
  unsigned int       cacheSize;
Packit Service 75d76b
  unsigned int       blockMapMaximumAge;
Packit Service 75d76b
  bool               mdRaid5ModeEnabled;
Packit Service 75d76b
  bool               deduplication;
Packit Service 75d76b
  char              *poolName;
Packit Service 75d76b
  ThreadCountConfig  threadCounts;
Packit Service 75d76b
  BlockCount         maxDiscardBlocks;
Packit Service 75d76b
} DeviceConfig;
Packit Service 75d76b
Packit Service 75d76b
/**
Packit Service 75d76b
 * Convert a RingNode to the DeviceConfig that contains it.
Packit Service 75d76b
 *
Packit Service 75d76b
 * @param node  The RingNode to convert
Packit Service 75d76b
 *
Packit Service 75d76b
 * @return The DeviceConfig wrapping the RingNode
Packit Service 75d76b
 **/
Packit Service 75d76b
static inline DeviceConfig *asDeviceConfig(RingNode *node)
Packit Service 75d76b
{
Packit Service 75d76b
  if (node == NULL) {
Packit Service 75d76b
    return NULL;
Packit Service 75d76b
  }
Packit Service 75d76b
  return (DeviceConfig *) ((byte *) node - offsetof(DeviceConfig, configNode));
Packit Service 75d76b
}
Packit Service 75d76b
Packit Service 75d76b
/**
Packit Service 75d76b
 * Grab a pointer to the pool name out of argv.
Packit Service 75d76b
 *
Packit Service 75d76b
 * @param [in]  argc         The number of table values
Packit Service 75d76b
 * @param [in]  argv         The array of table values
Packit Service 75d76b
 * @param [out] errorPtr     A pointer to return a error string in
Packit Service 75d76b
 * @param [out] poolNamePtr  A pointer to return the pool name
Packit Service 75d76b
 *
Packit Service 75d76b
 * @return VDO_SUCCESS or an error code
Packit Service 75d76b
 **/
Packit Service 75d76b
int getPoolNameFromArgv(int    argc,
Packit Service 75d76b
                        char **argv,
Packit Service 75d76b
                        char **errorPtr,
Packit Service 75d76b
                        char **poolNamePtr)
Packit Service 75d76b
  __attribute__((warn_unused_result));
Packit Service 75d76b
Packit Service 75d76b
/**
Packit Service 75d76b
 * Convert the dmsetup table into a DeviceConfig.
Packit Service 75d76b
 *
Packit Service 75d76b
 * @param [in]  argc        The number of table values
Packit Service 75d76b
 * @param [in]  argv        The array of table values
Packit Service 75d76b
 * @param [in]  ti          The target structure for this table
Packit Service 75d76b
 * @param [in]  verbose     Whether to log about the underlying device
Packit Service 75d76b
 * @param [out] configPtr   A pointer to return the allocated config
Packit Service 75d76b
 *
Packit Service 75d76b
 * @return VDO_SUCCESS or an error code
Packit Service 75d76b
 **/
Packit Service 75d76b
int parseDeviceConfig(int                argc,
Packit Service 75d76b
                      char             **argv,
Packit Service 75d76b
                      struct dm_target  *ti,
Packit Service 75d76b
                      bool               verbose,
Packit Service 75d76b
                      DeviceConfig     **configPtr)
Packit Service 75d76b
  __attribute__((warn_unused_result));
Packit Service 75d76b
Packit Service 75d76b
/**
Packit Service 75d76b
 * Free a device config created by parseDeviceConfig().
Packit Service 75d76b
 *
Packit Service 75d76b
 * @param configPtr  The pointer holding the config, which will be nulled
Packit Service 75d76b
 **/
Packit Service 75d76b
void freeDeviceConfig(DeviceConfig **configPtr);
Packit Service 75d76b
Packit Service 75d76b
/**
Packit Service 75d76b
 * Get the text describing the write policy.
Packit Service 75d76b
 *
Packit Service 75d76b
 * @param config  The device config
Packit Service 75d76b
 *
Packit Service 75d76b
 * @returns a pointer to a string describing the write policy
Packit Service 75d76b
 **/
Packit Service 75d76b
const char *getConfigWritePolicyString(DeviceConfig *config)
Packit Service 75d76b
  __attribute__((warn_unused_result));
Packit Service 75d76b
Packit Service 75d76b
/**
Packit Service 75d76b
 * Acquire or release a reference from the config to a kernel layer.
Packit Service 75d76b
 *
Packit Service 75d76b
 * @param config  The config in question
Packit Service 75d76b
 * @param layer   The kernel layer in question
Packit Service 75d76b
 **/
Packit Service 75d76b
void setDeviceConfigLayer(DeviceConfig *config, KernelLayer *layer);
Packit Service 75d76b
Packit Service 75d76b
#endif // DEVICE_CONFIG_H