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;
 | 
						|
}
 | 
						|
 |