MotorControlModuleSDFM_TMS3.../Projects/epwm_test/Freemaster/PE_freemaster_56F8xxx.c

307 lines
9.2 KiB
C

/******************************************************************************
* //Texas code composer variant
* Freescale Semiconductor Inc.
* (c) Copyright 2004-2007 Freescale Semiconductor, Inc.
* (c) Copyright 2001-2004 Motorola, Inc.
* ALL RIGHTS RESERVED.
*
****************************************************************************//*!
*
* @file PE_freemaster_56F8xxx.c
*
* @brief FreeMASTER Driver 56F800E-hardware dependent stuff
*
* @version 1.0.9.0
*
* @date May-17-2007
*
*******************************************************************************/
#include "PE_freemaster.h"
#include "PE_freemaster_private.h"
/*******************************************************************************
*
* @brief API: Main SCI/JTAG Interrupt handler call
*
* This Interrupt Service Routine handles the SCI interrupts for the FreeMASTER
* driver. In case you want to handle the interrupt in the application yourselves,
* call the FMSTR_ProcessSCI function which does the same job but is not compiled
* as an Interrupt Service Routine.
*
* In poll-driven mode (FMSTR_POLL_DRIVEN) this function does nothing.
*
*******************************************************************************/
/* 56F8xxx interrupt routine declaration, user has to */
/* direct vector to the FMSTR_Isr function */
void FMSTR_Isr(void)
{
#if FMSTR_LONG_INTR || FMSTR_SHORT_INTR
/* process serial interface */
#if FMSTR_USE_SCI
FMSTR_ProcessSCI();
#elif FMSTR_USE_JTAG
FMSTR_ProcessJTAG();
#endif
#endif
}
/* automatic inlining may cause problems with C calling convention assumed below */
/**************************************************************************//*!
*
* @brief The "memcpy" used internally in FreeMASTER driver
*
* @param nDestAddr - destination memory address
* @param nSrcAddr - source memory address
* @param nSize - memory size (always in bytes)
*
* @return This function returns a pointer to next destination byte
*
******************************************************************************
*
* This function accepts both 16bit or 32bit address and works correctly
* even in the SDM mode. Buffer address is a standard ANSI C pointer
*
* Warning: This call assumes CodeWarrior style of passing parameters,
* i.e. 32 bit operands passed in A and B accumulators
*
* Warning2: FMSTR_ADDR type MUST be numeric! (UWord type)
*
******************************************************************************/
void FMSTR_CopyMemory(FMSTR_ADDR nDestAddr, FMSTR_ADDR nSrcAddr, FMSTR_SIZE8 nSize)
{
FMSTR_U8* ps = (FMSTR_U8*) nSrcAddr;
FMSTR_U8* pd = (FMSTR_U8*) nDestAddr;
// nSize = nSize>>1;
while(nSize--)
*pd++ = *ps++;
}
/**************************************************************************//*!
*
* @brief Write-into the communication buffer memory
*
* @param pDestBuff - pointer to destination memory in communication buffer
* @param nSrcAddr - source memory address
* @param nSize - buffer size (always in bytes)
*
* @return This function returns a pointer to next byte in comm. buffer
*
******************************************************************************
*
* This function accepts both 16bit or 32bit address and works correctly
* even in the SDM mode. Buffer address is a standard ANSI C pointer
*
* Warning: This call assumes CodeWarrior style of passing parameters,
* i.e. 32 bit operands passed in A and B accumulators
*
* Warning2: FMSTR_ADDR type MUST be numeric! (UWord type)
*
******************************************************************************/
FMSTR_BPTR FMSTR_CopyToBuffer(FMSTR_BPTR pDestBuff, FMSTR_ADDR nSrcAddr, FMSTR_SIZE8 nSize)
{
FMSTR_U8* ps = (FMSTR_U8*) nSrcAddr;
FMSTR_U8* pd = (FMSTR_U8*) pDestBuff;
nSize = nSize>>1;
//Texas code composer variant
while(nSize--)
{
*pd++ = *ps;
*pd++ = (*ps++) >> 8; //*pd++ = *ps++;
}
return (FMSTR_BPTR) pd;
}
/**************************************************************************//*!
*
* @brief Read-out memory from communication buffer
*
* @param nDestAddr - destination memory address
* @param pSrcBuff - pointer to source memory in communication buffer
* @param nSize - buffer size (always in bytes)
*
* @return This function returns a pointer to next byte in comm. buffer
*
******************************************************************************
*
* This function accepts both 16bit or 32bit address and works correctly
* even in the SDM mode. Buffer address is a standard ANSI C pointer
*
* Warning: This call assumes CodeWarrior style of passing parameters,
* i.e. 32 bit operands passed in A and B accumulators
*
* Warning2: FMSTR_ADDR type MUST be numeric! (UWord type)
*
******************************************************************************/
FMSTR_BPTR FMSTR_CopyFromBuffer(FMSTR_ADDR nDestAddr, FMSTR_BPTR pSrcBuff, FMSTR_SIZE8 nSize)
{
FMSTR_U8* ps = (FMSTR_U8*) pSrcBuff;
FMSTR_U8* pd = (FMSTR_U8*) nDestAddr;
//Texas code composer variant
nSize = nSize>>1;
while(nSize--)
{
*pd = *ps++;
*pd++ += (*ps++)<<8; // *pd++ = *ps++;
}
return (FMSTR_BPTR) ps;
}
/**************************************************************************//*!
*
* @brief Read-out memory from communication buffer, perform AND-masking
*
* @param nDestAddr - destination memory address
* @param pSrcBuff - source memory in communication buffer, mask follows data
* @param nSize - buffer size (always in bytes)
*
******************************************************************************
*
* This function accepts both 16bit or 32bit address and works correctly
* even in the SDM mode. Buffer address is a standard ANSI C pointer
*
* Warning: This call assumes CodeWarrior style of passing parameters,
* i.e. 32 bit operands passed in A and B accumulators
*
* Warning2: FMSTR_ADDR type MUST be numeric! (UWord type)
*
******************************************************************************/
void FMSTR_CopyFromBufferWithMask(FMSTR_ADDR nDestAddr, FMSTR_BPTR pSrcBuff, FMSTR_SIZE8 nSize)
{
FMSTR_U8* ps = (FMSTR_U8*) pSrcBuff;
FMSTR_U8* pd = (FMSTR_U8*) nDestAddr;
FMSTR_U8* pm = ps + nSize;
FMSTR_U8 mask, stmp, dtmp;
while(nSize--)
{
mask = *pm++;
stmp = *ps++;
dtmp = *pd;
/* perform AND-masking */
stmp = (FMSTR_U8) ((stmp & mask) | (dtmp & ~mask));
/* put the result back */
*pd++ = stmp;
}
}
/**************************************************************************//*!
*
* @brief Select an address size to be used in next access to a comm. buffer
*
* @param bNextAddrIsEx - when non zero, next expected address is 32bit wide
* - when zero, next expected address is 16bit wide
*
******************************************************************************/
#if FMSTR_USE_EX_CMDS && FMSTR_USE_NOEX_CMDS
static FMSTR_BOOL pcm_bUseExAddr;
void FMSTR_SetExAddr(FMSTR_BOOL bNextAddrIsEx)
{
pcm_bUseExAddr = bNextAddrIsEx;
}
#endif
/**************************************************************************//*!
*
* @brief Fetch 16/32 bit address from buffer
*
* @param pAddr - ANSI C pointer to a variable which is to receive the result
* @param pSrc - pointer to a source memory in communication buffer
*
* @return This function returns a pointer to next byte in comm. buffer
*
******************************************************************************/
FMSTR_BPTR FMSTR_AddressFromBuffer(FMSTR_ADDR* pAddr, FMSTR_BPTR pSrc)
{
/* do we have to differentiate the EX and non-EX access? */
#if FMSTR_USE_EX_CMDS && FMSTR_USE_NOEX_CMDS
if(pcm_bUseExAddr)
#endif
{
#if FMSTR_USE_EX_CMDS
/* fetch 32bit value */
FMSTR_U32 nAddr32;
pSrc = FMSTR_ValueFromBuffer32(&nAddr32, pSrc);
/* and convert it to the address type */
*pAddr = (FMSTR_ADDR) nAddr32;
#endif
}
#if FMSTR_USE_EX_CMDS && FMSTR_USE_NOEX_CMDS
else
#endif
{
#if FMSTR_USE_NOEX_CMDS
/* fetch 16bit value */
FMSTR_U16 nAddr16;
pSrc = FMSTR_ValueFromBuffer16(&nAddr16, pSrc);
/* and convert it to the address type */
*pAddr = (FMSTR_ADDR) nAddr16; //+ ((FMSTR_ADDR) *(&nAddr16+1))<<8;
#endif
}
return pSrc;
}
/**************************************************************************//*!
*
* @brief Store 16/32 bit address to buffer
*
* @param pDest - pointer to a destination memory in communication buffer
* @param pSrc - memory address value
*
* @return This function returns a pointer to next byte in comm. buffer
*
******************************************************************************/
FMSTR_BPTR FMSTR_AddressToBuffer(FMSTR_BPTR pDest, FMSTR_ADDR nAddr)
{
/* do we have to differentiate the EX and non-EX access? */
#if FMSTR_USE_EX_CMDS && FMSTR_USE_NOEX_CMDS
if(pcm_bUseExAddr)
#endif
{
#if FMSTR_USE_EX_CMDS
/* put the address as a 32bit value */
pDest = FMSTR_ValueToBuffer32(pDest, (FMSTR_U32) nAddr);
#endif
}
#if FMSTR_USE_EX_CMDS && FMSTR_USE_NOEX_CMDS
else
#endif
{
#if FMSTR_USE_NOEX_CMDS
/* put the address as a 16bit value */
pDest = FMSTR_ValueToBuffer16(pDest, (FMSTR_U16) nAddr);
#endif
}
return pDest;
}