xref: /freebsd/sys/dev/isci/scil/scif_library.h (revision e796cc77c586c2955b2f3940dbf4991b31e8d289)
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 
199