/**************************************************************************** * * SciTech OS Portability Manager Library * * ======================================================================== * * The contents of this file are subject to the SciTech MGL Public * License Version 1.0 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.scitechsoft.com/mgl-license.txt * * Software distributed under the License is distributed on an * "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or * implied. See the License for the specific language governing * rights and limitations under the License. * * The Original Code is Copyright (C) 1991-1998 SciTech Software, Inc. * * The Initial Developer of the Original Code is SciTech Software, Inc. * All Rights Reserved. * * ======================================================================== * * Language: ANSI C * Environment: any * * Description: Test program to check the ability to call a real mode * procedure. We simply copy a terribly simple assembly * language routine into a real mode block that we allocate, * and then attempt to call the routine and verify that it * was successful. * * Functions tested: PM_allocRealSeg() * PM_freeRealSeg() * PM_callRealMode() * ****************************************************************************/ #include #include #include #include "pmapi.h" /* Block of real mode code we will eventually call */ static unsigned char realModeCode[] = { 0x93, /* xchg ax,bx */ 0x87, 0xCA, /* xchg cx,dx */ 0xCB /* retf */ }; int main(void) { RMREGS regs; RMSREGS sregs; uchar *p; unsigned r_seg,r_off; printf("Program running in "); switch (PM_getModeType()) { case PM_realMode: printf("real mode.\n\n"); break; case PM_286: printf("16 bit protected mode.\n\n"); break; case PM_386: printf("32 bit protected mode.\n\n"); break; } /* Allocate a the block of real mode memory */ if ((p = PM_allocRealSeg(sizeof(realModeCode), &r_seg, &r_off)) == NULL) { printf("Unable to allocate real mode memory!\n"); exit(1); } /* Copy the real mode code */ memcpy(p,realModeCode,sizeof(realModeCode)); /* Now call the real mode code */ regs.x.ax = 1; regs.x.bx = 2; regs.x.cx = 3; regs.x.dx = 4; regs.x.si = 5; regs.x.di = 6; sregs.es = 7; sregs.ds = 8; PM_callRealMode(r_seg,r_off,®s,&sregs); if (regs.x.ax != 2 || regs.x.bx != 1 || regs.x.cx != 4 || regs.x.dx != 3 || regs.x.si != 5 || regs.x.di != 6 || sregs.es != 7 || sregs.ds != 8) { printf("Real mode call failed!\n"); printf("\n"); printf("ax = %04X, bx = %04X, cx = %04X, dx = %04X\n", regs.x.ax,regs.x.bx,regs.x.cx,regs.x.dx); printf("si = %04X, di = %04X, es = %04X, ds = %04X\n", regs.x.si,regs.x.di,sregs.es,sregs.ds); } else printf("Real mode call succeeded!\n"); /* Free the memory we allocated */ PM_freeRealSeg(p); return 0; }