mirror of
https://github.com/AsahiLinux/u-boot
synced 2025-01-25 19:35:17 +00:00
83 lines
2 KiB
C
83 lines
2 KiB
C
|
/*
|
||
|
This file defines the interface to the lpc22xx SPI module.
|
||
|
Copyright (C) 2006 Embedded Artists AB (www.embeddedartists.com)
|
||
|
|
||
|
This file may be included in software not adhering to the GPL.
|
||
|
|
||
|
This program is free software; you can redistribute it and/or modify
|
||
|
it under the terms of the GNU General Public License as published by
|
||
|
the Free Software Foundation; either version 2 of the License, or
|
||
|
(at your option) any later version.
|
||
|
|
||
|
This program is distributed in the hope that it will be useful,
|
||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
GNU General Public License for more details.
|
||
|
|
||
|
You should have received a copy of the GNU General Public License
|
||
|
along with this program; if not, write to the Free Software
|
||
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||
|
*/
|
||
|
|
||
|
#ifndef SPI_H
|
||
|
#define SPI_H
|
||
|
|
||
|
#include <config.h>
|
||
|
#include <common.h>
|
||
|
#include <asm/errno.h>
|
||
|
#include <asm/arch/hardware.h>
|
||
|
|
||
|
#define SPIF 0x80
|
||
|
|
||
|
#define spi_lock() disable_interrupts();
|
||
|
#define spi_unlock() enable_interrupts();
|
||
|
|
||
|
extern unsigned long spi_flags;
|
||
|
extern unsigned char spi_idle;
|
||
|
|
||
|
int spi_init(void);
|
||
|
|
||
|
static inline unsigned char spi_read(void)
|
||
|
{
|
||
|
unsigned char b;
|
||
|
|
||
|
PUT8(S0SPDR, spi_idle);
|
||
|
while (!(GET8(S0SPSR) & SPIF));
|
||
|
b = GET8(S0SPDR);
|
||
|
|
||
|
return b;
|
||
|
}
|
||
|
|
||
|
static inline void spi_write(unsigned char b)
|
||
|
{
|
||
|
PUT8(S0SPDR, b);
|
||
|
while (!(GET8(S0SPSR) & SPIF));
|
||
|
GET8(S0SPDR); /* this will clear the SPIF bit */
|
||
|
}
|
||
|
|
||
|
static inline void spi_set_clock(unsigned char clk_value)
|
||
|
{
|
||
|
PUT8(S0SPCCR, clk_value);
|
||
|
}
|
||
|
|
||
|
static inline void spi_set_cfg(unsigned char phase,
|
||
|
unsigned char polarity,
|
||
|
unsigned char lsbf)
|
||
|
{
|
||
|
unsigned char v = 0x20; /* master bit set */
|
||
|
|
||
|
if (phase)
|
||
|
v |= 0x08; /* set phase bit */
|
||
|
if (polarity) {
|
||
|
v |= 0x10; /* set polarity bit */
|
||
|
spi_idle = 0xFF;
|
||
|
} else {
|
||
|
spi_idle = 0x00;
|
||
|
}
|
||
|
if (lsbf)
|
||
|
v |= 0x40; /* set lsbf bit */
|
||
|
|
||
|
PUT8(S0SPCR, v);
|
||
|
}
|
||
|
#endif /* SPI_H */
|