Subversion Repositories Projects

Rev

Rev 2598 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
471 cascade 1
/****************************************************************************
2601 - 2
 *   Copyright (C) 2009-2018 by Claas Anders "CaScAdE" Rathje               *
471 cascade 3
 *   admiralcascade@gmail.com                                               *
4
 *   Project-URL: http://www.mylifesucks.de/oss/c-osd/                      *
5
 *                                                                          *
6
 *   This program is free software; you can redistribute it and/or modify   *
7
 *   it under the terms of the GNU General Public License as published by   *
8
 *   the Free Software Foundation; either version 2 of the License.         *
9
 *                                                                          *
10
 *   This program is distributed in the hope that it will be useful,        *
11
 *   but WITHOUT ANY WARRANTY; without even the implied warranty of         *
12
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the          *
13
 *   GNU General Public License for more details.                           *
14
 *                                                                          *
15
 *   You should have received a copy of the GNU General Public License      *
16
 *   along with this program; if not, write to the                          *
17
 *   Free Software Foundation, Inc.,                                        *
18
 *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.              *
19
 ****************************************************************************/
20
 
762 - 21
#ifndef _SPI_H
22
#define _SPI_H
23
 
507 cascade 24
/*
25
 * structs 'n union for easy SPI transfer
26
 */
27
typedef struct {
761 - 28
    int16_t ampere;
29
    int32_t mah;
30
    int16_t volt;
507 cascade 31
} __attribute__((packed)) SPI_strom_data_t;
32
 
33
typedef struct {
761 - 34
    uint8_t c[10];
35
    uint8_t chk;
507 cascade 36
} __attribute__((packed)) SPI_char_buffer_t;
37
 
38
union SPI_buffer_t {
761 - 39
    SPI_strom_data_t data;
40
    SPI_char_buffer_t buffer;
507 cascade 41
};
42
 
43
volatile union SPI_buffer_t SPI_buffer;
44
 
471 cascade 45
/**
46
 * SPI interrupt handler
47
 */
48
ISR(SPI_STC_vect);
49
 
50
/**
51
 * init the SPI as master
52
 */
53
void SpiMasterInit(void);
54
 
55
/**
56
 * check if SPI transfer is still busy
57
 */
58
int TransferIsBusy(void);
59
 
60
/**
507 cascade 61
 * start a new transfer with length <len>
471 cascade 62
 */
507 cascade 63
void StartTransfer(uint16_t);
64
 
65
/**
66
 * send next command through spi
67
 */
68
void spi_send_next();
762 - 69
 
70
#endif