Skip to content

Commit

Permalink
baytrail: disable tco timer
Browse files Browse the repository at this point in the history
The TCO timer always starts ticking out of reset.
However, depending on microcode loading and punit
initialization the TCO timing out has a different
impact on the sytem. Without loading microcode
or initializing the punit the tco times out and
nothing happens. However, when microcode is loaded
a timeout will reset the system. Lastly, if the
punit is initialized but the microcode isn't loaded
the TCO timeout will shut down the system.

To fix all the weird symptoms disable the TCO.

BUG=chrome-os-partner:22858
BRANCH=None
TEST=Built and booted with microcode loading. Reset doesn't
     occur.

Change-Id: I49cd62f510726a96bf734ae728a352c671d1561e
Signed-off-by: Aaron Durbin <[email protected]>
Reviewed-on: https://chromium-review.googlesource.com/171860
Reviewed-by: Shawn Nematbakhsh <[email protected]>
Reviewed-on: http://review.coreboot.org/4862
Tested-by: build bot (Jenkins)
Reviewed-by: Stefan Reinauer <[email protected]>
  • Loading branch information
Aaron Durbin authored and adurbin committed Feb 5, 2014
1 parent a64ef62 commit fd039f7
Show file tree
Hide file tree
Showing 5 changed files with 49 additions and 1 deletion.
10 changes: 10 additions & 0 deletions src/soc/intel/baytrail/baytrail/pmc.h
Original file line number Diff line number Diff line change
Expand Up @@ -27,4 +27,14 @@
#define GEN_PMCONF1 0x20
# define UART_EN (1 << 24)

/* IO Mapped registers behind ACPI_BASE_ADDRESS */
#define TCO_RLD 0x60
#define TCO_STS 0x64
# define SECOND_TO_STS (1 << 17)
# define TCO_TIMEOUT (1 << 3)
#define TCO1_CNT 0x68
# define TCO_LOCK (1 << 12)
# define TCO_TMR_HALT (1 << 11)
#define TCO_TMR 0x70

#endif /* _BAYTRAIL_PMC_H_ */
1 change: 1 addition & 0 deletions src/soc/intel/baytrail/baytrail/romstage.h
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,7 @@ void * asmlinkage romstage_main(unsigned long bist, uint32_t tsc_lo,
void asmlinkage romstage_after_car(void);
void raminit(struct mrc_params *mp, int prev_sleep_state);
void gfx_init(void);
void tco_disable(void);

#if CONFIG_ENABLE_BUILTIN_COM1
void byt_config_com1_and_enable(void);
Expand Down
1 change: 1 addition & 0 deletions src/soc/intel/baytrail/romstage/Makefile.inc
Original file line number Diff line number Diff line change
Expand Up @@ -3,3 +3,4 @@ romstage-y += romstage.c
romstage-y += raminit.c
romstage-$(CONFIG_ENABLE_BUILTIN_COM1) += uart.c
romstage-y += gfx.c
romstage-y += pmc.c
35 changes: 35 additions & 0 deletions src/soc/intel/baytrail/romstage/pmc.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
/*
* This file is part of the coreboot project.
*
* Copyright (C) 2013 Google Inc.
*
* 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
*/

#include <stddef.h>
#include <arch/io.h>
#include <baytrail/iomap.h>
#include <baytrail/iosf.h>
#include <baytrail/pci_devs.h>
#include <baytrail/pmc.h>
#include <baytrail/romstage.h>

void tco_disable(void)
{
uint32_t reg;

reg = inl(ACPI_BASE_ADDRESS + TCO1_CNT);
reg |= TCO_TMR_HALT;
outl(reg, ACPI_BASE_ADDRESS + TCO1_CNT);
}
3 changes: 2 additions & 1 deletion src/soc/intel/baytrail/romstage/romstage.c
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,6 @@
#include <timestamp.h>
#include <baytrail/gpio.h>
#include <baytrail/iomap.h>
#include <baytrail/iosf.h>
#include <baytrail/lpc.h>
#include <baytrail/pci_devs.h>
#include <baytrail/romstage.h>
Expand Down Expand Up @@ -121,6 +120,8 @@ void romstage_common(struct romstage_params *params)

program_base_addresses();

tco_disable();

byt_config_com1_and_enable();

console_init();
Expand Down

0 comments on commit fd039f7

Please sign in to comment.