summaryrefslogtreecommitdiffstats
path: root/linux
diff options
context:
space:
mode:
authornick <nick@b3059339-0415-0410-9bf9-f77b7e298cf2>2001-10-30 16:17:07 +0000
committernick <nick@b3059339-0415-0410-9bf9-f77b7e298cf2>2001-10-30 16:17:07 +0000
commit38f0f99daa4d7bab4cad4827561eab25b7ffbf9f (patch)
treebd7c434bee5a4f853c9c17e393c25cdd68ddf567 /linux
parenta6edfc86dbe1f63833da455ab7512a5cc75a957d (diff)
downloadmpv-38f0f99daa4d7bab4cad4827561eab25b7ffbf9f.tar.bz2
mpv-38f0f99daa4d7bab4cad4827561eab25b7ffbf9f.tar.xz
Misc: more checks
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@2553 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'linux')
-rw-r--r--linux/vbelib.c10
1 files changed, 8 insertions, 2 deletions
diff --git a/linux/vbelib.c b/linux/vbelib.c
index c21d3c683d..b2376ef06d 100644
--- a/linux/vbelib.c
+++ b/linux/vbelib.c
@@ -88,6 +88,7 @@ int vbeInit( void )
{
unsigned short iopl_port;
size_t i;
+ int retval;
if(!LRMI_init()) return VBE_VM86_FAIL;
/*
Allow read/write to ALL io ports
@@ -99,9 +100,11 @@ int vbeInit( void )
ioperm(0, 1024, 1);
iopl(3);
memset(&vbe_pm_info,0,sizeof(struct VesaProtModeInterface));
- vbeGetProtModeInfo(&vbe_pm_info);
+ retval = vbeGetProtModeInfo(&vbe_pm_info);
+ if(retval != VBE_OK) return retval;
i = 0;
- while((iopl_port=vbe_pm_info.iopl_ports[i++]) != 0xFFFF) ioperm(iopl_port,1,1);
+ while((iopl_port=vbe_pm_info.iopl_ports[i]) != 0xFFFF
+ && vbe_pm_info.iopl_ports[i++] > 1023) ioperm(iopl_port,1,1);
iopl(3);
return VBE_OK;
}
@@ -451,14 +454,17 @@ int vbeGetProtModeInfo(struct VesaProtModeInterface *pm_info)
if((r.es >> 12) != hh_int_10_seg) retval = VBE_BROKEN_BIOS;
rm_info = PhysToVirtSO(r.es,info_offset);
pm_info->SetWindowCall = PhysToVirtSO(r.es,info_offset+rm_info->SetWindowCall);
+ if(!is_addr_valid(pm_info->SetWindowCall)) retval = VBE_BROKEN_BIOS;
#ifdef HAVE_VERBOSE_VAR
if(verbose > 1) printf("vbelib: SetWindowCall=%04X:%04X => %p\n",r.es,info_offset+rm_info->SetWindowCall,pm_info->SetWindowCall);
#endif
pm_info->SetDisplayStart = PhysToVirtSO(r.es,info_offset+rm_info->SetDisplayStart);
+ if(!is_addr_valid(pm_info->SetDisplayStart)) retval = VBE_BROKEN_BIOS;
#ifdef HAVE_VERBOSE_VAR
if(verbose > 1) printf("vbelib: SetDisplayStart=%04X:%04X => %p\n",r.es,info_offset+rm_info->SetDisplayStart,pm_info->SetDisplayStart);
#endif
pm_info->SetPaletteData = PhysToVirtSO(r.es,info_offset+rm_info->SetPaletteData);
+ if(!is_addr_valid(pm_info->SetPaletteData)) retval = VBE_BROKEN_BIOS;
#ifdef HAVE_VERBOSE_VAR
if(verbose > 1) printf("vbelib: SetPaletteData=%04X:%04X => %p\n",r.es,info_offset+rm_info->SetPaletteData,pm_info->SetPaletteData);
#endif