The Design and Implementation of the FreeBSD Operating System, Second Edition
Now available: The Design and Implementation of the FreeBSD Operating System (Second Edition)


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]

FreeBSD/Linux Kernel Cross Reference
sys/dev/isci/scil/scif_library.h

Version: -  FREEBSD  -  FREEBSD-13-STABLE  -  FREEBSD-13-0  -  FREEBSD-12-STABLE  -  FREEBSD-12-0  -  FREEBSD-11-STABLE  -  FREEBSD-11-0  -  FREEBSD-10-STABLE  -  FREEBSD-10-0  -  FREEBSD-9-STABLE  -  FREEBSD-9-0  -  FREEBSD-8-STABLE  -  FREEBSD-8-0  -  FREEBSD-7-STABLE  -  FREEBSD-7-0  -  FREEBSD-6-STABLE  -  FREEBSD-6-0  -  FREEBSD-5-STABLE  -  FREEBSD-5-0  -  FREEBSD-4-STABLE  -  FREEBSD-3-STABLE  -  FREEBSD22  -  l41  -  OPENBSD  -  linux-2.6  -  MK84  -  PLAN9  -  xnu-8792 
SearchContext: -  none  -  3  -  10 

    1 /*-
    2  * SPDX-License-Identifier: BSD-2-Clause OR GPL-2.0
    3  *
    4  * This file is provided under a dual BSD/GPLv2 license.  When using or
    5  * redistributing this file, you may do so under either license.
    6  *
    7  * GPL LICENSE SUMMARY
    8  *
    9  * Copyright(c) 2008 - 2011 Intel Corporation. All rights reserved.
   10  *
   11  * This program is free software; you can redistribute it and/or modify
   12  * it under the terms of version 2 of the GNU General Public License as
   13  * published by the Free Software Foundation.
   14  *
   15  * This program is distributed in the hope that it will be useful, but
   16  * WITHOUT ANY WARRANTY; without even the implied warranty of
   17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   18  * General Public License for more details.
   19  *
   20  * You should have received a copy of the GNU General Public License
   21  * along with this program; if not, write to the Free Software
   22  * Foundation, Inc., 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
   23  * The full GNU General Public License is included in this distribution
   24  * in the file called LICENSE.GPL.
   25  *
   26  * BSD LICENSE
   27  *
   28  * Copyright(c) 2008 - 2011 Intel Corporation. All rights reserved.
   29  * All rights reserved.
   30  *
   31  * Redistribution and use in source and binary forms, with or without
   32  * modification, are permitted provided that the following conditions
   33  * are met:
   34  *
   35  *   * Redistributions of source code must retain the above copyright
   36  *     notice, this list of conditions and the following disclaimer.
   37  *   * Redistributions in binary form must reproduce the above copyright
   38  *     notice, this list of conditions and the following disclaimer in
   39  *     the documentation and/or other materials provided with the
   40  *     distribution.
   41  *
   42  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
   43  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
   44  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
   45  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
   46  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
   47  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
   48  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
   49  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
   50  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
   51  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
   52  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
   53  *
   54  * $FreeBSD$
   55  */
   56 #ifndef _SCIF_LIBRARY_H_
   57 #define _SCIF_LIBRARY_H_
   58 
   59 /**
   60  * @file
   61  *
   62  * @brief This file contains all of the interface methods that can be called
   63  *        by an SCI Framework user on the library object.  The library is
   64  *        the container of all other objects being managed (i.e. controllers,
   65  *        target devices, sas ports, etc.) by SCIF.
   66  */
   67 
   68 #ifdef __cplusplus
   69 extern "C" {
   70 #endif // __cplusplus
   71 
   72 #include <dev/isci/scil/sci_types.h>
   73 #include <dev/isci/scil/sci_status.h>
   74 
   75 
   76 /**
   77  * @brief This method will contsruct the SCI framework library based on the
   78  *        supplied parameter information.  By default, libraries are
   79  *        considered "ready" as soon as they are constructed.
   80  *
   81  * @param[in]  library_memory_p a pointer to the memory at which the
   82  *             library object is located.
   83  * @param[in]  max_controller_count the maximum number of controllers that
   84  *             this library can manage.
   85  *
   86  * @return An opaque library handle to be used by the SCI user for all
   87  *         subsequent library operations.
   88  */
   89 SCI_LIBRARY_HANDLE_T scif_library_construct(
   90    void * library_memory_p,
   91    U8     max_controller_count
   92 );
   93 
   94 /**
   95  * @brief This method returns the size of the framework library object.  The
   96  *        size of the framework library object includes the associated core
   97  *        object.
   98  *
   99  * @param[in]  max_controller_count the maximum number of controllers that
  100  *             this library can manage.
  101  *
  102  * @return a positive integer value indicating the size (in bytes) of the
  103  *         library object.
  104  */
  105 U32 scif_library_get_object_size(
  106    U8  max_controller_count
  107 );
  108 
  109 /**
  110  * @brief This method will allocate the next available framework controller
  111  *        object that can be managed by this framework library.
  112  *
  113  * @see For additional information please refer to:
  114  *      scic_library_allocate_controller()
  115  *
  116  * @param[in]  library the handle to the library object for which to allocate
  117  *             a controller.
  118  * @param[out] new_controller_p This parameter specifies a pointer to the
  119  *             controller handle that was added to the library.
  120  *
  121  * @return Indicate if the controller was successfully allocated or if iti
  122  *         failed in some way.
  123  * @retval SCI_SUCCESS if the controller was successfully allocated.
  124  * @retval SCI_FAILURE_INSUFFICIENT_RESOURCES if the library has no more
  125  *         available controller objects to allocate.
  126  */
  127 SCI_STATUS scif_library_allocate_controller(
  128    SCI_LIBRARY_HANDLE_T      library,
  129    SCI_CONTROLLER_HANDLE_T * new_controller_p
  130 );
  131 
  132 /**
  133  * @brief This method will attempt to free the supplied controller to the
  134  *        library.
  135  *
  136  * @param[in]  library the handle to the library object for which to free
  137  *             a controller.
  138  * @param[in]  controller the handle to the controller object to be freed
  139  *             from the library.
  140  *
  141  * @return Indicate if the controller was successfully freed or if it failed
  142  *         in some way.
  143  * @retval SCI_SUCCESS if the controller was successfully freed.
  144  * @retval SCI_FAILURE_CONTROLLER_NOT_FOUND if the supplied controller is
  145  *         not managed by the supplied library.
  146  */
  147 SCI_STATUS scif_library_free_controller(
  148    SCI_LIBRARY_HANDLE_T     library,
  149    SCI_CONTROLLER_HANDLE_T  controller
  150 );
  151 
  152 
  153 /**
  154  * @brief This method returns the SCI Core library handle
  155  *        associated with this library.
  156  *
  157  * @param[in]  scif_library the handle to the library
  158  *             object for which to retrieve the core specific
  159  *             library handle
  160  *
  161  * @return Return the SCI core library handle associated with
  162  *         the supplied framework library.
  163  */
  164 SCI_LIBRARY_HANDLE_T scif_library_get_scic_handle(
  165    SCI_LIBRARY_HANDLE_T   scif_library
  166 );
  167 
  168 
  169 /**
  170  * @brief This method returns the minimum number of timers needed.  If the
  171  *        user supplies timers less then the number specified via this
  172  *        call, then the user runs the risk of improper operation.  This
  173  *        call includes the minimum number of timers needed by the core.
  174  *
  175  * @return This method returns a value representing the minimum number of
  176  *         timers required by this framework implementation
  177  */
  178 U16 scif_library_get_min_timer_count(
  179    void
  180 );
  181 
  182 /**
  183  * @brief This method returns the maximum number of timers that could
  184  *        be ever be in use by this component at a given time.
  185  *
  186  * @return This method returns a value representing the minimum number of
  187  *         timers required by this framework implementation
  188  */
  189 U16 scif_library_get_max_timer_count(
  190    void
  191 );
  192 
  193 #ifdef __cplusplus
  194 }
  195 #endif // __cplusplus
  196 
  197 #endif // _SCIF_LIBRARY_H_
  198 

Cache object: 2acecefcf5d978d58a7960ef1ada0b28


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]


This page is part of the FreeBSD/Linux Linux Kernel Cross-Reference, and was automatically generated using a modified version of the LXR engine.