mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-24 22:11:26 +02:00 
			
		
		
		
	This helps to clean up the include/ directory so that it only contains non-architecture-specific headers and also matches Linux's directory layout which many U-Boot developers are already familiar with. Signed-off-by: Peter Tyser <ptyser@xes-inc.com>
		
			
				
	
	
		
			83 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
		
			2.0 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 */
 |