162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * OpenRISC irq.c
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Linux architectural port borrowing liberally from similar works of
662306a36Sopenharmony_ci * others.  All original copyrights apply as per the original source
762306a36Sopenharmony_ci * declaration.
862306a36Sopenharmony_ci *
962306a36Sopenharmony_ci * Modifications for the OpenRISC architecture:
1062306a36Sopenharmony_ci * Copyright (C) 2010-2011 Jonas Bonn <jonas@southpole.se>
1162306a36Sopenharmony_ci */
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_ci#include <linux/interrupt.h>
1462306a36Sopenharmony_ci#include <linux/init.h>
1562306a36Sopenharmony_ci#include <linux/ftrace.h>
1662306a36Sopenharmony_ci#include <linux/irq.h>
1762306a36Sopenharmony_ci#include <linux/irqchip.h>
1862306a36Sopenharmony_ci#include <linux/export.h>
1962306a36Sopenharmony_ci#include <linux/irqflags.h>
2062306a36Sopenharmony_ci
2162306a36Sopenharmony_ci/* read interrupt enabled status */
2262306a36Sopenharmony_ciunsigned long arch_local_save_flags(void)
2362306a36Sopenharmony_ci{
2462306a36Sopenharmony_ci	return mfspr(SPR_SR) & (SPR_SR_IEE|SPR_SR_TEE);
2562306a36Sopenharmony_ci}
2662306a36Sopenharmony_ciEXPORT_SYMBOL(arch_local_save_flags);
2762306a36Sopenharmony_ci
2862306a36Sopenharmony_ci/* set interrupt enabled status */
2962306a36Sopenharmony_civoid arch_local_irq_restore(unsigned long flags)
3062306a36Sopenharmony_ci{
3162306a36Sopenharmony_ci	mtspr(SPR_SR, ((mfspr(SPR_SR) & ~(SPR_SR_IEE|SPR_SR_TEE)) | flags));
3262306a36Sopenharmony_ci}
3362306a36Sopenharmony_ciEXPORT_SYMBOL(arch_local_irq_restore);
3462306a36Sopenharmony_ci
3562306a36Sopenharmony_civoid __init init_IRQ(void)
3662306a36Sopenharmony_ci{
3762306a36Sopenharmony_ci	irqchip_init();
3862306a36Sopenharmony_ci}
39