summaryrefslogtreecommitdiff
path: root/libloragw/tst/test_loragw_spi.c
blob: b0c7fbca3e0bfa0a85f84dbe52a94d63b8ecc895 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/*
 / _____)             _              | |
( (____  _____ ____ _| |_ _____  ____| |__
 \____ \| ___ |    (_   _) ___ |/ ___)  _ \
 _____) ) ____| | | || |_| ____( (___| | | |
(______/|_____)_|_|_| \__)_____)\____)_| |_|
  (C)2013 Semtech-Cycleo

Description:
	Minimum test program for the loragw_spi 'library'
	Use logic analyser to check the results.

License: Revised BSD License, see LICENSE.TXT file include in the project
Maintainer: Sylvain Miermont
*/


/* -------------------------------------------------------------------------- */
/* --- DEPENDANCIES --------------------------------------------------------- */

#include <stdint.h>
#include <stdio.h>

#include "loragw_spi.h"

/* -------------------------------------------------------------------------- */
/* --- PRIVATE MACROS ------------------------------------------------------- */

#define ARRAY_SIZE(a) (sizeof(a) / sizeof((a)[0]))

/* -------------------------------------------------------------------------- */
/* --- PRIVATE CONSTANTS ---------------------------------------------------- */

#define BURST_TEST_SIZE 2500 /* >> LGW_BURST_CHUNK */
#define TIMING_REPEAT	1	 /* repeat transactions multiple times for timing characterisation */

/* -------------------------------------------------------------------------- */
/* --- MAIN FUNCTION -------------------------------------------------------- */

int main()
{
	int i;
	void *spi_target = NULL;
	uint8_t data = 0;
	uint8_t dataout[BURST_TEST_SIZE];
	uint8_t datain[BURST_TEST_SIZE];
	
	for (i = 0; i < BURST_TEST_SIZE; ++i) {
		dataout[i] = 0x30 + (i % 10); /* ASCCI code for 0 -> 9 */
		datain[i] = 0x23; /* garbage data, to be overwritten by received data */
	}
	
	printf("Beginning of test for loragw_spi.c\n");
	lgw_spi_open(&spi_target);
	
	/* normal R/W test */
	for (i = 0; i < TIMING_REPEAT; ++i)
		lgw_spi_w(spi_target, 0xAA, 0x96);
	for (i = 0; i < TIMING_REPEAT; ++i)
		lgw_spi_r(spi_target, 0x55, &data);
	
	/* burst R/W test, small bursts << LGW_BURST_CHUNK */
	for (i = 0; i < TIMING_REPEAT; ++i)
		lgw_spi_wb(spi_target, 0x55, dataout, 16);
	for (i = 0; i < TIMING_REPEAT; ++i)
		lgw_spi_rb(spi_target, 0x55, datain, 16);
	
	/* burst R/W test, large bursts >> LGW_BURST_CHUNK */
	for (i = 0; i < TIMING_REPEAT; ++i)
		lgw_spi_wb(spi_target, 0x5A, dataout, ARRAY_SIZE(dataout));
	for (i = 0; i < TIMING_REPEAT; ++i)
		lgw_spi_rb(spi_target, 0x5A, datain, ARRAY_SIZE(datain));
	
	/* last read (blocking), just to be sure no to quit before the FTDI buffer is flushed */
	lgw_spi_r(spi_target, 0x55, &data);
	printf("data received (simple read): %d\n",data);
	
	lgw_spi_close(spi_target);
	printf("End of test for loragw_spi.c\n");
	
	return 0;
}

/* --- EOF ------------------------------------------------------------------ */