/*
 * Copyright (C) 2015 HAW Hamburg
 *
 * This file is subject to the terms and conditions of the GNU Lesser
 * General Public License v2.1. See the file LICENSE in the top level
 * directory for more details.
 */

/**
 * @ingroup     drivers_lis3mdl
 *
 * @{
 *
 * @file
 * @brief       Definitions for the LIS3MDL 3-axis magnetometer
 *
 * @author      René Herthel <rene-herthel@outlook.de>
 */

#ifndef LIS3MDL_INTERNAL_H
#define LIS3MDL_INTERNAL_H

#ifdef __cplusplus
extern "C" {
#endif

/**
 * @name    LIS3DML chip identification
 * @{
 */
#define LIS3MDL_CHIP_ID                   (0x3D)
#define LIS3MDL_CHIP_ADDR                 (0x1C)
/** @} */

/**
 * @name    LIS3DML device identification register
 * @{
 */
#define LIS3DML_WHO_AM_I_REG              (0x0F)
/**  @} */

/**
 * @name    LIS3DML control register
 * @{
 */
#define LIS3MDL_CTRL_REG1                 (0x20)
#define LIS3MDL_CTRL_REG2                 (0x21)
#define LIS3MDL_CTRL_REG3                 (0x22)
#define LIS3MDL_CTRL_REG4                 (0x23)
#define LIS3MDL_CTRL_REG5                 (0x24)
/**  @} */

/**
 * @name    LIS3DML masks for CTRL_REG1
 * @{
 */
#define LIS3MDL_MASK_REG1_TEMP_EN         (0x80)
/**  @} */

/**
 * @name    LIS3DML masks for CTRL_REG2
 * @{
 */
#define LIS3MDL_MASK_REG2_REBOOT          (0x06)
#define LIS3MDL_MASK_REG2_SOFT_RST        (0x04)
/**  @} */

/**
 * @name    LIS3DML masks for CTRL_REG3
 * @{
 */
#define LIS3MDL_MASK_REG3_LOW_POWER_EN    (0x02)
#define LIS3MDL_MASK_REG3_CONT_CONV_MODE  (0x00)
#define LIS3MDL_MASK_REG3_Z_LOW_POWER     (0x00)
#define LIS3MDL_MASK_REG3_Z_MEDIUM_POWER  (0x04)
/**  @} */

/**
 * @name    LIS3DML masks for CTRL_REG5
 * @{
 */
#define LIS3MDL_MASK_REG5_BDU             (0x40)
#define LIS3MDL_MASK_REG5_BDU_OFF         (0x00)
/**  @} */

/**
 * @name    LIS3DML status register
 * @{
 */
#define LIS3MDL_STATUS_REG                (0x27)
/**  @} */

/**
 * @name    LIS3DML magnometer output register
 * @{
 */
#define LIS3MDL_OUT_X_L_REG               (0x28)
#define LIS3MDL_OUT_X_H_REG               (0x29)
#define LIS3MDL_OUT_Y_L_REG               (0x2A)
#define LIS3MDL_OUT_Y_H_REG               (0x2B)
#define LIS3MDL_OUT_Z_L_REG               (0x2C)
#define LIS3MDL_OUT_Z_H_REG               (0x2D)
/**  @} */

/**
 * @name    LIS3DML temperature output register
 * @{
 */
#define LIS3MDL_TEMP_OUT_L_REG            (0x2E)
#define LIS3MDL_TEMP_OUT_H_REG            (0x2F)
/**  @} */

/**
 * @name    LIS3DML interrupt register
 * @{
 */
#define LIS3MDL_INT_CFG_REG               (0x30)
#define LIS3MDL_INT_SRC_REG               (0x31)
#define LIS3MDL_INT_THS_L_REG             (0x32)
#define LIS3MDL_INT_THS_H_REG             (0x33)
/**  @} */

/**
 * @name    LIS3MDL masks for interrupt cfg register
 * @{
 */
#define LIS3MDL_MASK_INT_CFG_XIEN         (0x80)
#define LIS3MDL_MASK_INT_CFG_YIEN         (0x40)
#define LIS3MDL_MASK_INT_CFG_ZIEN         (0x20)
#define LIS3MDL_MASK_INT_CFG_IEA          (0x04)
#define LIS3MDL_MASK_INT_CFG_LIR          (0x02)
#define LIS3MDL_MASK_INT_CFG_IEN          (0x01)
/** }@ */

/**
 * @name    LIS3MDL masks for interrupt src register
 * @{
 */
#define LIS3MDL_MASK_INT_SRC_PTH_X        (0x80)
#define LIS3MDL_MASK_INT_SRC_PTH_Y        (0x40)
#define LIS3MDL_MASK_INT_SRC_PTH_Z        (0x20)
#define LIS3MDL_MASK_INT_SRC_NTH_X        (0x10)
#define LIS3MDL_MASK_INT_SRC_NTH_Y        (0x08)
#define LIS3MDL_MASK_INT_SRC_NTH_Z        (0x04)
#define LIS3MDL_MASK_INT_SRC_MROI         (0x02)
#define LIS3MDL_MASK_INT_SRC_INT          (0x01)

#ifdef __cplusplus
}
#endif

#endif /* LIS3MDL_INTERNAL_H */
/** @} */