mirror of
https://github.com/Telecominfraproject/OpenCellular.git
synced 2025-12-27 18:25:05 +00:00
All the additional work that needs to be done in EHCI BAR relocation is independent of the hardware platform and was functionally identical in all the copies removed. When USBDEBUG is not selected, PCI EHCI controllers use standard pci_dev_read_resources() call. With USBDEBUG selected, PCI EHCI controller's device_operations .read_resources is replaced with pci_ehci_read_resources() call, which in turn will replace the device_operations .set_resources call. The replacement for .set_resources reconfigures usbdebug driver side, and calls the original .set_resources to configure hardware side. Change-Id: I8e136a5da4efedf60b6dd7068c0488153efaaf8e Signed-off-by: Kyösti Mälkki <kyosti.malkki@gmail.com> Reviewed-on: http://review.coreboot.org/3412 Reviewed-by: Aaron Durbin <adurbin@google.com> Tested-by: build bot (Jenkins) Reviewed-by: Paul Menzel <paulepanter@users.sourceforge.net>
66 lines
2.2 KiB
C
66 lines
2.2 KiB
C
/*
|
|
* This file is part of the coreboot project.
|
|
*
|
|
* Copyright (C) 2007 AMD
|
|
* Written by Yinghai Lu <yinghai.lu@amd.com> for AMD.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; version 2 of the License.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA, 02110-1301 USA
|
|
*/
|
|
|
|
#ifndef USBDEBUG_H
|
|
#define USBDEBUG_H
|
|
|
|
#define EHCI_BAR_INDEX 0x10
|
|
|
|
#ifndef __PRE_RAM__
|
|
#if !CONFIG_USBDEBUG
|
|
#define pci_ehci_read_resources pci_dev_read_resources
|
|
#else
|
|
/* Relocation of EHCI Debug Port BAR
|
|
*
|
|
* PCI EHCI controller with Debug Port capability shall replace
|
|
* pci_dev_read_resources() with pci_ehci_read_resources() in its
|
|
* declaration of device_operations for .read_resources.
|
|
* This installs a hook to reconfigure usbdebug when resource allocator
|
|
* assigns a new BAR for the device.
|
|
*/
|
|
struct device;
|
|
void pci_ehci_read_resources(struct device *dev);
|
|
#endif
|
|
#endif
|
|
|
|
struct ehci_debug_info {
|
|
void *ehci_caps;
|
|
void *ehci_regs;
|
|
void *ehci_debug;
|
|
u32 devnum;
|
|
u32 endpoint_out;
|
|
u32 endpoint_in;
|
|
char buf[8];
|
|
u8 bufidx;
|
|
};
|
|
|
|
void enable_usbdebug(unsigned int port);
|
|
int dbgp_bulk_write_x(struct ehci_debug_info *dbg_info, const char *bytes, int size);
|
|
int dbgp_bulk_read_x(struct ehci_debug_info *dbg_info, void *data, int size);
|
|
void set_ehci_base(unsigned ehci_base);
|
|
void set_ehci_debug(unsigned ehci_debug);
|
|
unsigned get_ehci_debug(void);
|
|
void set_debug_port(unsigned port);
|
|
int early_usbdebug_init(void);
|
|
void usbdebug_tx_byte(struct ehci_debug_info *info, unsigned char data);
|
|
void usbdebug_tx_flush(struct ehci_debug_info *info);
|
|
int usbdebug_init(unsigned ehci_bar, unsigned offset, struct ehci_debug_info *info);
|
|
#endif
|