168156ad9STijl Coosemans /*- 2*51369649SPedro F. Giffuni * SPDX-License-Identifier: BSD-3-Clause 3*51369649SPedro F. Giffuni * 468156ad9STijl Coosemans * Copyright (c) 1990 The Regents of the University of California. 568156ad9STijl Coosemans * All rights reserved. 668156ad9STijl Coosemans * 768156ad9STijl Coosemans * This code is derived from software contributed to Berkeley by 868156ad9STijl Coosemans * William Jolitz. 968156ad9STijl Coosemans * 1068156ad9STijl Coosemans * Redistribution and use in source and binary forms, with or without 1168156ad9STijl Coosemans * modification, are permitted provided that the following conditions 1268156ad9STijl Coosemans * are met: 1368156ad9STijl Coosemans * 1. Redistributions of source code must retain the above copyright 1468156ad9STijl Coosemans * notice, this list of conditions and the following disclaimer. 1568156ad9STijl Coosemans * 2. Redistributions in binary form must reproduce the above copyright 1668156ad9STijl Coosemans * notice, this list of conditions and the following disclaimer in the 1768156ad9STijl Coosemans * documentation and/or other materials provided with the distribution. 18fbbd9655SWarner Losh * 3. Neither the name of the University nor the names of its contributors 1968156ad9STijl Coosemans * may be used to endorse or promote products derived from this software 2068156ad9STijl Coosemans * without specific prior written permission. 2168156ad9STijl Coosemans * 2268156ad9STijl Coosemans * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 2368156ad9STijl Coosemans * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 2468156ad9STijl Coosemans * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 2568156ad9STijl Coosemans * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 2668156ad9STijl Coosemans * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 2768156ad9STijl Coosemans * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 2868156ad9STijl Coosemans * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 2968156ad9STijl Coosemans * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 3068156ad9STijl Coosemans * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 3168156ad9STijl Coosemans * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 3268156ad9STijl Coosemans * SUCH DAMAGE. 3368156ad9STijl Coosemans */ 3468156ad9STijl Coosemans 3568156ad9STijl Coosemans #ifndef _MACHINE_PSL_H_ 3668156ad9STijl Coosemans #define _MACHINE_PSL_H_ 3768156ad9STijl Coosemans 3868156ad9STijl Coosemans /* 3968156ad9STijl Coosemans * 386 processor status longword. 4068156ad9STijl Coosemans */ 4168156ad9STijl Coosemans #define PSL_C 0x00000001 /* carry bit */ 4268156ad9STijl Coosemans #define PSL_PF 0x00000004 /* parity bit */ 4368156ad9STijl Coosemans #define PSL_AF 0x00000010 /* bcd carry bit */ 4468156ad9STijl Coosemans #define PSL_Z 0x00000040 /* zero bit */ 4568156ad9STijl Coosemans #define PSL_N 0x00000080 /* negative bit */ 4668156ad9STijl Coosemans #define PSL_T 0x00000100 /* trace enable bit */ 4768156ad9STijl Coosemans #define PSL_I 0x00000200 /* interrupt enable bit */ 4868156ad9STijl Coosemans #define PSL_D 0x00000400 /* string instruction direction bit */ 4968156ad9STijl Coosemans #define PSL_V 0x00000800 /* overflow bit */ 5068156ad9STijl Coosemans #define PSL_IOPL 0x00003000 /* i/o privilege level */ 5168156ad9STijl Coosemans #define PSL_NT 0x00004000 /* nested task bit */ 5268156ad9STijl Coosemans #define PSL_RF 0x00010000 /* resume flag bit */ 5368156ad9STijl Coosemans #define PSL_VM 0x00020000 /* virtual 8086 mode bit */ 5468156ad9STijl Coosemans #define PSL_AC 0x00040000 /* alignment checking */ 5568156ad9STijl Coosemans #define PSL_VIF 0x00080000 /* virtual interrupt enable */ 5668156ad9STijl Coosemans #define PSL_VIP 0x00100000 /* virtual interrupt pending */ 5768156ad9STijl Coosemans #define PSL_ID 0x00200000 /* identification bit */ 5868156ad9STijl Coosemans 5968156ad9STijl Coosemans /* 6068156ad9STijl Coosemans * The i486 manual says that we are not supposed to change reserved flags, 6168156ad9STijl Coosemans * but this is too much trouble since the reserved flags depend on the cpu 6268156ad9STijl Coosemans * and setting them to their historical values works in practice. 6368156ad9STijl Coosemans */ 6468156ad9STijl Coosemans #define PSL_RESERVED_DEFAULT 0x00000002 6568156ad9STijl Coosemans 6668156ad9STijl Coosemans /* 6768156ad9STijl Coosemans * Initial flags for kernel and user mode. The kernel later inherits 6868156ad9STijl Coosemans * PSL_I and some other flags from user mode. 6968156ad9STijl Coosemans */ 7068156ad9STijl Coosemans #define PSL_KERNEL PSL_RESERVED_DEFAULT 7168156ad9STijl Coosemans #define PSL_USER (PSL_RESERVED_DEFAULT | PSL_I) 7268156ad9STijl Coosemans 7368156ad9STijl Coosemans /* 7468156ad9STijl Coosemans * Bits that can be changed in user mode on 486's. We allow these bits 7568156ad9STijl Coosemans * to be changed using ptrace(), sigreturn() and procfs. Setting PS_NT 7668156ad9STijl Coosemans * is undesirable but it may as well be allowed since users can inflict 7768156ad9STijl Coosemans * it on the kernel directly. Changes to PSL_AC are silently ignored on 7868156ad9STijl Coosemans * 386's. 793d271aaaSEd Maste * 803d271aaaSEd Maste * Users are allowed to change the privileged flag PSL_RF. The cpu sets PSL_RF 813d271aaaSEd Maste * in tf_eflags for faults. Debuggers should sometimes set it there too. 823d271aaaSEd Maste * tf_eflags is kept in the signal context during signal handling and there is 833d271aaaSEd Maste * no other place to remember it, so the PSL_RF bit may be corrupted by the 843d271aaaSEd Maste * signal handler without us knowing. Corruption of the PSL_RF bit at worst 853d271aaaSEd Maste * causes one more or one less debugger trap, so allowing it is fairly 863d271aaaSEd Maste * harmless. 8768156ad9STijl Coosemans */ 8868156ad9STijl Coosemans #define PSL_USERCHANGE (PSL_C | PSL_PF | PSL_AF | PSL_Z | PSL_N | PSL_T \ 893d271aaaSEd Maste | PSL_D | PSL_V | PSL_NT | PSL_RF | PSL_AC | PSL_ID) 9068156ad9STijl Coosemans 9168156ad9STijl Coosemans #endif /* !_MACHINE_PSL_H_ */ 92