home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: 10 Tools / 10-Tools.zip / kernex32.zip / mwdd_src.zip / 32bits / ext2-os2 / skeleton / basedev / drv32_strategy.c < prev    next >
C/C++ Source or Header  |  1997-03-16  |  3KB  |  90 lines

  1. //
  2. // $Header: d:\\32bits\\ext2-os2\\skeleton\\basedev\\rcs\\drv32_strategy.c,v 1.3 1997/03/16 12:51:42 Willm Exp $
  3. //
  4.  
  5. // 32 bits OS/2 device driver and IFS support. Provides 32 bits kernel 
  6. // services (DevHelp) and utility functions to 32 bits OS/2 ring 0 code 
  7. // (device drivers and installable file system drivers).
  8. // Copyright (C) 1995, 1996, 1997  Matthieu WILLM (willm@ibm.net)
  9. //
  10. // This program is free software; you can redistribute it and/or modify
  11. // it under the terms of the GNU General Public License as published by
  12. // the Free Software Foundation; either version 2 of the License, or
  13. // (at your option) any later version.
  14. //
  15. // This program is distributed in the hope that it will be useful,
  16. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  18. // GNU General Public License for more details.
  19. //
  20. // You should have received a copy of the GNU General Public License
  21. // along with this program; if not, write to the Free Software
  22. // Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  23.  
  24. #define INCL_DOSERRORS
  25. #define INCL_DOS
  26. #define INCL_NOPMAPI
  27. #include <os2.h>
  28.  
  29. #include <os2/types.h>
  30. #include <os2/devhlp32.h>
  31. #include <reqpkt32.h>
  32.  
  33. #include "drv32_entry_points.h"
  34.  
  35. static int (*driver_routing_table[32])() = {
  36.     drv32_invalid_command,  // 0 = Init
  37.     drv32_invalid_command,  // 1 = Media Check
  38.     drv32_invalid_command,  // 2 = Build BPB
  39.     drv32_invalid_command,  // 3 = Reserved
  40.     drv32_read,             // 4 = Read
  41.     drv32_invalid_command,  // 5 = Non-Destruct Read NoWait
  42.     drv32_invalid_command,  // 6 = Input Status
  43.     drv32_invalid_command,  // 7 = Input Flush
  44.     drv32_write,            // 8 = Write
  45.     drv32_invalid_command,  // 9 = Write w/Verify
  46.     drv32_invalid_command,  // A = Output Status
  47.     drv32_invalid_command,  // B = Output Flush
  48.     drv32_invalid_command,  // C = Reserved
  49.     drv32_open,             // D = Device Open (R/M)
  50.     drv32_close,            // E = Device Close (R/M)
  51.     drv32_invalid_command,  // F = Removable Media (R/M)
  52.     drv32_ioctl,            // 10 = Generic Ioctl
  53.     drv32_invalid_command,  // 11 = Reset Media
  54.     drv32_invalid_command,  // 12 = Get Logical Drive Map
  55.     drv32_invalid_command,  // 13 = Set Logical Drive Map
  56.     drv32_invalid_command,  // 14 = DeInstall
  57.     drv32_invalid_command,  // 15 = 
  58.     drv32_invalid_command,  // 16 = Get # Partitions
  59.     drv32_invalid_command,  // 17 = Get Unit map
  60.     drv32_invalid_command,  // 18 = No caching read
  61.     drv32_invalid_command,  // 19 = No caching write
  62.     drv32_invalid_command,  // 1A = No caching write w/Verify
  63.     drv32_init_base,        // 1B = Initialize
  64.     drv32_shutdown,         // 1C = Shutdown
  65.     drv32_invalid_command,  // 1D = Get DCS/VCS
  66.     drv32_invalid_command,  // 1E = ???
  67.     drv32_init_complete     // 1F = Init Complete
  68. };
  69.  
  70.  
  71. /*
  72.  * This is the 32 bits strategy entry point
  73.  */
  74. int DRV32ENTRY drv32_strategy(PTR16 reqpkt, int index) {
  75.     int status;
  76.  
  77.     if (index < sizeof(driver_routing_table) / sizeof(*driver_routing_table)) {
  78.         /*
  79.          * Valid command received
  80.          */
  81.         status = driver_routing_table[index](reqpkt);
  82.     } else {
  83.         /*
  84.          * Invalid command received
  85.          */
  86.         status = STDON + STERR + ERROR_I24_INVALID_PARAMETER;
  87.     }
  88.     return status;
  89. }
  90.