1
0
mirror of synced 2024-11-23 01:34:24 +01:00
avr_demo/tpic6b595_spi/main.c

88 lines
2.7 KiB
C
Raw Normal View History

2011-11-20 18:11:58 +01:00
/*
* Code to write data to TPIC6B595 SIPO shift register.
*
* The TPIC6B595 is a monolithic, high-voltage, medium-current power 8-bit
* shift register designed for use in systems that require relatively high
* load power.
*
* This device contains an 8-bit serial-in, parallel-out shift register that
* feeds an 8-bit D-type storage register. Data transfers through both the
* shift and storage registers on the rising edge of the shift-register clock
* (SRCK) and the register clock (RCK), respectively. The storage register
* transfers data to the output buffer when shift-register clear (SRCLR) is
* high. When SRCLR is low, the input shift register is cleared. When output
* enable (G) is held high, all data in the output buffers is held low and all
* drain outputs are off. When G is held low, data from the storage register
* is transparent to the output buffers. When data in the output buffers is
* low, the DMOS-transistor outputs are off. When data is high, the DMOS-
* transistor outputs have sink-current capability. The serial output (SER
* OUT) allows for cascading of the data from the shift register to additional
* devices.
*
* http://www.adafruit.com/datasheets/tpic6b595.pdf
* http://www.atmel.com/dyn/resources/prod_documents/doc2585.pdf
* http://www.atmel.com/dyn/resources/prod_documents/doc8025.pdf
*
* To compile and upload run: make clean; make; make program;
*
* Copyright 2011 Mika Tuupola
*
* Licensed under the MIT license:
* http://www.opensource.org/licenses/mit-license.php
*
*/
2012-01-13 22:28:32 +01:00
#define UART_RX_BUFFER_SIZE 128
2011-11-20 18:11:58 +01:00
#include <stdlib.h>
#include <stdio.h>
#include <util/delay.h>
#include "main.h"
2012-01-13 22:28:32 +01:00
#include "uart/uart.h"
#include "pins/digital.h"
#include "spi/spi.h"
2011-11-20 18:11:58 +01:00
static void init(void) {
}
int main(void) {
init();
uart_init();
spi_init();
stdout = &uart_output;
stdin = &uart_input;
char binary[17];
/* Show pattern for 5 seconds. */
2012-01-13 22:28:32 +01:00
spi_transfer(0b10101010);
spi_transfer(0b11110000);
2011-11-20 18:11:58 +01:00
digital_write(SPI_SS, LOW);
digital_write(SPI_SS, HIGH);
2012-01-13 22:28:32 +01:00
_delay_ms(5000);
2011-11-20 18:11:58 +01:00
while (1) {
for(uint16_t i = 0; i < 0xffff; i++) {
/* Print the number to serial for debugging. */
itoa(i, binary, 2);
printf("%s %d \n", binary, i);
/* Shift high byte first to shift register. */
2012-01-13 22:28:32 +01:00
spi_transfer(i >> 8);
spi_transfer(i & 0xff);
2011-11-20 18:11:58 +01:00
/* Pulse latch to transfer data from shift registers */
/* to storage registers. */
//digital_write(LATCH, LOW);
//digital_write(LATCH, HIGH);
digital_write(SPI_SS, LOW);
digital_write(SPI_SS, HIGH);
}
}
return 0;
}