/***************************************************************************//**
 * @file    drv_acmp.h
 * @brief   ACMP (analog comparator) driver of RT-Thread RTOS for EFM32
 *  COPYRIGHT (C) 2012, RT-Thread Development Team
 * @author  onelife
 * @version 1.0
 *******************************************************************************
 * @section License
 * The license and distribution terms for this file may be found in the file
 * LICENSE in this distribution or at http://www.rt-thread.org/license/LICENSE
 *******************************************************************************
 * @section Change Logs
 * Date         Author      Notes
 * 2011-02-23   onelife     Initial creation for EFM32
 * 2011-06-17   onelife     Modify for efm32lib v2 upgrading
 ******************************************************************************/
#ifndef __DRV_ACMP_H__
#define __DRV_ACMP_H__

/* Includes ------------------------------------------------------------------*/
#include "hdl_interrupt.h"

/* Exported types ------------------------------------------------------------*/
struct efm32_acmp_device_t
{
    ACMP_TypeDef        *acmp_device;
    efm32_irq_hook_t    hook;
};

struct efm32_acmp_output_t
{
    rt_uint32_t         location;
    rt_bool_t           enable;
    rt_bool_t           invert;
};

struct efm32_acmp_control_t
{
    ACMP_Init_TypeDef           *init;
    ACMP_Channel_TypeDef        posInput;
    ACMP_Channel_TypeDef        negInput;
    struct efm32_acmp_output_t  *output;
    efm32_irq_hook_t            hook;
};

/* Exported constants --------------------------------------------------------*/
/* Exported macro ------------------------------------------------------------*/
/* Exported functions ------------------------------------------------------- */
void rt_hw_acmp_init(void);

#endif /*__DRV_ACMP_H__ */