halpxa27xsspcontrolp.nc

来自「tinyos-2.x.rar」· NC 代码 · 共 180 行

NC
180
字号
/*
 * Copyright (c) 2005 Arch Rock Corporation 
 * All rights reserved. 
 * 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 the Arch Rock Corporation 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 ARCHED
 * ROCK OR ITS 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.
 */
/**
 *
 * @author Kaisen Lin
 * @author Phil Buonadonna
 */

#include "SSP.h"

module HalPXA27xSSPControlP {
  provides interface HalPXA27xSSPCntl;

  uses interface HplPXA27xSSP as SSP;
}

implementation {

  command error_t HalPXA27xSSPCntl.setMasterSCLK(bool enable) {
    uint32_t valSSCR1;
    valSSCR1 = call SSP.getSSCR1() & ~SSCR1_SCLKDIR;

    if(!enable)
      valSSCR1 |= SSCR1_SCLKDIR;
    
    call SSP.setSSCR1(valSSCR1);
    return SUCCESS;
  }

  command error_t HalPXA27xSSPCntl.setMasterSFRM(bool enable) {
    uint32_t valSSCR1;
    valSSCR1 = call SSP.getSSCR1() & ~SSCR1_SFRMDIR;

    if(!enable)
      valSSCR1 |= SSCR1_SFRMDIR;
    
    call SSP.setSSCR1(valSSCR1);
    return SUCCESS;
  }

  command error_t HalPXA27xSSPCntl.setReceiveWithoutTransmit(bool enable) {
    uint32_t valSSCR1;
    valSSCR1 = call SSP.getSSCR1() & ~SSCR1_RWOT;

    if(enable)
      valSSCR1 |= SSCR1_RWOT;
    
    call SSP.setSSCR1(valSSCR1);
    return SUCCESS;
  }

  command error_t HalPXA27xSSPCntl.setSSPFormat(SSPFrameFormat_t format) {
    uint32_t valSSCR0;
    valSSCR0 = call SSP.getSSCR0() & ~SSCR0_FRF(3);

    call SSP.setSSCR0(valSSCR0 | SSCR0_FRF(format));
    return SUCCESS;
  }

  command error_t HalPXA27xSSPCntl.setDataWidth(SSPDataWidth_t width) {
    uint8_t bitEDSS;
    uint32_t valSSCR0;
    
    if(width < 4)
      return EINVAL;

    // width + 1 = bits to use, don't forget to adjust!
    width -= 1;
    bitEDSS = width & 0x10; // keep bit 4
    width = width & 0xF; // keep bits 0-3
    
    valSSCR0 = call SSP.getSSCR0() & ~SSCR0_DSS(0xF) & ~SSCR0_EDSS;
    if(bitEDSS)
      valSSCR0 |= SSCR0_EDSS;
    valSSCR0 |= SSCR0_DSS(width);
   
    call SSP.setSSCR0(valSSCR0);
    return SUCCESS;
  }

  command error_t HalPXA27xSSPCntl.enableInvertedSFRM(bool enable) {
    uint32_t valSSCR1;
    valSSCR1 = call SSP.getSSCR1() & ~SSCR1_IFS;

    if(!enable)
      valSSCR1 |= SSCR1_IFS;
    
    call SSP.setSSCR1(valSSCR1);
    return SUCCESS;
  }

  command error_t HalPXA27xSSPCntl.setRxFifoLevel(SSPFifoLevel_t level) {
    uint32_t valSSCR1;
    valSSCR1 = call SSP.getSSCR1() & ~SSCR1_RFT(0xF);

    call SSP.setSSCR1(valSSCR1 | SSCR1_RFT(level));
    return SUCCESS;
  }

  command error_t HalPXA27xSSPCntl.setTxFifoLevel(SSPFifoLevel_t level) {
    uint32_t valSSCR1;
    valSSCR1 = call SSP.getSSCR1() & ~SSCR1_TFT(0xF);

    call SSP.setSSCR1(valSSCR1 | SSCR1_TFT(level));
    return SUCCESS;
  }

  command error_t HalPXA27xSSPCntl.setMicrowireTxSize(SSPMicrowireTxSize_t size) {
    uint32_t valSSCR1;
    valSSCR1 = call SSP.getSSCR1();

    if(size == UWIRE_16BIT)
      valSSCR1 |= SSCR1_MWDS;
    else if(size == UWIRE_8BIT)
      valSSCR1 &= ~ SSCR1_MWDS;
    else
      return FAIL;

    call SSP.setSSCR1(valSSCR1);
    return SUCCESS;
  }

  command error_t HalPXA27xSSPCntl.setClkRate(uint16_t clkdivider) {
    uint32_t valSSCR0;

    clkdivider -= 1; // check PXA Dev Manual for why to do this

    valSSCR0 = call SSP.getSSCR0() & ~SSCR0_SCR(0xFFF);
    valSSCR0 |= SSCR0_SCR(clkdivider);
    call SSP.setSSCR0(valSSCR0);
    return SUCCESS;
  }

  command error_t HalPXA27xSSPCntl.setClkMode(SSPClkMode_t mode) {
    uint32_t valSSCR0;
    valSSCR0 = call SSP.getSSCR0();

    if(mode == SSP_NETWORKMODE)
      valSSCR0 |= SSCR0_NCS;
    else if(mode == SSP_NORMALMODE)
      valSSCR0 &= ~SSCR0_NCS;
    else
      return FAIL;

    call SSP.setSSCR0(valSSCR0);
    return SUCCESS;
  }

  async event void SSP.interruptSSP() {
    // intentionally left blank, not supposed to handle interrupts
  }
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?