summaryrefslogtreecommitdiff
path: root/zephyr/shim/include/usbc/anx7452_usb_mux.h
blob: 1b3cdbcc8e11c0793d5b2d151854200475262b5e (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
/* Copyright 2023 The ChromiumOS Authors
 * Use of this source code is governed by a BSD-style license that can be
 * found in the LICENSE file.
 */

#ifndef __ZEPHYR_SHIM_ANX7452_USB_MUX_H
#define __ZEPHYR_SHIM_ANX7452_USB_MUX_H

#include "driver/retimer/anx7452_public.h"

#define ANX7452_USB_MUX_COMPAT analogix_anx7452

#define ANX7452_USB_EN_GPIO(mux_id) GPIO_SIGNAL(DT_PHANDLE(mux_id, usb_en_pin))

#define ANX7452_DP_EN_GPIO(mux_id)                                \
	COND_CODE_1(DT_NODE_HAS_PROP(mux_id, dp_en_pin),          \
		    (GPIO_SIGNAL(DT_PHANDLE(mux_id, dp_en_pin))), \
		    (GPIO_UNIMPLEMENTED))

#define ANX7452_CONTROLS_CONFIG(mux_id)                         \
	{                                                       \
		.usb_enable_gpio = ANX7452_USB_EN_GPIO(mux_id), \
		.dp_enable_gpio = ANX7452_DP_EN_GPIO(mux_id),   \
	}

#define USB_MUX_ANX7452_CONTROL_ARRAY(mux_id) \
	[USB_MUX_PORT(mux_id)] = ANX7452_CONTROLS_CONFIG(mux_id),

#define USB_MUX_ANX7452_CONTROLS_ARRAY                 \
	DT_FOREACH_STATUS_OKAY(ANX7452_USB_MUX_COMPAT, \
			       USB_MUX_ANX7452_CONTROL_ARRAY)

#define USB_MUX_CONFIG_ANX7452(mux_id)                         \
	{                                                      \
		USB_MUX_COMMON_FIELDS(mux_id),                 \
			.driver = &anx7452_usb_retimer_driver, \
			.i2c_port = I2C_PORT_BY_DEV(mux_id),   \
			.i2c_addr_flags = DT_REG_ADDR(mux_id), \
	}

#endif /* __ZEPHYR_SHIM_ANX7452_USB_MUX_H */