67eda96a78a6d4ceacaf5a8d4d4a35b18770a810
[deb_dpdk.git] / lib / librte_cryptodev / rte_cryptodev_pci.h
1 /*-
2  *   BSD LICENSE
3  *
4  *   Copyright(c) 2017 Intel Corporation. All rights reserved.
5  *
6  *   Redistribution and use in source and binary forms, with or without
7  *   modification, are permitted provided that the following conditions
8  *   are met:
9  *
10  *     * Redistributions of source code must retain the above copyright
11  *       notice, this list of conditions and the following disclaimer.
12  *     * Redistributions in binary form must reproduce the above copyright
13  *       notice, this list of conditions and the following disclaimer in
14  *       the documentation and/or other materials provided with the
15  *       distribution.
16  *     * Neither the name of the copyright holder nor the names of its
17  *       contributors may be used to endorse or promote products derived
18  *       from this software without specific prior written permission.
19  *
20  *   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21  *   "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22  *   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23  *   A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24  *   OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25  *   SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26  *   LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27  *   DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28  *   THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29  *   (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30  *   OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31  */
32
33 #ifndef _RTE_CRYPTODEV_PCI_H_
34 #define _RTE_CRYPTODEV_PCI_H_
35
36 #include <rte_pci.h>
37 #include "rte_cryptodev.h"
38
39 /**
40  * Initialisation function of a crypto driver invoked for each matching
41  * crypto PCI device detected during the PCI probing phase.
42  *
43  * @param       dev     The dev pointer is the address of the *rte_cryptodev*
44  *                      structure associated with the matching device and which
45  *                      has been [automatically] allocated in the
46  *                      *rte_crypto_devices* array.
47  *
48  * @return
49  *   - 0: Success, the device is properly initialised by the driver.
50  *        In particular, the driver MUST have set up the *dev_ops* pointer
51  *        of the *dev* structure.
52  *   - <0: Error code of the device initialisation failure.
53  */
54 typedef int (*cryptodev_pci_init_t)(struct rte_cryptodev *dev);
55
56 /**
57  * Finalisation function of a driver invoked for each matching
58  * PCI device detected during the PCI closing phase.
59  *
60  * @param       dev     The dev pointer is the address of the *rte_cryptodev*
61  *                      structure associated with the matching device and which
62  *                      has been [automatically] allocated in the
63  *                      *rte_crypto_devices* array.
64  *
65  *  * @return
66  *   - 0: Success, the device is properly finalised by the driver.
67  *        In particular, the driver MUST free the *dev_ops* pointer
68  *        of the *dev* structure.
69  *   - <0: Error code of the device initialisation failure.
70  */
71 typedef int (*cryptodev_pci_uninit_t)(struct rte_cryptodev *dev);
72
73 /**
74  * @internal
75  * Wrapper for use by pci drivers as a .probe function to attach to a crypto
76  * interface.
77  */
78 int
79 rte_cryptodev_pci_generic_probe(struct rte_pci_device *pci_dev,
80                         size_t private_data_size,
81                         cryptodev_pci_init_t dev_init);
82
83 /**
84  * @internal
85  * Wrapper for use by pci drivers as a .remove function to detach a crypto
86  * interface.
87  */
88 int
89 rte_cryptodev_pci_generic_remove(struct rte_pci_device *pci_dev,
90                 cryptodev_pci_uninit_t dev_uninit);
91
92 #endif /* _RTE_CRYPTODEV_PCI_H_ */