Sylvain Munaut | bc9f5c4 | 2020-09-14 10:22:29 +0200 | [diff] [blame] | 1 | /* |
| 2 | * e1.h |
| 3 | * |
| 4 | * Copyright (C) 2019-2020 Sylvain Munaut <tnt@246tNt.com> |
| 5 | * SPDX-License-Identifier: GPL-3.0-or-later |
| 6 | */ |
| 7 | |
| 8 | #pragma once |
| 9 | |
Sylvain Munaut | 2c0c136 | 2022-01-03 18:48:08 +0100 | [diff] [blame] | 10 | |
| 11 | /* control */ |
| 12 | |
Sylvain Munaut | 3da5151 | 2022-01-03 22:12:59 +0100 | [diff] [blame] | 13 | void e1_init(int port, uint16_t rx_cr, uint16_t tx_cr); |
Sylvain Munaut | 0cc1613 | 2022-01-10 13:26:15 +0100 | [diff] [blame] | 14 | void e1_start(int port); |
| 15 | void e1_stop(int port); |
| 16 | |
Sylvain Munaut | 3da5151 | 2022-01-03 22:12:59 +0100 | [diff] [blame] | 17 | void e1_poll(int port); |
| 18 | void e1_debug_print(int port, bool data); |
Sylvain Munaut | bc9f5c4 | 2020-09-14 10:22:29 +0200 | [diff] [blame] | 19 | |
Sylvain Munaut | 3da5151 | 2022-01-03 22:12:59 +0100 | [diff] [blame] | 20 | void e1_rx_config(int port, uint16_t cr); |
Sylvain Munaut | 4fd7155 | 2022-01-10 12:28:28 +0100 | [diff] [blame] | 21 | void e1_tx_config(int port, uint16_t cr); |
Harald Welte | 6add0aa | 2020-12-16 00:02:11 +0100 | [diff] [blame] | 22 | |
Sylvain Munaut | 2c0c136 | 2022-01-03 18:48:08 +0100 | [diff] [blame] | 23 | |
| 24 | /* data flow */ |
| 25 | |
Sylvain Munaut | 3da5151 | 2022-01-03 22:12:59 +0100 | [diff] [blame] | 26 | unsigned int e1_rx_need_data(int port, unsigned int usb_addr, unsigned int max_len, unsigned int *pos); |
| 27 | unsigned int e1_tx_feed_data(int port, unsigned int usb_addr, unsigned int len); |
Sylvain Munaut | 3da5151 | 2022-01-03 22:12:59 +0100 | [diff] [blame] | 28 | unsigned int e1_rx_level(int port); |
Sylvain Munaut | 4fd7155 | 2022-01-10 12:28:28 +0100 | [diff] [blame] | 29 | unsigned int e1_tx_level(int port); |
Sylvain Munaut | 2c0c136 | 2022-01-03 18:48:08 +0100 | [diff] [blame] | 30 | |
| 31 | |
| 32 | /* error reporting */ |
| 33 | |
Harald Welte | 805f2cf | 2020-12-14 17:31:03 +0100 | [diff] [blame] | 34 | #define E1_ERR_F_ALIGN_ERR 0x01 |
| 35 | #define E1_ERR_F_LOS 0x02 |
Harald Welte | 51baa36 | 2022-01-01 15:22:25 +0100 | [diff] [blame] | 36 | #define E1_ERR_F_RAI 0x04 |
Harald Welte | 805f2cf | 2020-12-14 17:31:03 +0100 | [diff] [blame] | 37 | |
| 38 | struct e1_error_count { |
| 39 | uint16_t crc; |
| 40 | uint16_t align; |
| 41 | uint16_t ovfl; |
| 42 | uint16_t unfl; |
| 43 | uint8_t flags; |
| 44 | }; |
| 45 | |
Sylvain Munaut | 3da5151 | 2022-01-03 22:12:59 +0100 | [diff] [blame] | 46 | const struct e1_error_count *e1_get_error_count(int port); |
Harald Welte | 805f2cf | 2020-12-14 17:31:03 +0100 | [diff] [blame] | 47 | |
Sylvain Munaut | 2c0c136 | 2022-01-03 18:48:08 +0100 | [diff] [blame] | 48 | |
| 49 | /* external function provided by the platform; used by E1 driver to control LEDs */ |
| 50 | |
Harald Welte | 5276567 | 2020-12-15 18:35:42 +0100 | [diff] [blame] | 51 | enum e1_platform_led { |
| 52 | E1P_LED_GREEN = 0, |
| 53 | E1P_LED_YELLOW = 1, |
| 54 | }; |
| 55 | |
| 56 | enum e1_platform_led_state { |
| 57 | E1P_LED_ST_OFF = 0, |
| 58 | E1P_LED_ST_ON = 1, |
| 59 | E1P_LED_ST_BLINK = 2, |
| 60 | E1P_LED_ST_BLINK_FAST = 3 |
| 61 | }; |
| 62 | |
Sylvain Munaut | 8f31a9e | 2022-01-03 22:09:03 +0100 | [diff] [blame] | 63 | extern void e1_platform_led_set(int port, enum e1_platform_led led, |
Harald Welte | 5276567 | 2020-12-15 18:35:42 +0100 | [diff] [blame] | 64 | enum e1_platform_led_state state); |