forked from zephyrproject-rtos/zephyr
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathspi_sifive.h
75 lines (57 loc) · 1.48 KB
/
spi_sifive.h
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
/*
* Copyright (c) 2018 SiFive Inc.
*
* SPDX-License-Identifier: Apache-2.0
*/
#ifndef _SPI_SIFIVE__H
#define _SPI_SIFIVE__H
#include "spi_context.h"
#include <sys_io.h>
#include <device.h>
#include <spi.h>
#define SPI_CFG(dev) ((struct spi_sifive_cfg *) ((dev)->config->config_info))
#define SPI_DATA(dev) ((struct spi_sifive_data *) ((dev)->driver_data))
#define SPI_REG(dev, offset) ((mem_addr_t) (SPI_CFG(dev)->base + (offset)))
/* Register Offsets */
#define REG_SCKDIV 0x000
#define REG_SCKMODE 0x004
#define REG_CSID 0x010
#define REG_CSDEF 0x014
#define REG_CSMODE 0x018
#define REG_DELAY0 0x028
#define REG_DELAY1 0x02C
#define REG_FMT 0x040
#define REG_TXDATA 0x048
#define REG_RXDATA 0x04C
#define REG_TXMARK 0x050
#define REG_RXMARK 0x054
#define REG_FCTRL 0x060
#define REG_FFMT 0x064
#define REG_IE 0x070
#define REG_IP 0x074
/* Masks */
#define SF_SCKDIV_DIV_MASK (0xFFF << 0)
#define SF_FMT_PROTO_MASK (0x3 << 0)
#define SF_FMT_LEN_MASK (0xF << 16)
/* Offsets */
#define SF_SCKMODE_POL 1
#define SF_SCKMODE_PHA 0
#define SF_FMT_LEN 16
#define SF_FMT_ENDIAN 2
#define SF_FCTRL_EN 0
/* Values */
#define SF_CSMODE_AUTO 0
#define SF_CSMODE_HOLD 2
#define SF_CSMODE_OFF 3
#define SF_FMT_PROTO_SINGLE 0
#define SF_TXDATA_FULL (1 << 31)
#define SF_RXDATA_EMPTY (1 << 31)
/* Structure Declarations */
struct spi_sifive_data {
struct spi_context ctx;
};
struct spi_sifive_cfg {
u32_t base;
u32_t f_sys;
};
#endif /* _SPI_SIFIVE__H */