Various USB Debug Port fixes (trivial).
- Drop unused DBGP_DEFAULT #defines on boards with chipsets where no USB Debug Port support is implemented anyway (at the moment, at least): - hp/dl145_g3 - hp/dl165_g6_fam10 - ICH7: Move unrelated code out of set_debug_port(). All ICH southbridges with Debug Port hardcode the physical USB port used as Debug Port to 1. In other words, this port is not user-configurable (as seems to be the case on NVIDIA MCP55). For now we keep the 'port' parameter in order to not change the API, this might be fixed differently later. Signed-off-by: Uwe Hermann <uwe@hermann-uwe.de> Acked-by: Uwe Hermann <uwe@hermann-uwe.de> git-svn-id: svn://svn.coreboot.org/coreboot/trunk@5842 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
This commit is contained in:
parent
bcabf2fa74
commit
370d979a93
8 changed files with 16 additions and 24 deletions
|
@ -37,7 +37,6 @@
|
||||||
#include <cpu/x86/bist.h>
|
#include <cpu/x86/bist.h>
|
||||||
|
|
||||||
#if CONFIG_USBDEBUG
|
#if CONFIG_USBDEBUG
|
||||||
#define DBGP_DEFAULT 0
|
|
||||||
#include "southbridge/intel/i82801gx/i82801gx_usb_debug.c"
|
#include "southbridge/intel/i82801gx/i82801gx_usb_debug.c"
|
||||||
#include "pc80/usbdebug_serial.c"
|
#include "pc80/usbdebug_serial.c"
|
||||||
#endif
|
#endif
|
||||||
|
@ -319,7 +318,7 @@ void main(unsigned long bist)
|
||||||
uart_init();
|
uart_init();
|
||||||
|
|
||||||
#if CONFIG_USBDEBUG
|
#if CONFIG_USBDEBUG
|
||||||
i82801gx_enable_usbdebug(DBGP_DEFAULT);
|
i82801gx_enable_usbdebug(1);
|
||||||
early_usbdebug_init();
|
early_usbdebug_init();
|
||||||
#endif
|
#endif
|
||||||
console_init();
|
console_init();
|
||||||
|
|
|
@ -44,8 +44,6 @@
|
||||||
#define K8_REV_F_SUPPORT_F0_F1_WORKAROUND 0
|
#define K8_REV_F_SUPPORT_F0_F1_WORKAROUND 0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define DBGP_DEFAULT 7
|
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <device/pci_def.h>
|
#include <device/pci_def.h>
|
||||||
|
|
|
@ -39,8 +39,6 @@
|
||||||
#define SET_FIDVID 1
|
#define SET_FIDVID 1
|
||||||
#define SET_FIDVID_CORE_RANGE 0
|
#define SET_FIDVID_CORE_RANGE 0
|
||||||
|
|
||||||
#define DBGP_DEFAULT 7
|
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <device/pci_def.h>
|
#include <device/pci_def.h>
|
||||||
|
|
|
@ -40,7 +40,6 @@
|
||||||
#include <cpu/x86/bist.h>
|
#include <cpu/x86/bist.h>
|
||||||
|
|
||||||
#if CONFIG_USBDEBUG
|
#if CONFIG_USBDEBUG
|
||||||
#define DBGP_DEFAULT 1
|
|
||||||
#include "southbridge/intel/i82801gx/i82801gx_usb_debug.c"
|
#include "southbridge/intel/i82801gx/i82801gx_usb_debug.c"
|
||||||
#include "pc80/usbdebug_serial.c"
|
#include "pc80/usbdebug_serial.c"
|
||||||
#endif
|
#endif
|
||||||
|
@ -275,7 +274,7 @@ void main(unsigned long bist)
|
||||||
uart_init();
|
uart_init();
|
||||||
|
|
||||||
#if CONFIG_USBDEBUG
|
#if CONFIG_USBDEBUG
|
||||||
i82801gx_enable_usbdebug(DBGP_DEFAULT);
|
i82801gx_enable_usbdebug(1);
|
||||||
early_usbdebug_init();
|
early_usbdebug_init();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -39,7 +39,6 @@
|
||||||
#include <cpu/x86/bist.h>
|
#include <cpu/x86/bist.h>
|
||||||
|
|
||||||
#if CONFIG_USBDEBUG
|
#if CONFIG_USBDEBUG
|
||||||
#define DBGP_DEFAULT 1
|
|
||||||
#include "southbridge/intel/i82801gx/i82801gx_usb_debug.c"
|
#include "southbridge/intel/i82801gx/i82801gx_usb_debug.c"
|
||||||
#include "pc80/usbdebug_serial.c"
|
#include "pc80/usbdebug_serial.c"
|
||||||
#endif
|
#endif
|
||||||
|
@ -236,7 +235,7 @@ void main(unsigned long bist)
|
||||||
uart_init();
|
uart_init();
|
||||||
|
|
||||||
#if CONFIG_USBDEBUG
|
#if CONFIG_USBDEBUG
|
||||||
i82801gx_enable_usbdebug(DBGP_DEFAULT);
|
i82801gx_enable_usbdebug(1);
|
||||||
early_usbdebug_init();
|
early_usbdebug_init();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -49,8 +49,6 @@
|
||||||
#include <cpu/x86/bist.h>
|
#include <cpu/x86/bist.h>
|
||||||
|
|
||||||
#if CONFIG_USBDEBUG
|
#if CONFIG_USBDEBUG
|
||||||
#define DBGP_DEFAULT 1
|
|
||||||
#include <usbdebug.h>
|
|
||||||
#include "southbridge/intel/i82801gx/i82801gx_usb_debug.c"
|
#include "southbridge/intel/i82801gx/i82801gx_usb_debug.c"
|
||||||
#include "pc80/usbdebug_serial.c"
|
#include "pc80/usbdebug_serial.c"
|
||||||
#endif
|
#endif
|
||||||
|
@ -379,7 +377,7 @@ void main(unsigned long bist)
|
||||||
uart_init();
|
uart_init();
|
||||||
|
|
||||||
#if CONFIG_USBDEBUG
|
#if CONFIG_USBDEBUG
|
||||||
i82801gx_enable_usbdebug(DBGP_DEFAULT);
|
i82801gx_enable_usbdebug(1);
|
||||||
early_usbdebug_init();
|
early_usbdebug_init();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -41,7 +41,6 @@
|
||||||
#include <cpu/x86/bist.h>
|
#include <cpu/x86/bist.h>
|
||||||
|
|
||||||
#if CONFIG_USBDEBUG
|
#if CONFIG_USBDEBUG
|
||||||
#define DBGP_DEFAULT 1
|
|
||||||
#include "southbridge/intel/i82801gx/i82801gx_usb_debug.c"
|
#include "southbridge/intel/i82801gx/i82801gx_usb_debug.c"
|
||||||
#include "pc80/usbdebug_serial.c"
|
#include "pc80/usbdebug_serial.c"
|
||||||
#endif
|
#endif
|
||||||
|
@ -291,7 +290,7 @@ void main(unsigned long bist)
|
||||||
uart_init();
|
uart_init();
|
||||||
|
|
||||||
#if CONFIG_USBDEBUG
|
#if CONFIG_USBDEBUG
|
||||||
i82801gx_enable_usbdebug(DBGP_DEFAULT);
|
i82801gx_enable_usbdebug(1);
|
||||||
early_usbdebug_init();
|
early_usbdebug_init();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -17,6 +17,8 @@
|
||||||
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <usbdebug.h>
|
||||||
|
|
||||||
// An arbitrary address for the BAR
|
// An arbitrary address for the BAR
|
||||||
#define EHCI_BAR 0xFEF00000
|
#define EHCI_BAR 0xFEF00000
|
||||||
// These could be read from DEBUG_BASE (0:1d.7 R 0x5A 16bit)
|
// These could be read from DEBUG_BASE (0:1d.7 R 0x5A 16bit)
|
||||||
|
@ -26,22 +28,22 @@
|
||||||
#define EHCI_PORTSC 0x44
|
#define EHCI_PORTSC 0x44
|
||||||
#define EHCI_DEBUG_OFFSET 0xA0
|
#define EHCI_DEBUG_OFFSET 0xA0
|
||||||
|
|
||||||
#include <usbdebug.h>
|
/* Required for successful build, but currently empty. */
|
||||||
|
void set_debug_port(unsigned int port)
|
||||||
|
{
|
||||||
|
/* Not needed, the ICH* southbridges hardcode physical USB port 1. */
|
||||||
|
}
|
||||||
|
|
||||||
void set_debug_port(unsigned port)
|
static void i82801gx_enable_usbdebug(unsigned int port)
|
||||||
{
|
{
|
||||||
u32 dbgctl;
|
u32 dbgctl;
|
||||||
|
|
||||||
|
pci_write_config32(PCI_DEV(0, 0x1d, 7), EHCI_BAR_INDEX, EHCI_BAR);
|
||||||
|
pci_write_config8(PCI_DEV(0, 0x1d, 7), 0x04, 0x2); // Memory Space Enable
|
||||||
|
|
||||||
printk(BIOS_DEBUG, "Enabling OWNER_CNT\n");
|
printk(BIOS_DEBUG, "Enabling OWNER_CNT\n");
|
||||||
dbgctl = read32(EHCI_BAR + EHCI_DEBUG_OFFSET);
|
dbgctl = read32(EHCI_BAR + EHCI_DEBUG_OFFSET);
|
||||||
dbgctl |= (1 << 30);
|
dbgctl |= (1 << 30);
|
||||||
write32(EHCI_BAR + EHCI_DEBUG_OFFSET, dbgctl);
|
write32(EHCI_BAR + EHCI_DEBUG_OFFSET, dbgctl);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void i82801gx_enable_usbdebug(unsigned port)
|
|
||||||
{
|
|
||||||
pci_write_config32(PCI_DEV(0, 0x1d, 7), EHCI_BAR_INDEX, EHCI_BAR);
|
|
||||||
pci_write_config8(PCI_DEV(0, 0x1d, 7), 0x04, 0x2); // Memory Space Enable
|
|
||||||
set_debug_port(port);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue