Staging
v0.8.1
https://github.com/torvalds/linux
Raw File
Tip revision: b85ea95d086471afb4ad062012a4d73cd328fa86 authored by Linus Torvalds on 13 November 2023, 00:19:07 UTC
Linux 6.7-rc1
Tip revision: b85ea95
xhci-rzv2m.c
// SPDX-License-Identifier: GPL-2.0
/*
 * xHCI host controller driver for RZ/V2M
 *
 * Copyright (C) 2022 Renesas Electronics Corporation
 */

#include <linux/usb/rzv2m_usb3drd.h>
#include "xhci-plat.h"
#include "xhci-rzv2m.h"

#define RZV2M_USB3_INTEN	0x1044	/* Interrupt Enable */

#define RZV2M_USB3_INT_XHC_ENA	BIT(0)
#define RZV2M_USB3_INT_HSE_ENA	BIT(2)
#define RZV2M_USB3_INT_ENA_VAL	(RZV2M_USB3_INT_XHC_ENA \
				 | RZV2M_USB3_INT_HSE_ENA)

int xhci_rzv2m_init_quirk(struct usb_hcd *hcd)
{
	struct device *dev = hcd->self.controller;

	rzv2m_usb3drd_reset(dev->parent, true);

	return 0;
}

void xhci_rzv2m_start(struct usb_hcd *hcd)
{
	u32 int_en;

	if (hcd->regs) {
		/* Interrupt Enable */
		int_en = readl(hcd->regs + RZV2M_USB3_INTEN);
		int_en |= RZV2M_USB3_INT_ENA_VAL;
		writel(int_en, hcd->regs + RZV2M_USB3_INTEN);
	}
}
back to top