MAX32665 Peripheral Driver API
Peripheral Driver API for the MAX32665
mxc_delay.h
1 
6 /* ****************************************************************************
7  * Copyright (C) 2016 Maxim Integrated Products, Inc., All Rights Reserved.
8  *
9  * Permission is hereby granted, free of charge, to any person obtaining a
10  * copy of this software and associated documentation files (the "Software"),
11  * to deal in the Software without restriction, including without limitation
12  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
13  * and/or sell copies of the Software, and to permit persons to whom the
14  * Software is furnished to do so, subject to the following conditions:
15  *
16  * The above copyright notice and this permission notice shall be included
17  * in all copies or substantial portions of the Software.
18  *
19  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
20  * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
21  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
22  * IN NO EVENT SHALL MAXIM INTEGRATED BE LIABLE FOR ANY CLAIM, DAMAGES
23  * OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
24  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
25  * OTHER DEALINGS IN THE SOFTWARE.
26  *
27  * Except as contained in this notice, the name of Maxim Integrated
28  * Products, Inc. shall not be used except as stated in the Maxim Integrated
29  * Products, Inc. Branding Policy.
30  *
31  * The mere transfer of this software does not imply any licenses
32  * of trade secrets, proprietary technology, copyrights, patents,
33  * trademarks, maskwork rights, or any other form of intellectual
34  * property whatsoever. Maxim Integrated Products, Inc. retains all
35  * ownership rights.
36  *
37  * $Date: 2018-08-28 17:06:43 -0500 (Tue, 28 Aug 2018) $
38  * $Revision: 37425 $
39  *
40  *************************************************************************** */
41 
42 /* Define to prevent redundant inclusion */
43 #ifndef _DELAY_H_
44 #define _DELAY_H_
45 
53 /***** Definitions *****/
60 #define MXC_DELAY_SEC(s) (((unsigned long)s) * 1000000UL)
61 
67 #define MXC_DELAY_MSEC(ms) (ms * 1000UL)
68 
74 #define MXC_DELAY_USEC(us) (us)
75 
82 typedef void (*mxc_delay_complete_t) (int result);
83 
84 /***** Function Prototypes *****/
85 
94 int MXC_Delay(unsigned long us);
95 
109 int MXC_DelayAsync (unsigned long us, mxc_delay_complete_t callback);
110 
116 int MXC_DelayCheck (void);
117 
122 void MXC_DelayAbort (void);
123 
129 void MXC_DelayHandler (void);
130 
133 #endif /* _DELAY_H_ */
MXC_DelayCheck
int MXC_DelayCheck(void)
Returns the status of a non-blocking delay request.
MXC_DelayHandler
void MXC_DelayHandler(void)
Processes the delay interrupt.
MXC_DelayAbort
void MXC_DelayAbort(void)
Stops an asynchronous delay previously started.
mxc_delay_complete_t
void(* mxc_delay_complete_t)(int result)
The callback routine used by MXC_DelayAsync() when the delay is complete or aborted early.
Definition: mxc_delay.h:82
MXC_Delay
int MXC_Delay(unsigned long us)
Blocks and delays for the specified number of microseconds.
MXC_DelayAsync
int MXC_DelayAsync(unsigned long us, mxc_delay_complete_t callback)
Starts a non-blocking delay for the specified number of microseconds.