numam-spdk/include/spdk/conf.h
Josh Soref 0c1fcc7705 spelling: include
Part of #2256

* accelerator
* access
* acknowledge
* address
* adrfam
* aggregation
* allocated
* appearance
* associated
* asynchronously
* authority
* available
* callback
* compare
* construct
* controller
* course
* definitions
* deinitialize
* descriptor
* destroy
* device
* efficiently
* elasticity
* failure
* frequency
* function
* hdgst
* implementation
* indefinitely
* initialization
* initialize
* initiator
* interrupt
* malicious
* management
* milliseconds
* namespace
* negative
* notification
* obtained
* otherwise
* passed
* positive
* request
* responded
* semantics
* sequence
* should
* specified
* structure
* subsystem
* successful
* synchronously
* transport

Change-Id: I808876a3b4b2dc56f95cfc42bc88336cfeec4288
Signed-off-by: Josh Soref <jsoref@gmail.com>
Reviewed-on: https://review.spdk.io/gerrit/c/spdk/spdk/+/10404
Community-CI: Mellanox Build Bot
Community-CI: Broadcom CI <spdk-ci.pdl@broadcom.com>
Tested-by: SPDK CI Jenkins <sys_sgci@intel.com>
Reviewed-by: Ben Walker <benjamin.walker@intel.com>
Reviewed-by: Jim Harris <james.r.harris@intel.com>
Reviewed-by: Shuhei Matsumoto <shuhei.matsumoto.xt@hitachi.com>
2021-12-01 09:15:13 +00:00

216 lines
6.6 KiB
C

/*-
* BSD LICENSE
*
* Copyright (C) 2008-2012 Daisuke Aoyama <aoyama@peach.ne.jp>.
* Copyright (c) Intel Corporation.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
* * Neither the name of Intel Corporation nor the names of its
* contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
/** \file
* Configuration file parser
*/
#ifndef SPDK_CONF_H
#define SPDK_CONF_H
#include "spdk/stdinc.h"
#ifdef __cplusplus
extern "C" {
#endif
struct spdk_conf_value;
struct spdk_conf_item;
struct spdk_conf_section;
struct spdk_conf;
/**
* Allocate a configuration struct used for the initialization of SPDK app.
*
* \return a pointer to the allocated configuration struct.
*/
struct spdk_conf *spdk_conf_allocate(void);
/**
* Free the configuration struct.
*
* \param cp Configuration struct to free.
*/
void spdk_conf_free(struct spdk_conf *cp);
/**
* Read configuration file for spdk_conf struct.
*
* \param cp Configuration struct used for the initialization of SPDK app.
* \param file File to read that is created by user to configure SPDK app.
*
* \return 0 on success, -1 on failure.
*/
int spdk_conf_read(struct spdk_conf *cp, const char *file);
/**
* Find the specified section of the configuration.
*
* \param cp Configuration struct used for the initialization of SPDK app.
* \param name Name of section to find.
*
* \return a pointer to the requested section on success or NULL otherwise.
*/
struct spdk_conf_section *spdk_conf_find_section(struct spdk_conf *cp, const char *name);
/**
* Get the first section of the configuration.
*
* \param cp Configuration struct used for the initialization of SPDK app.
*
* \return a pointer to the requested section on success or NULL otherwise.
*/
struct spdk_conf_section *spdk_conf_first_section(struct spdk_conf *cp);
/**
* Get the next section of the configuration.
*
* \param sp The current section of the configuration.
*
* \return a pointer to the requested section on success or NULL otherwise.
*/
struct spdk_conf_section *spdk_conf_next_section(struct spdk_conf_section *sp);
/**
* Match prefix of the name of section.
*
* \param sp The section of the configuration.
* \param name_prefix Prefix name to match.
*
* \return ture on success, false on failure.
*/
bool spdk_conf_section_match_prefix(const struct spdk_conf_section *sp, const char *name_prefix);
/**
* Get the name of the section.
*
* \param sp The section of the configuration.
*
* \return the name of the section.
*/
const char *spdk_conf_section_get_name(const struct spdk_conf_section *sp);
/**
* Get the number of the section.
*
* \param sp The section of the configuration.
*
* \return the number of the section.
*/
int spdk_conf_section_get_num(const struct spdk_conf_section *sp);
/**
* Get the value of the item with name 'key' in the section.
*
* If key appears multiple times, idx1 will control which version to retrieve.
* Indices will start from the top of the configuration file at 0 and increment
* by one for each new appearance. If the configuration key contains multiple
* whitespace delimited values, idx2 controls which value is returned. The index
* begins at 0.
*
*
* \param sp The section of the configuration.
* \param key Name of item.
* \param idx1 The index into the item list for the key.
* \param idx2 The index into the value list for the item.
*
* \return the requested value on success or NULL otherwise.
*/
char *spdk_conf_section_get_nmval(struct spdk_conf_section *sp, const char *key,
int idx1, int idx2);
/**
* Get the first value of the item with name 'key' in the section.
*
* \param sp The section of the configuration.
* \param key Name of item.
* \param idx The index into the value list for the item.
*
* \return the requested value on success or NULL otherwise.
*/
char *spdk_conf_section_get_nval(struct spdk_conf_section *sp, const char *key, int idx);
/**
* Get the first value of the first item with name 'key' in the section.
*
* \param sp The section of the configuration.
* \param key Name of item.
*
* \return the requested value on success or NULL otherwise.
*/
char *spdk_conf_section_get_val(struct spdk_conf_section *sp, const char *key);
/**
* Get the first value of the first item with name 'key' in the section.
*
* \param sp The section of the configuration.
* \param key Name of item.
*
* \return the requested value on success or NULL otherwise.
*/
int spdk_conf_section_get_intval(struct spdk_conf_section *sp, const char *key);
/**
* Get the bool value of the item with name 'key' in the section.
*
* This is used to check whether the service is enabled.
*
* \param sp The section of the configuration.
* \param key Name of item.
* \param default_val Default value.
*
* \return true if matching 'Yes/Y/True', false if matching 'No/N/False', default value otherwise.
*/
bool spdk_conf_section_get_boolval(struct spdk_conf_section *sp, const char *key, bool default_val);
/**
* Set the configuration as the default.
*
* \param cp Configuration to set.
*/
void spdk_conf_set_as_default(struct spdk_conf *cp);
/**
* Disable sections merging during 'spdk_conf_read()'
*
* \param cp Configuration to be read
*/
void spdk_conf_disable_sections_merge(struct spdk_conf *cp);
#ifdef __cplusplus
}
#endif
#endif