0N/A
0N/A/*
0N/A * Copyright (c) 1999-2002 by The XFree86 Project, Inc.
0N/A *
0N/A * Permission is hereby granted, free of charge, to any person obtaining a
0N/A * copy of this software and associated documentation files (the "Software"),
0N/A * to deal in the Software without restriction, including without limitation
0N/A * the rights to use, copy, modify, merge, publish, distribute, sublicense,
0N/A * and/or sell copies of the Software, and to permit persons to whom the
0N/A * Software is furnished to do so, subject to the following conditions:
0N/A *
0N/A * The above copyright notice and this permission notice shall be included in
0N/A * all copies or substantial portions of the Software.
0N/A *
0N/A * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
0N/A * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
0N/A * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
0N/A * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
873N/A * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
0N/A * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
0N/A * OTHER DEALINGS IN THE SOFTWARE.
0N/A *
0N/A * Except as contained in this notice, the name of the copyright holder(s)
0N/A * and author(s) shall not be used in advertising or otherwise to promote
3231N/A * the sale, use or other dealings in this Software without prior written
0N/A * authorization from the copyright holder(s) and author(s).
0N/A */
0N/A
0N/A#ifndef _XF86_RESOURCES_H
4134N/A
0N/A#define _XF86_RESOURCES_H
4134N/A
4134N/A#include "xf86str.h"
0N/A
1177N/A#define _END {ResEnd,0,0}
1400N/A
0N/A#define _VGA_EXCLUSIVE \
0N/A {ResExcMemBlock | ResBios | ResBus, 0x000A0000, 0x000AFFFF},\
0N/A {ResExcMemBlock | ResBios | ResBus, 0x000B0000, 0x000B7FFF},\
0N/A {ResExcMemBlock | ResBios | ResBus, 0x000B8000, 0x000BFFFF},\
0N/A {ResExcIoBlock | ResBios | ResBus, 0x03B0, 0x03BB},\
0N/A {ResExcIoBlock | ResBios | ResBus, 0x03C0, 0x03DF}
0N/A
0N/A#define _VGA_SHARED \
0N/A {ResShrMemBlock | ResBios | ResBus, 0x000A0000, 0x000AFFFF},\
0N/A {ResShrMemBlock | ResBios | ResBus, 0x000B0000, 0x000B7FFF},\
0N/A {ResShrMemBlock | ResBios | ResBus, 0x000B8000, 0x000BFFFF},\
0N/A {ResShrIoBlock | ResBios | ResBus, 0x03B0, 0x03BB},\
1400N/A {ResShrIoBlock | ResBios | ResBus, 0x03C0, 0x03DF}
1400N/A
1400N/A#define _VGA_SHARED_MEM \
1400N/A {ResShrMemBlock | ResBios | ResBus, 0x000A0000, 0x000AFFFF},\
1400N/A {ResShrMemBlock | ResBios | ResBus, 0x000B0000, 0x000B7FFF},\
0N/A {ResShrMemBlock | ResBios | ResBus, 0x000B8000, 0x000BFFFF}
4134N/A
0N/A#define _VGA_SHARED_IO \
0N/A {ResShrIoBlock | ResBios | ResBus, 0x03B0, 0x03BB},\
0N/A {ResShrIoBlock | ResBios | ResBus, 0x03C0, 0x03DF}
0N/A
0N/A/*
0N/A * Exclusive unused VGA: resources unneeded but cannot be disabled.
0N/A * Like old Millennium.
0N/A */
0N/A#define _VGA_EXCLUSIVE_UNUSED \
0N/A {ResExcUusdMemBlock | ResBios | ResBus, 0x000A0000, 0x000AFFFF},\
0N/A {ResExcUusdMemBlock | ResBios | ResBus, 0x000B0000, 0x000B7FFF},\
0N/A {ResExcUusdMemBlock | ResBios | ResBus, 0x000B8000, 0x000BFFFF},\
0N/A {ResExcUusdIoBlock | ResBios | ResBus, 0x03B0, 0x03BB},\
0N/A {ResExcUusdIoBlock | ResBios | ResBus, 0x03C0, 0x03DF}
0N/A
0N/A/*
0N/A * Shared unused VGA: resources unneeded but cannot be disabled
0N/A * independently. This is used to determine if a device needs RAC.
0N/A */
0N/A#define _VGA_SHARED_UNUSED \
0N/A {ResShrUusdMemBlock | ResBios | ResBus, 0x000A0000, 0x000AFFFF},\
0N/A {ResShrUusdMemBlock | ResBios | ResBus, 0x000B0000, 0x000B7FFF},\
0N/A {ResShrUusdMemBlock | ResBios | ResBus, 0x000B8000, 0x000BFFFF},\
0N/A {ResShrUusdIoBlock | ResBios | ResBus, 0x03B0, 0x03BB},\
0N/A {ResShrUusdIoBlock | ResBios | ResBus, 0x03C0, 0x03DF}
0N/A
0N/A/*
4134N/A * Sparse versions of the above for those adapters that respond to all ISA
0N/A * aliases of VGA ports.
0N/A */
0N/A#define _VGA_EXCLUSIVE_SPARSE \
0N/A {ResExcMemBlock | ResBios | ResBus, 0x000A0000, 0x000AFFFF},\
0N/A {ResExcMemBlock | ResBios | ResBus, 0x000B0000, 0x000B7FFF},\
0N/A {ResExcMemBlock | ResBios | ResBus, 0x000B8000, 0x000BFFFF},\
0N/A {ResExcIoSparse | ResBios | ResBus, 0x03B0, 0x03F8},\
0N/A {ResExcIoSparse | ResBios | ResBus, 0x03B8, 0x03FC},\
0N/A {ResExcIoSparse | ResBios | ResBus, 0x03C0, 0x03E0}
0N/A
0N/A#define _VGA_SHARED_SPARSE \
0N/A {ResShrMemBlock | ResBios | ResBus, 0x000A0000, 0x000AFFFF},\
0N/A {ResShrMemBlock | ResBios | ResBus, 0x000B0000, 0x000B7FFF},\
0N/A {ResShrMemBlock | ResBios | ResBus, 0x000B8000, 0x000BFFFF},\
0N/A {ResShrIoSparse | ResBios | ResBus, 0x03B0, 0x03F8},\
0N/A {ResShrIoSparse | ResBios | ResBus, 0x03B8, 0x03FC},\
0N/A {ResShrIoSparse | ResBios | ResBus, 0x03C0, 0x03E0}
0N/A
0N/A#define _8514_EXCLUSIVE \
0N/A {ResExcIoSparse | ResBios | ResBus, 0x02E8, 0x03F8}
0N/A
0N/A#define _8514_SHARED \
0N/A {ResShrIoSparse | ResBios | ResBus, 0x02E8, 0x03F8}
0N/A
0N/A/* Predefined resources */
4134N/Aextern resRange resVgaExclusive[];
0N/Aextern resRange resVgaShared[];
0N/Aextern resRange resVgaIoShared[];
0N/Aextern resRange resVgaMemShared[];
0N/Aextern resRange resVgaUnusedExclusive[];
0N/Aextern resRange resVgaUnusedShared[];
0N/Aextern resRange resVgaSparseExclusive[];
0N/Aextern resRange resVgaSparseShared[];
0N/Aextern resRange res8514Exclusive[];
0N/Aextern resRange res8514Shared[];
0N/A
0N/A/* Less misleading aliases for xf86SetOperatingState() */
0N/A#define resVgaMem resVgaMemShared
0N/A#define resVgaIo resVgaIoShared
0N/A#define resVga resVgaShared
0N/A
0N/A/* Old style names */
0N/A#define RES_EXCLUSIVE_VGA resVgaExclusive
0N/A#define RES_SHARED_VGA resVgaShared
0N/A#define RES_EXCLUSIVE_8514 res8514Exclusive
0N/A#define RES_SHARED_8514 res8514Shared
0N/A
0N/A#define _PCI_AVOID_PC_STYLE \
0N/A {ResExcIoSparse | ResBus, 0x0100, 0x0300},\
0N/A {ResExcIoSparse | ResBus, 0x0200, 0x0200},\
0N/A {ResExcMemBlock | ResBus, 0xA0000,0xFFFFF}
0N/A
0N/A#define RES_UNDEFINED NULL
0N/A#endif
0N/A