MAX32675 Peripheral Driver API
Peripheral Driver API for the MAX32675
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  *************************************************************************** */
38 
39 /* Define to prevent redundant inclusion */
40 #ifndef _DELAY_H_
41 #define _DELAY_H_
42 
50 /***** Definitions *****/
57 #define MXC_DELAY_SEC(s) (((unsigned long)s) * 1000000UL)
58 
64 #define MXC_DELAY_MSEC(ms) (ms * 1000UL)
65 
71 #define MXC_DELAY_USEC(us) (us)
72 
79 typedef void (*mxc_delay_complete_t) (int result);
80 
81 /***** Function Prototypes *****/
82 
91 int MXC_Delay (unsigned long us);
92 
106 int MXC_DelayAsync (unsigned long us, mxc_delay_complete_t callback);
107 
113 int MXC_DelayCheck (void);
114 
119 void MXC_DelayAbort (void);
120 
126 void MXC_DelayHandler (void);
127 
130 #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:79
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.