home *** CD-ROM | disk | FTP | other *** search
/ Virtual Reality Zone / VRZONE.ISO / mac / PC / PCGLOVE / GLOVE / OBJGLV.ZIP / SRC / DPRC_TSR.TXT < prev    next >
Internet Message Format  |  1992-09-28  |  5KB

  1. Date:  27-Aug-92 21:23 EDT
  2. From:  D. P. Research Corp [75530,3041]
  3. Subj:  Early TSR specs (sent to shannon)
  4.  
  5. [The following is the content of one of the DPRC source documents
  6. used as a specification for our own people to write VR input device drivers under MS-DOS.  Additional comments added in [].
  7.  
  8. Since DPRC is not in the driver business nor does it wish to be, the release of this document into the public domain does not constitute a breach of confidentiality.]
  9.  
  10.  
  11.  
  12.     Generic/high-level input device driver spec
  13.                      for DOS platforms
  14.  
  15.  
  16.  
  17. Circulated:    12-1-91
  18.  
  19. Prologue
  20.  
  21.     Likely the simulation group [of DPRC] building code for prototyping on low-end PCs will need to pick up inputs from many devices.  Some of the many input devices are also output devices (or may have "scales of operation"/temperature ranges/etc).
  22.  
  23.     Since we do not want to spend alot of time writing drivers for the plethora of devices out there, it would behove us to define an interface which allows us to switch out old devices and in new ones without recompiling or relinking the core code for our renderers.
  24.  
  25.  
  26. Considerations
  27.  
  28.    In everyday use the user community may not necessarily have (or want to use) keyboards.  Joysticks may be limited but they have analogues if their "positions" are actually the encoding of body [or body suit] switches.
  29.  
  30.  
  31. Desired traits
  32.  
  33.     - different drivers should be loadable before application starts; user of drivers should not need to know how to "program" other than setting IO port addr for driver (and only if absolutely not defaultable)
  34.  
  35.     - drivers should "layer"/nest using exec/system(). pure TSR not needed;    layers should remove themselves when application finishes;    layering order is allowed to be important
  36.  
  37.     - more than one input device may be used; each should be able to send its own commands;each can load table (and reload tables) of translations; which map movements to gestures/commands
  38.  
  39.     - commands (gestures recognized by drivers) are 4 byte strings packed into a long (unique in first 4). command lists will initially be loaded as part of executable and we will use toolbox to fix-up prototypes.
  40.  
  41.     - lowest layer driver is driver VR-bios (so drivers have common debug/printf/file IO layer) to use as a "library"; base library has own int 2F register/unregister section. it registers a "VR bios" as its key; to register start with ah of unused value (relative to undocumented DOS book) and move upward; 
  42.  
  43.     - code to register/check if VR bios is loaded yet is separate C callable obj file for others to link with (using C or C++). make it MSC|TC|ZTC callable; base lib is list of fn-ptrs as call-ins; fn ptrs can be rewritten by drivers of another layer; use macro-include file to define common IO funcs to look like plain C callables
  44.  
  45.     - application registers "callback" delay function with driver for use in chewing up time, callback is called during calibration to determine machine speed for sw loops; callback delay function can poll IO ports, do partial repetitive calcs etc. called with number of "steps" to take. each step roughly equal size.
  46.  
  47.     - driver should return callback function to be used by app to obtain current driver specific info plus generic 6dof info & cmd
  48.  
  49.     - driver called by app at unpredictable intervals. driver must maintain current state inside itself. driver is allowed to use 18.2hz and 1msec hooks to calibrate and setup as well as run. will recalibrate whenever app layer registers new delay callback.
  50.  
  51.     - current viewport/viewing origin/orientation is an "input" device which can be modified/talked to by other layers (certain actions/reactions will force it to re-orient) also consider head trackers (or HMDs)
  52.  
  53.     - change-delta notification callback to app when motions exceed registerd threshold;  thresholds expressed in % of device value range as scaled int
  54.  
  55.  
  56.  
  57.  
  58. Potential input devices on PC platforms
  59.  
  60.     mouse               keyboard (consider key groups sep)
  61.     trackball           2 joysticks in periscope-lever orientation
  62.     spaceball           IR movement sensor
  63.     3d mouse            ulrasonic position sensor
  64.     temp sensors        head orientation tracker        
  65.     3d-boom             adrenal activity detector 
  66.     heart rate encoder  body salts encoder
  67.     hall-effect sensor  galvanomic/static displacement sensors
  68.     alpha wave encoder  whistle/clap detector
  69.     pedalo speed sense  body-english/weight shift sensor
  70.     muscle-flex scanner centripital effect sensor
  71.     voice recog circuit/chip/(may require sep PC)           
  72.     chemical composition/ph/ionic concentration sensors
  73.    
  74.