/**
 * \file   mcasp.c
 *
 * \brief  This file contains functions which configure McASP pins
 */

/*
* Copyright (C) 2010 Texas Instruments Incorporated - http://www.ti.com/
*/
/*
*  Redistribution and use in source and binary forms, with or without
*  modification, are permitted provided that the following conditions
*  are met:
*
*    Redistributions of source code must retain the above copyright
*    notice, this list of conditions and the following disclaimer.
*
*    Redistributions in binary form must reproduce the above copyright
*    notice, this list of conditions and the following disclaimer in the
*    documentation and/or other materials provided with the
*    distribution.
*
*    Neither the name of Texas Instruments Incorporated nor the names of
*    its contributors may be used to endorse or promote products derived
*    from this software without specific prior written permission.
*
*  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
*  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
*  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
*  A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
*  OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
*  SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
*  LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
*  DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
*  THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
*  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
*  OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
*/

#include "soc_AM335x.h"
#include "hw_control_AM335x.h"
#include "hw_types.h"
#include "evmskAM335x.h"
#include "hw_cm_per.h"

#define MCASP_SEL_MODE            0x04
#define MCASP_0_SEL_MODE          0x00
#define CLKOUT1_SEL_MODE          0x03

/**
 * \brief   This function selects the McASP instance 1 pins
 *          
 * \param   None
 *
 * \return  TRUE/FALSE.
 *
 * \note    This muxing depends on the profile in which the EVM is configured.
 */
void McASP1PinMuxSetup(void)
{
    HWREG(SOC_CONTROL_REGS + CONTROL_CONF_MII1_COL) = 
                  CONTROL_CONF_MII1_RXERR_CONF_MII1_RXERR_RXACTIVE 
                  | MCASP_SEL_MODE;            
    HWREG(SOC_CONTROL_REGS + CONTROL_CONF_MII1_CRS) = 
                  CONTROL_CONF_MII1_RXERR_CONF_MII1_RXERR_RXACTIVE
                  | MCASP_SEL_MODE;            
    HWREG(SOC_CONTROL_REGS + CONTROL_CONF_MII1_RXERR) =
                  CONTROL_CONF_MII1_RXERR_CONF_MII1_RXERR_RXACTIVE
                  | MCASP_SEL_MODE;            
    HWREG(SOC_CONTROL_REGS + CONTROL_CONF_RMII1_REFCLK) = 
                  CONTROL_CONF_RMII1_REFCLK_CONF_RMII1_REFCLK_RXACTIVE 
                  | MCASP_SEL_MODE;   
    HWREG(SOC_CONTROL_REGS + CONTROL_CONF_XDMA_EVENT_INTR(0)) = 
                  CLKOUT1_SEL_MODE;
}


////////////////////////////////ADDED BY GAURAV/////////////////////////////////////////
/**
 * \brief   This function selects the McASP instance 0 pins
 *          
 * \param   None
 *
 * \return  TRUE/FALSE.
 *
 * \note    This muxing depends on the profile in which the EVM is configured.
 */
void McASP0PinMuxSetup(void)
{

            HWREG(SOC_CONTROL_REGS + CONTROL_CONF_MCASP0_AXR1) = 
                          CONTROL_CONF_MCASP0_AXR1_CONF_MCASP0_AXR1_RXACTIVE 
                          | MCASP_0_SEL_MODE;            
            HWREG(SOC_CONTROL_REGS + CONTROL_CONF_MCASP0_ACLKX) = 
                          CONTROL_CONF_MCASP0_ACLKX_CONF_MCASP0_ACLKX_RXACTIVE
                          | MCASP_0_SEL_MODE;            
            HWREG(SOC_CONTROL_REGS + CONTROL_CONF_MCASP0_FSX) =
                          CONTROL_CONF_MCASP0_FSX_CONF_MCASP0_FSX_RXACTIVE
                          | MCASP_0_SEL_MODE;            
            HWREG(SOC_CONTROL_REGS + CONTROL_CONF_MCASP0_AXR0) = 
                          CONTROL_CONF_MCASP0_AXR0_CONF_MCASP0_AXR0_RXACTIVE 
                          | MCASP_0_SEL_MODE;    
            HWREG(SOC_CONTROL_REGS + CONTROL_CONF_MCASP0_AHCLKX) = 
                          CONTROL_CONF_MCASP0_AHCLKX_CONF_MCASP0_AHCLKX_RXACTIVE 
                          | MCASP_0_SEL_MODE;    
}

/**
 * \brief   This function enables McASP 1 clocks
 *          
 * \param   None
 *
 * \return  None.
 *
 */
void McASP1ModuleClkConfig(void)
{
    HWREG(SOC_PRCM_REGS + CM_PER_MCASP1_CLKCTRL) =
                             CM_PER_MCASP1_CLKCTRL_MODULEMODE_ENABLE;

    while((HWREG(SOC_PRCM_REGS + CM_PER_MCASP1_CLKCTRL) &
      CM_PER_MCASP1_CLKCTRL_MODULEMODE) != CM_PER_MCASP1_CLKCTRL_MODULEMODE_ENABLE);


    /*
    ** Waiting for IDLEST field in CM_PER_MCASP1_CLKCTRL register to attain the
    ** desired value.
    */
    while((CM_PER_MCASP1_CLKCTRL_IDLEST_FUNC <<
           CM_PER_MCASP1_CLKCTRL_IDLEST_SHIFT)!=
          (HWREG(SOC_CM_PER_REGS + CM_PER_MCASP1_CLKCTRL) &
           CM_PER_MCASP1_CLKCTRL_IDLEST));

}


/**
 * \brief   This function enables McASP 0 clocks
 *          
 * \param   None
 *
 * \return  None.
 *
 */
void McASP0ModuleClkConfig(void)
{
    HWREG(SOC_PRCM_REGS + CM_PER_MCASP0_CLKCTRL) =
                             CM_PER_MCASP0_CLKCTRL_MODULEMODE_ENABLE;

    while((HWREG(SOC_PRCM_REGS + CM_PER_MCASP0_CLKCTRL) &
      CM_PER_MCASP0_CLKCTRL_MODULEMODE) != CM_PER_MCASP0_CLKCTRL_MODULEMODE_ENABLE);


    /*
    ** Waiting for IDLEST field in CM_PER_MCASP1_CLKCTRL register to attain the
    ** desired value.
    */
    while((CM_PER_MCASP0_CLKCTRL_IDLEST_FUNC <<
           CM_PER_MCASP0_CLKCTRL_IDLEST_SHIFT)!=
          (HWREG(SOC_CM_PER_REGS + CM_PER_MCASP0_CLKCTRL) &
           CM_PER_MCASP0_CLKCTRL_IDLEST));

}

/****************************** End Of File *********************************/
