2 * @file IxNpeMhUnsolicitedCbMgr_p.h
4 * @author Intel Corporation
7 * @brief This file contains the private API for the Unsolicited Callback
12 * IXP400 SW Release version 2.0
14 * -- Copyright Notice --
17 * Copyright 2001-2005, Intel Corporation.
18 * All rights reserved.
21 * Redistribution and use in source and binary forms, with or without
22 * modification, are permitted provided that the following conditions
24 * 1. Redistributions of source code must retain the above copyright
25 * notice, this list of conditions and the following disclaimer.
26 * 2. Redistributions in binary form must reproduce the above copyright
27 * notice, this list of conditions and the following disclaimer in the
28 * documentation and/or other materials provided with the distribution.
29 * 3. Neither the name of the Intel Corporation nor the names of its contributors
30 * may be used to endorse or promote products derived from this software
31 * without specific prior written permission.
34 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ``AS IS''
35 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
36 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
37 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
38 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
39 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
40 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
41 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
42 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
43 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
47 * -- End of Copyright Notice --
51 * @defgroup IxNpeMhUnsolicitedCbMgr_p IxNpeMhUnsolicitedCbMgr_p
53 * @brief The private API for the Unsolicited Callback Manager module.
58 #ifndef IXNPEMHUNSOLICITEDCBMGR_P_H
59 #define IXNPEMHUNSOLICITEDCBMGR_P_H
62 #include "IxOsalTypes.h"
65 * #defines for function return types, etc.
69 * Prototypes for interface functions.
73 * @fn void ixNpeMhUnsolicitedCbMgrInitialize (void)
75 * @brief This function initializes the Unsolicited Callback Manager
76 * module, setting up a callback data structure for each NPE.
78 * @return No return value.
81 void ixNpeMhUnsolicitedCbMgrInitialize (void);
84 * @fn void ixNpeMhUnsolicitedCbMgrCallbackSave (
86 IxNpeMhMessageId unsolicitedMessageId,
87 IxNpeMhCallback unsolicitedCallback)
89 * @brief This function saves a callback in the specified NPE's callback
90 * table. If a callback already exists for the specified ID then it will
93 * @param IxNpeMhNpeId npeId (in) - The ID of the NPE in whose callback
94 * table the callback will be saved.
95 * @param IxNpeMhMessageId unsolicitedMessageId (in) - The ID of the
96 * messages that this callback is for.
97 * @param IxNpeMhCallback unsolicitedCallback (in) - The callback function
100 * @return No return value.
103 void ixNpeMhUnsolicitedCbMgrCallbackSave (
105 IxNpeMhMessageId unsolicitedMessageId
,
106 IxNpeMhCallback unsolicitedCallback
);
109 * @fn void ixNpeMhUnsolicitedCbMgrCallbackRetrieve (
111 IxNpeMhMessageId unsolicitedMessageId,
112 IxNpeMhCallback *unsolicitedCallback)
114 * @brief This function retrieves the callback for the specified ID from
115 * the specified NPE's callback table. If no callback is registered for
116 * the specified ID and NPE then a callback value of NULL will be returned.
118 * @param IxNpeMhNpeId npeId (in) - The ID of the NPE from whose callback
119 * table the callback will be retrieved.
120 * @param IxNpeMhMessageId unsolicitedMessageId (in) - The ID of the
121 * messages that the callback is for.
122 * @param IxNpeMhCallback unsolicitedCallback (out) - The callback function
125 * @return No return value.
128 void ixNpeMhUnsolicitedCbMgrCallbackRetrieve (
130 IxNpeMhMessageId unsolicitedMessageId
,
131 IxNpeMhCallback
*unsolicitedCallback
);
134 * @fn void ixNpeMhUnsolicitedCbMgrShow (
137 * @brief This function will display the current state of the Unsolicited
138 * Callback Manager module.
140 * @param IxNpeMhNpeId npeId (in) - The ID of the NPE to display state
143 * @return No return value.
146 void ixNpeMhUnsolicitedCbMgrShow (
150 * @fn void ixNpeMhUnsolicitedCbMgrShowReset (
153 * @brief This function will reset the current state of the Unsolicited
154 * Callback Manager module.
156 * @param IxNpeMhNpeId npeId (in) - The ID of the NPE to reset state
159 * @return No return value.
162 void ixNpeMhUnsolicitedCbMgrShowReset (
165 #endif /* IXNPEMHUNSOLICITEDCBMGR_P_H */
168 * @} defgroup IxNpeMhUnsolicitedCbMgr_p