blob: 1bbc682713c269df9531214c5e6412dff9ce70a8 [file] [log] [blame]
rjw6c1fd8f2022-11-30 14:33:01 +08001
2
3#if !defined(DRV_GPIO_NOT_EXIST) && !defined(DRV_GPIO_OFF)
4
5#include "kal_general_types.h"
6#include "kal_public_api.h"
7#include "dcl.h"
8#include "drv_gpio.h"
9
10#include "drvpdn.h"
11
12#define DCL_GPIO_MAGIC_NUM 0x80000000
13#define DCL_GPO_MAGIC_NUM 0x40000000
14#define DCL_GPIO_CLK_MAGIC_NUM 0x20000000
15
16#define DCL_GPIO_IS_HANDLE_MAGIC(handle_) ((handle_)& DCL_GPIO_MAGIC_NUM)
17#define DCL_GPIO_GET_DEV(handle_) ((handle_)& (~DCL_GPIO_MAGIC_NUM))
18
19#define DCL_GPO_IS_HANDLE_MAGIC(handle_) ((handle_) & DCL_GPO_MAGIC_NUM)
20#define DCL_GPO_GET_DEV(handle_) ((handle_) & (~DCL_GPO_MAGIC_NUM))
21
22#define DCL_GPIO_CLK_IS_HANDLE_MAGIC(handle_) ((handle_) & DCL_GPIO_CLK_MAGIC_NUM)
23#define DCL_GPIO_CLK_GET_DEV(handle_) ((handle_) & (~DCL_GPIO_MAGIC_NUM))
24
25/*-----------------------------------------------------------------------*
26* FUNCTION
27* DclGPIO_Initialize
28*
29* DESCRIPTION
30* This function is to initialize GPIO module. Note that all the GPIO pin
31* will be set to a predefined state.
32*
33* PARAMETERS
34* DCL_STATUS_OK
35*
36* RETURNS
37* none
38*
39*-----------------------------------------------------------------------*/
40DCL_STATUS DclGPIO_Initialize(void)
41{
42 extern void GPIO_init(void);
43
44 GPIO_init();
45 return STATUS_OK;
46}
47
48/*-----------------------------------------------------------------------*
49* FUNCTION
50* DclGPIO_Open
51* DESCRIPTION
52* This function is to open the GPIO module and get a handle. Note that multiple opens are allowed.
53*
54* PARAMETERS
55* eDev: - only valid for DCL_GPIO,DCL_GPO,DCL_GPIO_CLK.
56* flags: - no sepcial flags is needed. Please use FLAGS_NONE
57*
58* RETURN VALUES
59* DCL_HANDLE_INVALID: - Open failed.
60* other value: - a valid handle
61*
62*-----------------------------------------------------------------------*/
63
64DCL_HANDLE DclGPIO_Open(DCL_DEV eDev, DCL_FLAGS flags)
65{
66// PDN_CLR(PDN_GPIO);
67 if(flags>GPIO_PIN_MAX)
68 {
69 ASSERT(0);
70 return DCL_HANDLE_INVALID;
71 }
72 if(eDev==DCL_GPIO)
73 {
74 return (DCL_GPIO_MAGIC_NUM | flags);
75 }
76 else if(eDev==DCL_GPO)
77 {
78 return (DCL_GPO_MAGIC_NUM | flags);
79 }
80 else if(eDev==DCL_GPIO_CLK)
81 {
82 return (DCL_GPIO_CLK_MAGIC_NUM | flags);
83 }
84 else
85 {
86 EXT_ASSERT(0,eDev,flags,0);
87 return DCL_HANDLE_INVALID;
88 }
89}
90
91/*-----------------------------------------------------------------------*
92* FUNCTION
93* DclGPIO_ReadData
94*
95* DESCRIPTION
96* This function is not supported for the GPIO module now.
97*
98* PARAMETERS
99* N/A
100*
101* RETURN VALUES
102* STATUS_UNSUPPORTED:
103*
104*-----------------------------------------------------------------------*/
105DCL_STATUS DclGPIO_ReadData(DCL_HANDLE handle, DCL_BUFF *buff, DCL_BUFF_LEN *buf_len, DCL_OPTIONS options)
106{
107 return STATUS_UNSUPPORTED;
108}
109
110/*-----------------------------------------------------------------------*
111* FUNCTION
112* DclGPIO_WriteData
113*
114* DESCRIPTION
115* This function is not supported for the GPIO module now.
116*
117* PARAMETERS
118* N/A
119*
120* RETURNS
121* STATUS_UNSUPPORTED
122*
123*-----------------------------------------------------------------------*/
124DCL_STATUS DclGPIO_WriteData(DCL_HANDLE handle, DCL_BUFF *buff, DCL_BUFF_LEN *buf_len, DCL_OPTIONS options)
125{
126 return STATUS_UNSUPPORTED;
127}
128
129/*-----------------------------------------------------------------------*
130* FUNCTION
131* DclGPIO_Configure
132*
133* DESCRIPTION
134* This function is not supported for the GPIO module now.
135*
136* PARAMETERS
137* N/A
138*
139* RETURNS
140* STATUS_UNSUPPORTED
141*
142*-----------------------------------------------------------------------*/
143DCL_STATUS DclGPIO_Configure(DCL_HANDLE handle, DCL_CONFIGURE_T *configure)
144{
145 return STATUS_UNSUPPORTED;
146}
147
148/*-----------------------------------------------------------------------*
149* FUNCTION
150* DclGPIO_RegisterCallback
151*
152* DESCRIPTION
153* This function is not supported for the GPIO module now.
154*
155* PARAMETERS
156* N/A
157*
158* RETURNS
159* STATUS_UNSUPPORTED
160*
161*-----------------------------------------------------------------------*/
162DCL_STATUS DclGPIO_RegisterCallback(DCL_HANDLE handle, DCL_EVENT event, PFN_DCL_CALLBACK callback)
163{
164 return STATUS_UNSUPPORTED;
165}
166
167/*-----------------------------------------------------------------------*
168* FUNCTION
169* DclGPIO_Control
170*
171* DESCRIPTION
172* This function is to send command to control the GPIO module.
173*
174* PARAMETERS
175* handle - a valid handle return by DclGPIO_Open()
176* cmd - a control command for GPIO module
177* 1. GPIO_CMD_READ: to read the input value from the GPIO port contain in handle.
178* 2. GPIO_CMD_WRITE_LOW: to write low to the output of GPIO port contain in handle.
179* 3. GPIO_CMD_WRITE_HIGH: to write high to the output of GPIO port contain in handle.
180* 4. GPIO_CMD_SET_MODE_0: to set the mode of the GPIO port contain in handle as mode 0.
181* 5. GPIO_CMD_SET_MODE_1: to set the mode of the GPIO port contain in handle as mode 1.
182* 6. GPIO_CMD_SET_MODE_2: to set the mode of the GPIO port contain in handle as mode 2.
183* 7. GPIO_CMD_SET_MODE_3: to set the mode of the GPIO port contain in handle as mode 3.
184* 8. GPIO_CMD_SET_DIR_OUT: to set the direction of the GPIO port as output.
185* 9. GPIO_CMD_SET_DIR_IN: to set the direction of the GPIO port as input.
186* 10. GPIO_CMD_RETURN_MODE: to get the mode of the GPIO port
187* 11. GPIO_CMD_RETURN_DIR: to get the direction of the GPIO port
188* 12. GPIO_CMD_RETURN_OUT: to return the output value of the GPIO port
189* 13. GPIO_CMD_ENABLE_PULL: to enable the pull resister for a GPIO port
190* 14. GPIO_CMD_DISABLE_PULL: to disenable the pull resister for a GPIO port
191* 15. GPIO_CMD_SET_PULL_HIGH: to select the pull up for a GPIO port
192* 16. GPIO_CMD_SET_PULL_LOW: to select the pull down for a GPIO port
193* 17. GPIO_CMD_SET_DINV: to set the inversion of a GPIO port
194* 18. GPIO_CMD_SET_DEBUG: to enable or disable debug mode
195* 19. GPIO_CMD_SET_CLK_OUT: to set the clock frequency for a clock output
196*
197* 20. GPO_CMD_RETURN_MODE: to get the mode of the GPO port
198* 21. GPO_CMD_RETURN_OUT: to return the output value of the GPO port
199* 22. GPO_CMD_WRITE_HIGH: to write high to the output of GPO port contain in handle.
200* 23. GPO_CMD_WRITE_LOW: to write low to the output of GPO port contain in handle.
201* 24. GPO_CMD_MODE_SET_0: to set the mode of the GPIO port contain in handle as mode 0.
202* 25. GPO_CMD_MODE_SET_1: to set the mode of the GPI1 port contain in handle as mode 1.
203* 26. GPO_CMD_MODE_SET_2: to set the mode of the GPI2 port contain in handle as mode 2.
204* 27. GPO_CMD_MODE_SET_3: to set the mode of the GPI3 port contain in handle as mode 3.
205
206* 28. GPIO_CMD_SET_DIR_OUT_NO_IRQ_MASK_T: to set the direction of the GPIO port as output without IRQ protect.
207* 29. GPIO_CMD_SET_DIR_IN_NO_IRQ_MASK_T: to set the direction of the GPIO port as input without IRQ protect
208* 30. GPIO_CMD_WRITE_HIGH_NO_IRQ_MASK_T: to write high to the output of GPIO port contain in handle without IRQ protect.
209* 31. GPIO_CMD_WRITE_LOW_NO_IRQ_MASK_T: to write low to the output of GPIO port contain in handle without IRQ protect.
210* 32. GPIO_CMD_READ_NO_IRQ_MASK_T: to read the input value from the GPIO port contain in handle without IRQ protect..
211
212* 33. GPIO_CMD_WRITE_FOR_SPI_T:
213* data - for 1. GPIO_CMD_READ:
214* 1. GPIO_CMD_READ: pointer to a GPIO_CTRLS structure
215* 2. GPIO_CMD_WRITE_LOW: NULL.
216* 3. GPIO_CMD_WRITE_HIGH: NULL.
217* 4. GPIO_CMD_SET_MODE_0: NULL.
218* 5. GPIO_CMD_SET_MODE_1: NULL.
219* 6. GPIO_CMD_SET_MODE_2: NULL.
220* 7. GPIO_CMD_SET_MODE_3: NULL.
221* 8. GPIO_CMD_SET_DIR_OUT: NULL.
222* 9. GPIO_CMD_SET_DIR_IN: NULL.
223* 10. GPIO_CMD_RETURN_MODE: pointer to a GPIO_CTRL_RETURN_MODE_T structure
224* 11. GPIO_CMD_RETURN_DIR: pointer to a GPIO_CTRL_SET_DIR_T structure
225* 12. GPIO_CMD_RETURN_OUT: pointer to a GPIO_CTRL_RETURN_OUT_T structure
226* 13. GPIO_CMD_ENABLE_PULL: NULL.
227* 14. GPIO_CMD_DISABLE_PULL: NULL.
228* 15. GPIO_CMD_SET_PULL_HIGH: NULL.
229* 16. GPIO_CMD_SET_PULL_LOW: NULL.
230* 17. GPIO_CMD_SET_DINV: pointer to a GPIO_CTRL_SET_DINV_T structure
231* 18. GPIO_CMD_SET_DEBUG: pointer to a GPIO_CTRL_SET_DEBUG_T structure
232* 19. GPIO_CMD_SET_CLK_OUT: pointer to a GPIO_CTRL_SET_CLK_OUT_T structure
233*
234* 20. GPO_CMD_RETURN_MODE: pointer to a GPO_CTRL_RETURN_MODE_T structure
235* 21. GPO_CMD_RETURN_OUT: pointer to a GPO_CTRL_RETURN_OUT_T structure
236* 22. GPO_CMD_WRITE_HIGH: NULL.
237* 23. GPO_CMD_WRITE_LOW: NULL.
238* 24. GPO_CMD_MODE_SET_0: NULL..
239* 25. GPO_CMD_MODE_SET_1: NULL..
240* 26. GPO_CMD_MODE_SET_2: NULL.
241* 27. GPO_CMD_MODE_SET_3: NULL.
242
243* 28. GPIO_CMD_SET_DIR_OUT_NO_IRQ_MASK_T: NULL.
244* 29. GPIO_CMD_SET_DIR_IN_NO_IRQ_MASK_T: NULL.
245* 30. GPIO_CMD_WRITE_HIGH_NO_IRQ_MASK_T: NULL.
246* 31. GPIO_CMD_WRITE_LOW_NO_IRQ_MASK_T: NULL.
247* 32. GPIO_CMD_READ_NO_IRQ_MASK_T: pointer to a GPIO_CTRLS structure
248
249* 33. GPIO_CMD_WRITE_FOR_SPI_T: pointer to
250* RETURNS
251* STATUS_OK - command is executed successfully.
252* STATUS_FAIL - command is failed.
253* STATUS_INVALID_CMD - The command is invalid.
254* STATUS_INVALID_HANDLE - The handle is invalid.
255* STATUS_INVALID_CTRL_DATA - The ctrl data is not valid.
256*-----------------------------------------------------------------------*/
257DCL_STATUS DclGPIO_Control(DCL_HANDLE handle, DCL_CTRL_CMD cmd, DCL_CTRL_DATA_T *data)
258{
259 kal_int16 port;
260 port= 0x0000FFFF & handle;
261
262 if(DCL_HANDLE_INVALID==handle)
263 {
264 return STATUS_FAIL;
265 }
266
267 if(DCL_GPIO_IS_HANDLE_MAGIC(handle))
268 {
269 switch(cmd)
270 {
271 case GPIO_CMD_READ:
272 {
273 GPIO_CTRL_READ_T *prRead;
274 prRead = &(data->rRead);
275 prRead->u1IOData = GPIO_ReadIO(port);
276 break;
277 }
278 case GPIO_CMD_WRITE_LOW:
279 {
280 GPIO_WriteIO(GPIO_IO_LOW, port);
281 break;
282 }
283 case GPIO_CMD_WRITE_HIGH:
284 {
285 GPIO_WriteIO(GPIO_IO_HIGH, port);
286 break;
287 }
288 case GPIO_CMD_SET_MODE_0:
289 {
290 GPIO_ModeSetup(port, GPIO_MODE_0);
291 break;
292 }
293 case GPIO_CMD_SET_MODE_1:
294 {
295 GPIO_ModeSetup(port, GPIO_MODE_1);
296 break;
297 }
298 case GPIO_CMD_SET_MODE_2:
299 {
300 GPIO_ModeSetup(port, GPIO_MODE_2);
301 break;
302 }
303 case GPIO_CMD_SET_MODE_3:
304 {
305 GPIO_ModeSetup(port, GPIO_MODE_3);
306 break;
307 }
308 case GPIO_CMD_SET_MODE_4: //mode4-7 only for chip support more than 3bit mode control.
309 {
310 GPIO_ModeSetup(port, GPIO_MODE_4);
311 break;
312 }
313 case GPIO_CMD_SET_MODE_5:
314 {
315 GPIO_ModeSetup(port, GPIO_MODE_5);
316 break;
317 }
318 case GPIO_CMD_SET_MODE_6:
319 {
320 GPIO_ModeSetup(port, GPIO_MODE_6);
321 break;
322 }
323 case GPIO_CMD_SET_MODE_7:
324 {
325 GPIO_ModeSetup(port, GPIO_MODE_7);
326 break;
327 }
328 case GPIO_CMD_SET_DIR_OUT:
329 {
330 GPIO_InitIO(GPIO_DIR_OUT,port);
331 break;
332 }
333 case GPIO_CMD_SET_DIR_IN:
334 {
335 GPIO_InitIO(GPIO_DIR_IN,port);
336 break;
337 }
338 case GPIO_CMD_RETURN_MODE:
339 {
340 GPIO_CTRL_RETURN_MODE_T *prReturnMode;
341 prReturnMode = &(data->rReturnMode);
342 prReturnMode->u1RetMode = GPIO_ReturnMode(port);
343 break;
344 }
345 case GPIO_CMD_RETURN_DIR:
346 {
347 GPIO_CTRL_RETURN_DIR_T *prReturnDir;
348 prReturnDir = &(data->rReturnDir);
349 prReturnDir->u1RetDirData =GPIO_ReturnDir(port);
350 break;
351 }
352 case GPIO_CMD_RETURN_OUT:
353 {
354 GPIO_CTRL_RETURN_OUT_T *prReturnOut;
355 prReturnOut = &(data->rReturnOut);
356 prReturnOut->u1RetOutData = GPIO_ReturnDout(port);
357 break;
358 }
359 case GPIO_CMD_ENABLE_PULL:
360 {
361 GPIO_PullenSetup(port, (kal_bool)GPIO_PULL_ENABLE);
362 break;
363 }
364 case GPIO_CMD_DISABLE_PULL:
365 {
366 GPIO_PullenSetup(port, (kal_bool)GPIO_PULL_DISABLE);
367 break;
368 }
369 case GPIO_CMD_SET_PULL_HIGH:
370 {
371 GPIO_PullSelSetup(port,(kal_bool) GPIO_PULL_HIGH);
372 break;
373 }
374 case GPIO_CMD_SET_PULL_LOW:
375 {
376 GPIO_PullSelSetup(port, (kal_bool)GPIO_PULL_LOW);
377 break;
378 }
379 case GPIO_CMD_SET_DINV:
380 {
381 GPIO_CTRL_SET_DINV_T *prSetDinv;
382 prSetDinv = &(data->rSetDinv);
383 GPIO_DinvSetup(port,(kal_bool)( prSetDinv->fgSetDinv));
384 break;
385 }
386 case GPIO_CMD_SET_DEBUG:
387 {
388// GPIO_CTRL_SET_DEBUG_T *prSetDebug;
389// prSetDebug = &(data->rSetDebug);
390// GPIO_SetDebugMode((kal_bool)(prSetDebug->fgSetDebug));
391 break;
392 }
393 #ifdef __CUST_NEW__
394 case GPIO_CMD_SET_DIR_OUT_NO_IRQ_MASK:
395 {
396 GPIO_InitIO_FAST(GPIO_DIR_OUT,port);
397 break;
398 }
399 case GPIO_CMD_SET_DIR_IN_NO_IRQ_MASK:
400 {
401 GPIO_InitIO_FAST(GPIO_DIR_IN,port);
402 break;
403 }
404 case GPIO_CMD_WRITE_HIGH_NO_IRQ_MASK:
405 {
406 GPIO_WriteIO_FAST(GPIO_IO_HIGH,port);
407 break;
408 }
409 case GPIO_CMD_WRITE_LOW_NO_IRQ_MASK:
410 {
411 GPIO_WriteIO_FAST(GPIO_IO_LOW,port);
412 break;
413 }
414 case GPIO_CMD_READ_NO_IRQ_MASK:
415 {
416 GPIO_CTRL_READ_T *prRead;
417 prRead = &(data->rRead);
418 prRead->u1IOData = GPIO_ReadIO_FAST(port);
419 break;
420 }
421 #endif
422 case GPIO_CMD_WRITE_FOR_SPI:
423 {
424 GPIO_CTRL_WRITE_FOR_SPI_T *prWrite;
425 prWrite = &(data->rWriteSpi);
426 GPIO_WriteIO_FAST2(prWrite->data,prWrite->no,prWrite->remainder_shift);
427 break;
428 }
429 case GPIO_CMD_SET_OWNERSHIP_TO_MD:
430 {
431 gpio_set_ownership(port,GPIO_MD_OWNERSHIP);
432 break;
433 }
434 case GPIO_CMD_SET_OWNERSHIP_TO_AP:
435 {
436 gpio_set_ownership(port,GPIO_AP_OWNERSHIP);
437 break;
438 }
439 case GPIO_CMD_SET_DRIVE:
440 {
441 GPIO_CTRL_SET_DRIVE_T *prDrive;
442 prDrive = &(data->rSetDrive);
443 if(gpio_set_drive(port,prDrive->u1DriveMode)!=0)
444 {
445 return STATUS_FAIL;
446 }
447 break;
448 }
449 case GPIO_CMD_RETURN_DRIVE:
450 {
451// GPIO_CTRL_SET_DRIVE_T *prDrive;
452// prDrive = &(data->rReturnDrive);
453// prDrive->u1DriveMode = gpio_get_drive_value(port);
454 break;
455 }
456 case GPIO_CMD_RETURN_OWNERSHIP:
457 {
458 GPIO_CTRL_RETURN_OWNERSHIP_T *prOwnership;
459 prOwnership = &(data->rReturnOwnership);
460 prOwnership->u1OwnerShip = gpio_get_ownership(port);
461 break;
462 }
463 default:
464 EXT_ASSERT(0,handle,cmd,0);
465 return STATUS_INVALID_CMD;
466 }
467 }
468 else if(DCL_GPO_IS_HANDLE_MAGIC(handle))
469 {
470 switch(cmd)
471 {
472 case GPO_CMD_MODE_SET_0:
473 {
474// GPO_ModeSetup(port,GPO_MODE_0);
475 break;
476 }
477 case GPO_CMD_MODE_SET_1:
478 {
479// GPO_ModeSetup(port,GPO_MODE_1);
480 break;
481 }
482 case GPO_CMD_MODE_SET_2:
483 {
484// GPO_ModeSetup(port,GPO_MODE_2);
485 break;
486 }
487 case GPO_CMD_MODE_SET_3:
488 {
489// GPO_ModeSetup(port,GPO_MODE_3);
490 break;
491 }
492 case GPO_CMD_WRITE_LOW :
493 {
494// GPO_WriteIO(port,GPO_IO_LOW);
495 break;
496 }
497 case GPO_CMD_WRITE_HIGH:
498 {
499// GPO_WriteIO(port,GPO_IO_HIGH);
500 break;
501 }
502 case GPO_CMD_RETURN_OUT:
503 {
504// GPO_CTRL_RETURN_OUT_T *prReturnOut;
505// prReturnOut = &(data->oReturnOut);
506// prReturnOut->u1RetOutData = GPO_ReturnDout(port);
507 break;
508 }
509 case GPO_CMD_RETURN_MODE:
510 {
511// GPO_CTRL_RETURN_MODE_T *prReturnMode;
512// prReturnMode = &(data->oReturnMode);
513// prReturnMode->u1RetMode = GPO_ReturnMode(port);
514 break;
515 }
516 default:
517 EXT_ASSERT(0,handle,cmd,0);
518 return STATUS_INVALID_CMD;
519 }
520 }
521 else if (DCL_GPIO_CLK_IS_HANDLE_MAGIC(handle))
522 {
523 switch(cmd)
524 {
525 case GPIO_CMD_SET_CLK_OUT:
526 {
527 /* //not support in MT6290
528 kal_uint8 mode=0;
529 kal_uint8 clknum=0;
530 GPIO_CTRL_SET_CLK_OUT_T *prSetClkOut;
531 prSetClkOut = &(data->rSetClkOut);
532 mode = get_mode(prSetClkOut->u2Mode);
533 clknum=get_clknum(prSetClkOut->u2ClkNum);
534 GPIO_SetClkOut(clknum,(gpio_clk_mode)mode);
535 */
536 break;
537 }
538 case GPIO_CMD_SET_CLK_DIV:
539 {
540 /* //not support in MT6290
541 kal_uint8 clknum=0;
542 GPIO_CTRL_SET_CLK_DIV_T *prSetClkDiv;
543 prSetClkDiv= &(data->rSetClkDiv);
544 clknum=get_clknum(prSetClkDiv->u2ClkNum);
545 GPIO_SetClkDiv(clknum,prSetClkDiv->u2Div);
546 */
547 break;
548 }
549 default:
550 EXT_ASSERT(0,handle,cmd,0);
551 return STATUS_INVALID_CMD;
552 }
553 }
554 else
555 {
556 EXT_ASSERT(0,handle,cmd,0);
557 return STATUS_INVALID_DCL_HANDLE;
558 }
559 return STATUS_OK;
560}
561
562/*-----------------------------------------------------------------------*
563* FUNCTION
564* DclGPIO_Close
565*
566* DESCRIPTION
567* This function is not supported for the GPIO module now.
568*
569* PARAMETERS
570* N/A
571*
572* RETURNS
573* STATUS_UNSUPPORTED
574*
575*-----------------------------------------------------------------------*/
576DCL_STATUS DclGPIO_Close(DCL_HANDLE handle)
577{
578 return STATUS_OK;
579}
580
581
582#else /*!defined(DRV_GPIO_NOT_EXIST) && !defined(DRV_GPIO_OFF)*/
583
584DCL_STATUS DclGPIO_Initialize(void)
585{
586 return STATUS_FAIL;
587}
588
589DCL_HANDLE DclGPIO_Open(DCL_DEV dev, DCL_FLAGS flags)
590{
591 return DCL_HANDLE_INVALID;
592}
593
594DCL_STATUS DclGPIO_ReadData(DCL_HANDLE handle, DCL_BUFF *buff, DCL_BUFF_LEN *buf_len, DCL_OPTIONS options)
595{
596 return STATUS_UNSUPPORTED;
597}
598
599DCL_STATUS DclGPIO_WriteData(DCL_HANDLE handle, DCL_BUFF *buff, DCL_BUFF_LEN *buf_len, DCL_OPTIONS options)
600{
601 return STATUS_UNSUPPORTED;
602}
603
604DCL_STATUS DclGPIO_Configure(DCL_HANDLE handle, DCL_CONFIGURE_T *configure)
605{
606 return STATUS_UNSUPPORTED;
607}
608
609DCL_STATUS DclGPIO_RegisterCallback(DCL_HANDLE handle, DCL_EVENT event, PFN_DCL_CALLBACK callback)
610{
611 return STATUS_FAIL;
612}
613
614DCL_STATUS DclGPIO_Control(DCL_HANDLE handle, DCL_CTRL_CMD cmd, DCL_CTRL_DATA_T *data)
615{
616 return STATUS_FAIL;
617}
618
619DCL_STATUS DclGPIO_Close(DCL_HANDLE handle)
620{
621 return STATUS_FAIL;
622}
623#endif /*!defined(DRV_GPIO_NOT_EXIST) && !defined(DRV_GPIO_OFF)*/
624