Zephyr API Documentation
2.7.0-rc2
A Scalable Open Source RTOS
xlnx_gem.h
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2021, Weidmueller Interface GmbH & Co. KG
3
* SPDX-License-Identifier: Apache-2.0
4
*/
5
6
#ifndef ZEPHYR_INCLUDE_DT_BINDINGS_ETHERNET_XLNX_GEM_H_
7
#define ZEPHYR_INCLUDE_DT_BINDINGS_ETHERNET_XLNX_GEM_H_
8
9
/* PHY auto-detection alias */
10
#define XLNX_GEM_PHY_AUTO_DETECT 0
11
12
/* MDC divider values */
13
#define XLNX_GEM_MDC_DIVIDER_8 0
/* LPD_LSBUS_CLK < 20 MHz */
14
#define XLNX_GEM_MDC_DIVIDER_16 1
/* LPD_LSBUS_CLK 20 - 40 MHz */
15
#define XLNX_GEM_MDC_DIVIDER_32 2
/* LPD_LSBUS_CLK 40 - 80 MHz */
16
/*
17
* According to the ZynqMP's gem.network_config register documentation,
18
* divider /32 is to be used for a 100 MHz LPD LSBUS clock.
19
*/
20
#define XLNX_GEM_MDC_DIVIDER_48 3
/* LPD_LSBUS_CLK 80 - 120 MHz */
21
22
/* Link speed values */
23
#define XLNX_GEM_LINK_SPEED_10MBIT 1
24
#define XLNX_GEM_LINK_SPEED_100MBIT 2
25
#define XLNX_GEM_LINK_SPEED_1GBIT 3
26
27
/* AMBA AHB data bus width */
28
#define XLNX_GEM_AMBA_AHB_DBUS_WIDTH_32BIT 0
29
#define XLNX_GEM_AMBA_AHB_DBUS_WIDTH_64BIT 1
30
#define XLNX_GEM_AMBA_AHB_DBUS_WIDTH_128BIT 2
31
32
/* AMBA AHB burst length */
33
#define XLNX_GEM_AMBA_AHB_BURST_SINGLE 1
34
#define XLNX_GEM_AMBA_AHB_BURST_INCR4 4
35
#define XLNX_GEM_AMBA_AHB_BURST_INCR8 8
36
#define XLNX_GEM_AMBA_AHB_BURST_INCR16 16
37
38
/* Hardware RX buffer size */
39
#define XLNX_GEM_HW_RX_BUFFER_SIZE_1KB 0
40
#define XLNX_GEM_HW_RX_BUFFER_SIZE_2KB 1
41
#define XLNX_GEM_HW_RX_BUFFER_SIZE_4KB 2
42
#define XLNX_GEM_HW_RX_BUFFER_SIZE_8KB 3
43
44
#endif
/* ZEPHYR_INCLUDE_DT_BINDINGS_ETHERNET_XLNX_GEM_H_ */
include
dt-bindings
ethernet
xlnx_gem.h
Generated on Sun Oct 9 2022 09:21:56 for Zephyr API Documentation by
1.9.4