mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 447b0c7b93
			
		
	
	
		447b0c7b93
		
	
	
	
	
		
			
			This adds support for the mostly register-compatible SPICTRL cores from the GRLIB VHDL IP core library from Aeroflex Gaisler. They are normally running on SPARC. A different entry in of_fsl_spi_match matches this core and indicates a different hardware type that is used to set up different function pointers and special cases. The GRLIB core operates in cpu mode. The number of bits per word might be limited. There might be native chipselects selected via a slave select register. These differences to the FSL type cores, if present, are indicated by a capabilities register. Other register and function differences exists but are not relevant to the driver. Acked-by: Anton Vorontsov <anton@enomsg.org> Signed-off-by: Andreas Larsson <andreas@gaisler.com> Signed-off-by: Grant Likely <grant.likely@secretlab.ca>
		
			
				
	
	
		
			73 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Freescale SPI controller driver.
 | |
|  *
 | |
|  * Maintainer: Kumar Gala
 | |
|  *
 | |
|  * Copyright (C) 2006 Polycom, Inc.
 | |
|  * Copyright 2010 Freescale Semiconductor, Inc.
 | |
|  *
 | |
|  * CPM SPI and QE buffer descriptors mode support:
 | |
|  * Copyright (c) 2009  MontaVista Software, Inc.
 | |
|  * Author: Anton Vorontsov <avorontsov@ru.mvista.com>
 | |
|  *
 | |
|  * GRLIB support:
 | |
|  * Copyright (c) 2012 Aeroflex Gaisler AB.
 | |
|  * Author: Andreas Larsson <andreas@gaisler.com>
 | |
|  *
 | |
|  * 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.
 | |
|  */
 | |
| 
 | |
| #ifndef __SPI_FSL_SPI_H__
 | |
| #define __SPI_FSL_SPI_H__
 | |
| 
 | |
| /* SPI Controller registers */
 | |
| struct fsl_spi_reg {
 | |
| 	__be32 cap; /* TYPE_GRLIB specific */
 | |
| 	u8 res1[0x1C];
 | |
| 	__be32 mode;
 | |
| 	__be32 event;
 | |
| 	__be32 mask;
 | |
| 	__be32 command;
 | |
| 	__be32 transmit;
 | |
| 	__be32 receive;
 | |
| 	__be32 slvsel; /* TYPE_GRLIB specific */
 | |
| };
 | |
| 
 | |
| /* SPI Controller mode register definitions */
 | |
| #define	SPMODE_LOOP		(1 << 30)
 | |
| #define	SPMODE_CI_INACTIVEHIGH	(1 << 29)
 | |
| #define	SPMODE_CP_BEGIN_EDGECLK	(1 << 28)
 | |
| #define	SPMODE_DIV16		(1 << 27)
 | |
| #define	SPMODE_REV		(1 << 26)
 | |
| #define	SPMODE_MS		(1 << 25)
 | |
| #define	SPMODE_ENABLE		(1 << 24)
 | |
| #define	SPMODE_LEN(x)		((x) << 20)
 | |
| #define	SPMODE_PM(x)		((x) << 16)
 | |
| #define	SPMODE_OP		(1 << 14)
 | |
| #define	SPMODE_CG(x)		((x) << 7)
 | |
| 
 | |
| /* TYPE_GRLIB SPI Controller capability register definitions */
 | |
| #define SPCAP_SSEN(x)		(((x) >> 16) & 0x1)
 | |
| #define SPCAP_SSSZ(x)		(((x) >> 24) & 0xff)
 | |
| #define SPCAP_MAXWLEN(x)	(((x) >> 20) & 0xf)
 | |
| 
 | |
| /*
 | |
|  * Default for SPI Mode:
 | |
|  *	SPI MODE 0 (inactive low, phase middle, MSB, 8-bit length, slow clk
 | |
|  */
 | |
| #define	SPMODE_INIT_VAL (SPMODE_CI_INACTIVEHIGH | SPMODE_DIV16 | SPMODE_REV | \
 | |
| 			 SPMODE_MS | SPMODE_LEN(7) | SPMODE_PM(0xf))
 | |
| 
 | |
| /* SPIE register values */
 | |
| #define	SPIE_NE		0x00000200	/* Not empty */
 | |
| #define	SPIE_NF		0x00000100	/* Not full */
 | |
| 
 | |
| /* SPIM register values */
 | |
| #define	SPIM_NE		0x00000200	/* Not empty */
 | |
| #define	SPIM_NF		0x00000100	/* Not full */
 | |
| 
 | |
| #endif /* __SPI_FSL_SPI_H__ */
 |