xref: /OK3568_Linux_fs/u-boot/include/fsl-mc/fsl_dpbp.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun  * Freescale Layerscape MC I/O wrapper
3*4882a593Smuzhiyun  *
4*4882a593Smuzhiyun  * Copyright (C) 2013-2015 Freescale Semiconductor, Inc.
5*4882a593Smuzhiyun  * Author: German Rivera <German.Rivera@freescale.com>
6*4882a593Smuzhiyun  *
7*4882a593Smuzhiyun  * SPDX-License-Identifier:	GPL-2.0+
8*4882a593Smuzhiyun  */
9*4882a593Smuzhiyun /*!
10*4882a593Smuzhiyun  *  @file    fsl_dpbp.h
11*4882a593Smuzhiyun  *  @brief   Data Path Buffer Pool API
12*4882a593Smuzhiyun  */
13*4882a593Smuzhiyun #ifndef __FSL_DPBP_H
14*4882a593Smuzhiyun #define __FSL_DPBP_H
15*4882a593Smuzhiyun 
16*4882a593Smuzhiyun /* DPBP Version */
17*4882a593Smuzhiyun #define DPBP_VER_MAJOR				2
18*4882a593Smuzhiyun #define DPBP_VER_MINOR				2
19*4882a593Smuzhiyun 
20*4882a593Smuzhiyun /* Command IDs */
21*4882a593Smuzhiyun #define DPBP_CMDID_CLOSE				0x800
22*4882a593Smuzhiyun #define DPBP_CMDID_OPEN					0x804
23*4882a593Smuzhiyun #define DPBP_CMDID_CREATE				0x904
24*4882a593Smuzhiyun #define DPBP_CMDID_DESTROY				0x900
25*4882a593Smuzhiyun 
26*4882a593Smuzhiyun #define DPBP_CMDID_ENABLE				0x002
27*4882a593Smuzhiyun #define DPBP_CMDID_DISABLE				0x003
28*4882a593Smuzhiyun #define DPBP_CMDID_GET_ATTR				0x004
29*4882a593Smuzhiyun #define DPBP_CMDID_RESET				0x005
30*4882a593Smuzhiyun 
31*4882a593Smuzhiyun /*                cmd, param, offset, width, type, arg_name */
32*4882a593Smuzhiyun #define DPBP_CMD_OPEN(cmd, dpbp_id) \
33*4882a593Smuzhiyun 	MC_CMD_OP(cmd, 0, 0,  32, int,	    dpbp_id)
34*4882a593Smuzhiyun 
35*4882a593Smuzhiyun /*                cmd, param, offset, width, type, arg_name */
36*4882a593Smuzhiyun #define DPBP_RSP_GET_ATTRIBUTES(cmd, attr) \
37*4882a593Smuzhiyun do { \
38*4882a593Smuzhiyun 	MC_RSP_OP(cmd, 0, 16, 16, uint16_t, attr->bpid); \
39*4882a593Smuzhiyun 	MC_RSP_OP(cmd, 0, 32, 32, int,	    attr->id);\
40*4882a593Smuzhiyun 	MC_RSP_OP(cmd, 1, 0,  16, uint16_t, attr->version.major);\
41*4882a593Smuzhiyun 	MC_RSP_OP(cmd, 1, 16, 16, uint16_t, attr->version.minor);\
42*4882a593Smuzhiyun } while (0)
43*4882a593Smuzhiyun 
44*4882a593Smuzhiyun /* Data Path Buffer Pool API
45*4882a593Smuzhiyun  * Contains initialization APIs and runtime control APIs for DPBP
46*4882a593Smuzhiyun  */
47*4882a593Smuzhiyun 
48*4882a593Smuzhiyun struct fsl_mc_io;
49*4882a593Smuzhiyun 
50*4882a593Smuzhiyun /**
51*4882a593Smuzhiyun  * dpbp_open() - Open a control session for the specified object.
52*4882a593Smuzhiyun  * @mc_io:	Pointer to MC portal's I/O object
53*4882a593Smuzhiyun  * @cmd_flags:	Command flags; one or more of 'MC_CMD_FLAG_'
54*4882a593Smuzhiyun  * @dpbp_id:	DPBP unique ID
55*4882a593Smuzhiyun  * @token:	Returned token; use in subsequent API calls
56*4882a593Smuzhiyun  *
57*4882a593Smuzhiyun  * This function can be used to open a control session for an
58*4882a593Smuzhiyun  * already created object; an object may have been declared in
59*4882a593Smuzhiyun  * the DPL or by calling the dpbp_create function.
60*4882a593Smuzhiyun  * This function returns a unique authentication token,
61*4882a593Smuzhiyun  * associated with the specific object ID and the specific MC
62*4882a593Smuzhiyun  * portal; this token must be used in all subsequent commands for
63*4882a593Smuzhiyun  * this specific object
64*4882a593Smuzhiyun  *
65*4882a593Smuzhiyun  * Return:	'0' on Success; Error code otherwise.
66*4882a593Smuzhiyun  */
67*4882a593Smuzhiyun int dpbp_open(struct fsl_mc_io	*mc_io,
68*4882a593Smuzhiyun 	      uint32_t		cmd_flags,
69*4882a593Smuzhiyun 	      int		dpbp_id,
70*4882a593Smuzhiyun 	      uint16_t		*token);
71*4882a593Smuzhiyun 
72*4882a593Smuzhiyun /**
73*4882a593Smuzhiyun  * dpbp_close() - Close the control session of the object
74*4882a593Smuzhiyun  * @mc_io:	Pointer to MC portal's I/O object
75*4882a593Smuzhiyun  * @cmd_flags:	Command flags; one or more of 'MC_CMD_FLAG_'
76*4882a593Smuzhiyun  * @token:	Token of DPBP object
77*4882a593Smuzhiyun  *
78*4882a593Smuzhiyun  * After this function is called, no further operations are
79*4882a593Smuzhiyun  * allowed on the object without opening a new control session.
80*4882a593Smuzhiyun  *
81*4882a593Smuzhiyun  * Return:	'0' on Success; Error code otherwise.
82*4882a593Smuzhiyun  */
83*4882a593Smuzhiyun int dpbp_close(struct fsl_mc_io	*mc_io,
84*4882a593Smuzhiyun 	       uint32_t		cmd_flags,
85*4882a593Smuzhiyun 	       uint16_t	token);
86*4882a593Smuzhiyun 
87*4882a593Smuzhiyun /**
88*4882a593Smuzhiyun  * struct dpbp_cfg - Structure representing DPBP configuration
89*4882a593Smuzhiyun  * @options:	place holder
90*4882a593Smuzhiyun  */
91*4882a593Smuzhiyun struct dpbp_cfg {
92*4882a593Smuzhiyun 	uint32_t options;
93*4882a593Smuzhiyun };
94*4882a593Smuzhiyun 
95*4882a593Smuzhiyun /**
96*4882a593Smuzhiyun  * dpbp_create() - Create the DPBP object.
97*4882a593Smuzhiyun  * @mc_io:	Pointer to MC portal's I/O object
98*4882a593Smuzhiyun  * @cmd_flags:	Command flags; one or more of 'MC_CMD_FLAG_'
99*4882a593Smuzhiyun  * @cfg:	Configuration structure
100*4882a593Smuzhiyun  * @token:	Returned token; use in subsequent API calls
101*4882a593Smuzhiyun  *
102*4882a593Smuzhiyun  * Create the DPBP object, allocate required resources and
103*4882a593Smuzhiyun  * perform required initialization.
104*4882a593Smuzhiyun  *
105*4882a593Smuzhiyun  * The object can be created either by declaring it in the
106*4882a593Smuzhiyun  * DPL file, or by calling this function.
107*4882a593Smuzhiyun  * This function returns a unique authentication token,
108*4882a593Smuzhiyun  * associated with the specific object ID and the specific MC
109*4882a593Smuzhiyun  * portal; this token must be used in all subsequent calls to
110*4882a593Smuzhiyun  * this specific object. For objects that are created using the
111*4882a593Smuzhiyun  * DPL file, call dpbp_open function to get an authentication
112*4882a593Smuzhiyun  * token first.
113*4882a593Smuzhiyun  *
114*4882a593Smuzhiyun  * Return:	'0' on Success; Error code otherwise.
115*4882a593Smuzhiyun  */
116*4882a593Smuzhiyun int dpbp_create(struct fsl_mc_io	*mc_io,
117*4882a593Smuzhiyun 		uint32_t		cmd_flags,
118*4882a593Smuzhiyun 		const struct dpbp_cfg	*cfg,
119*4882a593Smuzhiyun 		uint16_t		*token);
120*4882a593Smuzhiyun 
121*4882a593Smuzhiyun /**
122*4882a593Smuzhiyun  * dpbp_destroy() - Destroy the DPBP object and release all its resources.
123*4882a593Smuzhiyun  * @mc_io:	Pointer to MC portal's I/O object
124*4882a593Smuzhiyun  * @cmd_flags:	Command flags; one or more of 'MC_CMD_FLAG_'
125*4882a593Smuzhiyun  * @token:	Token of DPBP object
126*4882a593Smuzhiyun  *
127*4882a593Smuzhiyun  * Return:	'0' on Success; error code otherwise.
128*4882a593Smuzhiyun  */
129*4882a593Smuzhiyun int dpbp_destroy(struct fsl_mc_io	*mc_io,
130*4882a593Smuzhiyun 		 uint32_t		cmd_flags,
131*4882a593Smuzhiyun 		 uint16_t		token);
132*4882a593Smuzhiyun 
133*4882a593Smuzhiyun /**
134*4882a593Smuzhiyun  * dpbp_enable() - Enable the DPBP.
135*4882a593Smuzhiyun  * @mc_io:	Pointer to MC portal's I/O object
136*4882a593Smuzhiyun  * @cmd_flags:	Command flags; one or more of 'MC_CMD_FLAG_'
137*4882a593Smuzhiyun  * @token:	Token of DPBP object
138*4882a593Smuzhiyun  *
139*4882a593Smuzhiyun  * Return:	'0' on Success; Error code otherwise.
140*4882a593Smuzhiyun  */
141*4882a593Smuzhiyun int dpbp_enable(struct fsl_mc_io	*mc_io,
142*4882a593Smuzhiyun 		uint32_t		cmd_flags,
143*4882a593Smuzhiyun 		uint16_t		token);
144*4882a593Smuzhiyun 
145*4882a593Smuzhiyun /**
146*4882a593Smuzhiyun  * dpbp_disable() - Disable the DPBP.
147*4882a593Smuzhiyun  * @mc_io:	Pointer to MC portal's I/O object
148*4882a593Smuzhiyun  * @cmd_flags:	Command flags; one or more of 'MC_CMD_FLAG_'
149*4882a593Smuzhiyun  * @token:	Token of DPBP object
150*4882a593Smuzhiyun  *
151*4882a593Smuzhiyun  * Return:	'0' on Success; Error code otherwise.
152*4882a593Smuzhiyun  */
153*4882a593Smuzhiyun int dpbp_disable(struct fsl_mc_io	*mc_io,
154*4882a593Smuzhiyun 		 uint32_t		cmd_flags,
155*4882a593Smuzhiyun 		 uint16_t		token);
156*4882a593Smuzhiyun 
157*4882a593Smuzhiyun /**
158*4882a593Smuzhiyun  * dpbp_is_enabled() - Check if the DPBP is enabled.
159*4882a593Smuzhiyun  * @mc_io:	Pointer to MC portal's I/O object
160*4882a593Smuzhiyun  * @cmd_flags:	Command flags; one or more of 'MC_CMD_FLAG_'
161*4882a593Smuzhiyun  * @token:	Token of DPBP object
162*4882a593Smuzhiyun  * @en:		Returns '1' if object is enabled; '0' otherwise
163*4882a593Smuzhiyun  *
164*4882a593Smuzhiyun  * Return:	'0' on Success; Error code otherwise.
165*4882a593Smuzhiyun  */
166*4882a593Smuzhiyun int dpbp_is_enabled(struct fsl_mc_io	*mc_io,
167*4882a593Smuzhiyun 		    uint32_t		cmd_flags,
168*4882a593Smuzhiyun 		    uint16_t		token,
169*4882a593Smuzhiyun 		    int		*en);
170*4882a593Smuzhiyun 
171*4882a593Smuzhiyun /**
172*4882a593Smuzhiyun  * dpbp_reset() - Reset the DPBP, returns the object to initial state.
173*4882a593Smuzhiyun  * @mc_io:	Pointer to MC portal's I/O object
174*4882a593Smuzhiyun  * @cmd_flags:	Command flags; one or more of 'MC_CMD_FLAG_'
175*4882a593Smuzhiyun  * @token:	Token of DPBP object
176*4882a593Smuzhiyun  *
177*4882a593Smuzhiyun  * Return:	'0' on Success; Error code otherwise.
178*4882a593Smuzhiyun  */
179*4882a593Smuzhiyun int dpbp_reset(struct fsl_mc_io	*mc_io,
180*4882a593Smuzhiyun 	       uint32_t		cmd_flags,
181*4882a593Smuzhiyun 	       uint16_t	token);
182*4882a593Smuzhiyun 
183*4882a593Smuzhiyun 
184*4882a593Smuzhiyun /**
185*4882a593Smuzhiyun  * struct dpbp_attr - Structure representing DPBP attributes
186*4882a593Smuzhiyun  * @id:		DPBP object ID
187*4882a593Smuzhiyun  * @version:	DPBP version
188*4882a593Smuzhiyun  * @bpid:	Hardware buffer pool ID; should be used as an argument in
189*4882a593Smuzhiyun  *		acquire/release operations on buffers
190*4882a593Smuzhiyun  */
191*4882a593Smuzhiyun struct dpbp_attr {
192*4882a593Smuzhiyun 	int id;
193*4882a593Smuzhiyun 	/**
194*4882a593Smuzhiyun 	 * struct version - Structure representing DPBP version
195*4882a593Smuzhiyun 	 * @major:	DPBP major version
196*4882a593Smuzhiyun 	 * @minor:	DPBP minor version
197*4882a593Smuzhiyun 	 */
198*4882a593Smuzhiyun 	struct {
199*4882a593Smuzhiyun 		uint16_t major;
200*4882a593Smuzhiyun 		uint16_t minor;
201*4882a593Smuzhiyun 	} version;
202*4882a593Smuzhiyun 	uint16_t bpid;
203*4882a593Smuzhiyun };
204*4882a593Smuzhiyun 
205*4882a593Smuzhiyun /**
206*4882a593Smuzhiyun  * dpbp_get_attributes - Retrieve DPBP attributes.
207*4882a593Smuzhiyun  *
208*4882a593Smuzhiyun  * @mc_io:	Pointer to MC portal's I/O object
209*4882a593Smuzhiyun  * @cmd_flags:	Command flags; one or more of 'MC_CMD_FLAG_'
210*4882a593Smuzhiyun  * @token:	Token of DPBP object
211*4882a593Smuzhiyun  * @attr:	Returned object's attributes
212*4882a593Smuzhiyun  *
213*4882a593Smuzhiyun  * Return:	'0' on Success; Error code otherwise.
214*4882a593Smuzhiyun  */
215*4882a593Smuzhiyun int dpbp_get_attributes(struct fsl_mc_io	*mc_io,
216*4882a593Smuzhiyun 			uint32_t	cmd_flags,
217*4882a593Smuzhiyun 			uint16_t		token,
218*4882a593Smuzhiyun 			struct dpbp_attr	*attr);
219*4882a593Smuzhiyun 
220*4882a593Smuzhiyun /** @} */
221*4882a593Smuzhiyun 
222*4882a593Smuzhiyun #endif /* __FSL_DPBP_H */
223