1a4145534SPeter Tyser /* 2a4145534SPeter Tyser * 3aa0d99fcSAlison Wang * Copyright (C) 2004-2007, 2012 Freescale Semiconductor, Inc. 4a4145534SPeter Tyser * TsiChung Liew (Tsi-Chung.Liew@freescale.com) 5a4145534SPeter Tyser * 6*1a459660SWolfgang Denk * SPDX-License-Identifier: GPL-2.0+ 7a4145534SPeter Tyser */ 8a4145534SPeter Tyser 9a4145534SPeter Tyser /* CPU specific interrupt routine */ 10a4145534SPeter Tyser #include <common.h> 11a4145534SPeter Tyser #include <asm/immap.h> 12aa0d99fcSAlison Wang #include <asm/io.h> 13a4145534SPeter Tyser interrupt_init(void)14a4145534SPeter Tyserint interrupt_init(void) 15a4145534SPeter Tyser { 16aa0d99fcSAlison Wang int0_t *intp = (int0_t *) (CONFIG_SYS_INTR_BASE); 17a4145534SPeter Tyser 18a4145534SPeter Tyser /* Make sure all interrupts are disabled */ 19aa0d99fcSAlison Wang setbits_be32(&intp->imrh0, 0xffffffff); 20aa0d99fcSAlison Wang setbits_be32(&intp->imrl0, 0xffffffff); 21a4145534SPeter Tyser 22a4145534SPeter Tyser enable_interrupts(); 23a4145534SPeter Tyser return 0; 24a4145534SPeter Tyser } 25a4145534SPeter Tyser 26a4145534SPeter Tyser #if defined(CONFIG_MCFTMR) dtimer_intr_setup(void)27a4145534SPeter Tyservoid dtimer_intr_setup(void) 28a4145534SPeter Tyser { 29aa0d99fcSAlison Wang int0_t *intp = (int0_t *) (CONFIG_SYS_INTR_BASE); 30a4145534SPeter Tyser 31aa0d99fcSAlison Wang out_8(&intp->icr0[CONFIG_SYS_TMRINTR_NO], CONFIG_SYS_TMRINTR_PRI); 32aa0d99fcSAlison Wang clrbits_be32(&intp->imrh0, CONFIG_SYS_TMRINTR_MASK); 33a4145534SPeter Tyser } 34a4145534SPeter Tyser #endif 35