oskit/oskit-20020317/linux/shared/x86/s_intr.c

77 lines
1.5 KiB
C
Executable File

/*
* Copyright (c) 1996-2000 The University of Utah and the Flux Group.
*
* This file is part of the OSKit Linux Glue Libraries, which are free
* software, also known as "open source;" you can redistribute them and/or
* modify them under the terms of the GNU General Public License (GPL),
* version 2, as published by the Free Software Foundation (FSF).
*
* The OSKit 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 GPL for more details. You should have
* received a copy of the GPL along with the OSKit; see the file COPYING. If
* not, write to the FSF, 59 Temple Place #330, Boston, MA 02111-1307, USA.
*/
#include "osenv.h"
/*
* XXX: x86-specific.
*/
#define IF_FLAG 0x00000200
void
linux_cli()
{
osenv_intr_disable();
}
void
linux_sti()
{
osenv_intr_enable();
}
unsigned
linux_save_flags()
{
unsigned rc;
asm volatile("
pushfl
popl %0" : "=r" (rc));
rc &= ~IF_FLAG;
if (osenv_intr_enabled())
rc |= IF_FLAG;
return rc;
}
void
linux_restore_flags(unsigned flags)
{
/*
* XXX: Linux drivers only count on the interrupt enable bit
* being properly restored.
*/
if (flags & IF_FLAG)
osenv_intr_enable();
else
osenv_intr_disable();
}
unsigned
linux_save_flags_cli()
{
unsigned rc;
asm volatile("
pushfl
popl %0" : "=r" (rc));
rc &= ~IF_FLAG;
if (osenv_intr_save_disable())
rc |= IF_FLAG;
return rc;
}