64 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			64 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| 
								 | 
							
								// spin.c
							 | 
						||
| 
								 | 
							
								//
							 | 
						||
| 
								 | 
							
								// Example program for bcm2835 library
							 | 
						||
| 
								 | 
							
								// Shows how to interface with SPI to transfer a number of bytes to and from an SPI device
							 | 
						||
| 
								 | 
							
								//
							 | 
						||
| 
								 | 
							
								// After installing bcm2835, you can build this 
							 | 
						||
| 
								 | 
							
								// with something like:
							 | 
						||
| 
								 | 
							
								// gcc -o spin spin.c -l bcm2835
							 | 
						||
| 
								 | 
							
								// sudo ./spin
							 | 
						||
| 
								 | 
							
								//
							 | 
						||
| 
								 | 
							
								// Or you can test it before installing with:
							 | 
						||
| 
								 | 
							
								// gcc -o spin -I ../../src ../../src/bcm2835.c spin.c
							 | 
						||
| 
								 | 
							
								// sudo ./spin
							 | 
						||
| 
								 | 
							
								//
							 | 
						||
| 
								 | 
							
								// Author: Mike McCauley
							 | 
						||
| 
								 | 
							
								// Copyright (C) 2012 Mike McCauley
							 | 
						||
| 
								 | 
							
								// $Id: RF22.h,v 1.21 2012/05/30 01:51:25 mikem Exp $
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#include <bcm2835.h>
							 | 
						||
| 
								 | 
							
								#include <stdio.h>
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								int main(int argc, char **argv)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    // If you call this, it will not actually access the GPIO
							 | 
						||
| 
								 | 
							
								// Use for testing
							 | 
						||
| 
								 | 
							
								//        bcm2835_set_debug(1);
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								    if (!bcm2835_init())
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								      printf("bcm2835_init failed. Are you running as root??\n");
							 | 
						||
| 
								 | 
							
								      return 1;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (!bcm2835_spi_begin())
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								      printf("bcm2835_spi_begin failed. Are you running as root??\n");
							 | 
						||
| 
								 | 
							
								      return 1;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    bcm2835_spi_begin();
							 | 
						||
| 
								 | 
							
								    bcm2835_spi_setBitOrder(BCM2835_SPI_BIT_ORDER_MSBFIRST);      // The default
							 | 
						||
| 
								 | 
							
								    bcm2835_spi_setDataMode(BCM2835_SPI_MODE0);                   // The default
							 | 
						||
| 
								 | 
							
								    bcm2835_spi_setClockDivider(BCM2835_SPI_CLOCK_DIVIDER_65536); // The default
							 | 
						||
| 
								 | 
							
								    bcm2835_spi_chipSelect(BCM2835_SPI_CS0);                      // The default
							 | 
						||
| 
								 | 
							
								    bcm2835_spi_setChipSelectPolarity(BCM2835_SPI_CS0, LOW);      // the default
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								    // Send a some bytes to the slave and simultaneously read 
							 | 
						||
| 
								 | 
							
								    // some bytes back from the slave
							 | 
						||
| 
								 | 
							
								    // Most SPI devices expect one or 2 bytes of command, after which they will send back
							 | 
						||
| 
								 | 
							
								    // some data. In such a case you will have the command bytes first in the buffer,
							 | 
						||
| 
								 | 
							
								    // followed by as many 0 bytes as you expect returned data bytes. After the transfer, you 
							 | 
						||
| 
								 | 
							
								    // Can the read the reply bytes from the buffer.
							 | 
						||
| 
								 | 
							
								    // If you tie MISO to MOSI, you should read back what was sent.
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								    char buf[] = { 0x01, 0x02, 0x11, 0x33 }; // Data to send
							 | 
						||
| 
								 | 
							
								    bcm2835_spi_transfern(buf, sizeof(buf));
							 | 
						||
| 
								 | 
							
								    // buf will now be filled with the data that was read from the slave
							 | 
						||
| 
								 | 
							
								    printf("Read from SPI: %02X  %02X  %02X  %02X \n", buf[0], buf[1], buf[2], buf[3]);
							 | 
						||
| 
								 | 
							
								    
							 | 
						||
| 
								 | 
							
								    bcm2835_spi_end();
							 | 
						||
| 
								 | 
							
								    bcm2835_close();
							 | 
						||
| 
								 | 
							
								    return 0;
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 |