2013-08-07 12:20:53 +02:00
|
|
|
/*
|
|
|
|
* ssp0-borad.h - header file of the SPI interface for the LPC2387.
|
2013-09-19 16:53:35 +02:00
|
|
|
* Copyright (C) 2013 Freie Universität Berlin
|
2013-08-19 16:17:58 +02:00
|
|
|
*
|
2014-08-23 15:43:13 +02:00
|
|
|
* 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.
|
2013-08-07 12:20:53 +02:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
* @internal
|
2013-08-19 16:17:58 +02:00
|
|
|
* @brief SPI interface definitions for the LPC2387
|
2013-08-07 12:20:53 +02:00
|
|
|
*
|
2013-08-19 16:17:58 +02:00
|
|
|
* @author Marco Ziegert <ziegert@inf.fu-berlin.de>
|
|
|
|
* @author Zakaria Kasmi <zkasmi@inf.fu-berlin.de>
|
2013-08-07 12:20:53 +02:00
|
|
|
* @version $Revision: 3854 $
|
|
|
|
*
|
2013-08-19 16:17:58 +02:00
|
|
|
* @note $Id: avsextrem-ssp0.c 3854 2010-01-18 15:27:01Z zkasmi $
|
2013-08-07 12:20:53 +02:00
|
|
|
*/
|
2015-04-23 05:00:54 +02:00
|
|
|
#ifndef SSP_H__
|
|
|
|
#define SSP_H__
|
2013-08-07 12:20:53 +02:00
|
|
|
|
|
|
|
#include "stdint.h"
|
|
|
|
|
2014-10-13 15:25:50 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2014-07-31 20:34:28 +02:00
|
|
|
#define DMA_ENABLED 0
|
2013-08-07 12:20:53 +02:00
|
|
|
|
2013-09-19 16:53:35 +02:00
|
|
|
/*
|
|
|
|
* if USE_CS is zero, set SSEL as GPIO that you have total control of the
|
|
|
|
* sequence
|
|
|
|
**/
|
2014-07-31 20:34:28 +02:00
|
|
|
#define USE_CS 0
|
2013-08-07 12:20:53 +02:00
|
|
|
|
2013-09-19 16:53:35 +02:00
|
|
|
/*
|
|
|
|
* if 1, use driver for onboard BMA180, otherwise for external BMA180 utilizing
|
|
|
|
* Nanopan Connector
|
|
|
|
**/
|
2014-07-31 20:34:28 +02:00
|
|
|
#define BMA180_ONBOARD 1
|
2013-08-07 12:20:53 +02:00
|
|
|
|
2014-07-31 20:34:28 +02:00
|
|
|
#define SMB380_ACC 0
|
|
|
|
#define NANOPAN 1
|
|
|
|
#define NORDIC 2
|
|
|
|
#define BMA180_EXTERN 3
|
|
|
|
#define BMA180_INTERN 4
|
|
|
|
#define L3G_EXTERN 5
|
|
|
|
#define L3G_INTERN 6
|
|
|
|
#define ACAMDMS 7
|
2013-08-07 12:20:53 +02:00
|
|
|
|
|
|
|
/* SPI read and write buffer size */
|
2014-07-31 20:34:28 +02:00
|
|
|
#define BUFSIZE 256
|
|
|
|
#define FIFOSIZE 8
|
2013-08-07 12:20:53 +02:00
|
|
|
|
|
|
|
/* SSP select pin */
|
2015-05-26 19:42:44 +02:00
|
|
|
#define SSP0_SEL 1 << 21 /* P1.21 SMB380 */
|
2013-08-07 12:20:53 +02:00
|
|
|
|
2015-05-26 19:42:44 +02:00
|
|
|
#define SSP0_SELN 1 << 16 /* P0.16 Nanotron */
|
2013-08-07 12:20:53 +02:00
|
|
|
|
|
|
|
/* SSP1 external interrupt Pin (SMB380 specific) */
|
2015-05-26 19:42:44 +02:00
|
|
|
#define SMB380_INT1 1 << 1 /* P0.1 */
|
|
|
|
#define BMA180_INT1 1 << 8 /* P2.8 */
|
2013-08-07 12:20:53 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* SSP1 CR0 register */
|
2014-07-31 20:34:28 +02:00
|
|
|
#define SSPCR0_DSS 1 << 0
|
|
|
|
#define SSPCR0_FRF 1 << 4
|
|
|
|
#define SSPCR0_SPO 1 << 6
|
|
|
|
#define SSPCR0_SPH 1 << 7
|
|
|
|
#define SSPCR0_SCR 1 << 8
|
2013-08-07 12:20:53 +02:00
|
|
|
|
|
|
|
/* SSP1 CR1 register */
|
2014-07-31 20:34:28 +02:00
|
|
|
#define SSPCR1_LBM 1 << 0
|
|
|
|
#define SSPCR1_SSE 1 << 1
|
|
|
|
#define SSPCR1_MS 1 << 2
|
|
|
|
#define SSPCR1_SOD 1 << 3
|
2013-08-07 12:20:53 +02:00
|
|
|
|
|
|
|
/* SSP1 Interrupt Mask Set/Clear register */
|
2014-07-31 20:34:28 +02:00
|
|
|
#define SSPIMSC_RORIM 1 << 0
|
|
|
|
#define SSPIMSC_RTIM 1 << 1
|
|
|
|
#define SSPIMSC_RXIM 1 << 2
|
|
|
|
#define SSPIMSC_TXIM 1 << 3
|
2013-08-07 12:20:53 +02:00
|
|
|
|
|
|
|
/* SSP1 Interrupt Status register */
|
2014-07-31 20:34:28 +02:00
|
|
|
#define SSPRIS_RORRIS 1 << 0
|
|
|
|
#define SSPRIS_RTRIS 1 << 1
|
|
|
|
#define SSPRIS_RXRIS 1 << 2
|
|
|
|
#define SSPRIS_TXRIS 1 << 3
|
2013-08-07 12:20:53 +02:00
|
|
|
|
|
|
|
/* SSP1 Masked Interrupt register */
|
2014-07-31 20:34:28 +02:00
|
|
|
#define SSPMIS_RORMIS 1 << 0
|
|
|
|
#define SSPMIS_RTMIS 1 << 1
|
|
|
|
#define SSPMIS_RXMIS 1 << 2
|
|
|
|
#define SSPMIS_TXMIS 1 << 3
|
2013-08-07 12:20:53 +02:00
|
|
|
|
|
|
|
/* SSP1 Interrupt clear register */
|
2014-07-31 20:34:28 +02:00
|
|
|
#define SSPICR_RORIC 1 << 0
|
|
|
|
#define SSPICR_RTIC 1 << 1
|
2013-08-07 12:20:53 +02:00
|
|
|
|
2014-07-31 20:34:28 +02:00
|
|
|
#define SSP1_INTERRUPT_MODE 0
|
|
|
|
#define SMB380_EXTINT_MODE 1
|
|
|
|
#define BMA180_EXTINT_MODE 1
|
2013-08-07 12:20:53 +02:00
|
|
|
|
2013-08-19 16:17:58 +02:00
|
|
|
uint32_t SSP0Init(void);
|
2013-09-19 16:53:35 +02:00
|
|
|
uint8_t SSP0Prepare(uint8_t chip, uint8_t datasize, uint8_t cpol, uint8_t cpha,
|
|
|
|
uint16_t freq);
|
2013-08-07 12:20:53 +02:00
|
|
|
uint8_t SSP0Unprepare(uint8_t chip);
|
|
|
|
unsigned char SSP0_write(const uint16_t data, uint8_t device);
|
|
|
|
unsigned short SSP0_read(uint8_t device);
|
2013-09-19 16:53:35 +02:00
|
|
|
unsigned char SMB380_ssp_write(const unsigned char regAddr,
|
|
|
|
const unsigned char data, unsigned char flag);
|
2013-08-07 12:20:53 +02:00
|
|
|
unsigned short SMB380_ssp_read(void);
|
|
|
|
unsigned short nrf24l01_ssp_read_write(const uint8_t data);
|
|
|
|
unsigned short acam_trx(const uint8_t data);
|
|
|
|
void SSP0Handler(void);
|
|
|
|
|
2014-10-13 15:25:50 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2015-04-23 05:00:54 +02:00
|
|
|
#endif /* SSP_H__ */
|