en:docs:fapi:viosetstate

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Next revision
Previous revision
en:docs:fapi:viosetstate [2021/09/05 06:20] – created prokusheven:docs:fapi:viosetstate [2021/11/04 12:45] (current) prokushev
Line 1: Line 1:
 +{{page>en:templates:fapiint}}
 +
 +====== VioSetState ======
 +
 This call performs one of the following functions; set palette registers, sets the overscan (border) colour, set the blink/background intensity switch, set color registers, set the underline location, or set the target VioSetMode display configuration. This call performs one of the following functions; set palette registers, sets the overscan (border) colour, set the blink/background intensity switch, set color registers, set the underline location, or set the target VioSetMode display configuration.
  
-==Syntax==+===== Syntax ===== 
 +<code c>
  VioSetState (RequestBlock, VioHandle)  VioSetState (RequestBlock, VioHandle)
 +</code>
 +===== Parameters =====
 +
 +  * RequestBlock (PVOID) - input : Address of the video state structures consisting of six different structures depending on the request type:
 +    * 0 - Set palette registers
 +    * 1 - Set overscan (border) color 
 +    * 2 - Set blink/background intensity switch 
 +    * 3 - Set color registers 
 +    * 4 - Reserved 
 +    * 5 - Set underline location 
 +    * 6 - Set target VioSetMode display configuration 
 +    * 7 - Reserved
  
-==Parameters== 
-;RequestBlock (PVOID) - input : Address of the video state structures consisting of six different structures depending on the request type: 
-::0 - Set palette registers 
-::1 - Set overscan (border) color  
-::2 - Set blink/background intensity switch  
-::3 - Set color registers  
-::4 - Reserved  
-::5 - Set underline location  
-::6 - Set target VioSetMode display configuration  
-::7 - Reserved 
 The six structures, depending on request type, are: The six structures, depending on request type, are:
-{|class="wikitable" 
-! ||Applies to||length (USHORT) - input : Length of structure, including length.||reqtype (USHORT) - input|| 
-|- 
-|VIOPALSTATE||EGA, VGA, or IBM Personal System/2 Display Adapter||38 - Maximum valid value.||Request type 0 for palette registers.|| 
-:palette (USHORT) - input: First palette register in the palette register sequence; must be specified in the range 0 through 15. The palette registers are returned in sequential order. The number returned is based upon length. 
-:color (USHORT*(length-6)/2) - input : Color value for each palette register. The maximum number of entries in the color value array is 16. 
-|- 
-|VIOOVERSCAN||CGA, VGA, or IBM Personal System/2 Display Adapter||Only valid value.||Request type 1 for overscan (border) color.||Color value. 
-|- 
-|VIOINTENSITY||CGA, EGA, MCGA, VGA, or IBM Personal System/2 Display Adapter||Only valid value.||Request type 2 for blink/background intensity switch.|| 
-:switch (USHORT) - input : Switch set as: 
-::0 - Blinking foreground colors enabled. 
-::1 - High intensity background colors enabled. 
-|- 
-|VIOCOLORREG||VGA, or IBM Personal System/2 Display Adapter||12 - Only valid value.||Request type 3 for color registers.|| 
-:first color (USHORT) - input : First color register to set in the color register sequence; must be specified in the range 0 through 255. The color registers are set in sequential order. 
-:number color (USHORT) - input : Number of color registers to set; must be specified in the range 1 through 256. 
-:datarea (PCH) - input : Far address of a data area containing one three-byte entry for each color register to be set. The format of each entry is as follows: 
-::Byte 1 - Red value 
-::Byte 2 - Green value 
-::Byte 3 - Blue value 
-|- 
-| || || ||4|| 
-|- 
-|VIOSETULINELOC||EGA, VGA, or IBM Personal System/2 Display Adapter||Only valid value.||Request type 5 to set the scan line for underlining. Underlining is enabled only when the foreground color is 1 or 9.|| 
-:scanline (USHORT) - input : Scan line minus 1. Values of 0 through 31 are acceptable. A value of 32 means underlining is disabled.  
-|- 
-|VIOSETTARGET|| ||Only valid value.||Request type 6 to set display configuration to be the target of the next VioSetMode.|| 
-:select (USHORT) - input : Configuration: 
-::0 - Default selection algorithm. See VioSetMode. 
-::1 - Primary 
-::2 - Secondary 
-|} 
-;VioHandle (HVIO) - input : Reserved word of 0s. 
  
-==Return Code==+^ ^ Applies to  ^ length (USHORT) - input : Length of structure, including length. ^ reqtype (USHORT) - input ^ ^ 
 +| VIOPALSTATE | EGA, VGA, or IBM Personal System/2 Display Adapter | 38 - Maximum valid value  |Request type 0 for palette registers | palette (USHORT) - input: First palette register in the palette register sequence; must be specified in the range 0 through 15. The palette registers are returned in sequential order. The number returned is based upon length. | 
 +| ::: | ::: | ::: | ::: | color (USHORT*(length-6)/2) - input : Color value for each palette register. The maximum number of entries in the color value array is 16 | 
 +|VIOOVERSCAN|CGA, VGA, or IBM Personal System/2 Display Adapter|Only valid value.|Request type 1 for overscan (border) color.|Color value. | 
 +|VIOINTENSITY|CGA, EGA, MCGA, VGA, or IBM Personal System/2 Display Adapter|Only valid value.|Request type 2 for blink/background intensity switch.| switch (USHORT) - input : Switch set as: | 
 +| ::: | ::: | ::: | ::: | 0 - Blinking foreground colors enabled. | 
 +| ::: | ::: | ::: | ::: | 1 - High intensity background colors enabled. | 
 +|VIOCOLORREG|VGA, or IBM Personal System/2 Display Adapter|12 - Only valid value.|Request type 3 for color registers.| first color (USHORT) - input : First color register to set in the color register sequence; must be specified in the range 0 through 255. The color registers are set in sequential order. | 
 +| ::: | ::: | ::: | ::: |number color (USHORT) - input : Number of color registers to set; must be specified in the range 1 through 256. | 
 +| ::: | ::: | ::: | ::: |datarea (PCH) - input : Far address of a data area containing one three-byte entry for each color register to be set. The format of each entry is as follows: | 
 +| ::: | ::: | ::: | ::: |Byte 1 - Red value | 
 +| ::: | ::: | ::: | ::: |Byte 2 - Green value | 
 +| ::: | ::: | ::: | ::: |Byte 3 - Blue value | 
 +|VIOSETULINELOC|EGA, VGA, or IBM Personal System/2 Display Adapter|Only valid value.|Request type 5 to set the scan line for underlining. Underlining is enabled only when the foreground color is 1 or 9.| scanline (USHORT) - input : Scan line minus 1. Values of 0 through 31 are acceptable. A value of 32 means underlining is disabled. | 
 +|VIOSETTARGET| |Only valid value.|Request type 6 to set display configuration to be the target of the next VioSetMode.| :select (USHORT) - input : Configuration:
 +| ::: | ::: | ::: | ::: | 0 - Default selection algorithm. See VioSetMode. | 
 +| ::: | ::: | ::: | ::: | 1 - Primary | 
 +| ::: | ::: | ::: | ::: | 2 - Secondary | 
 + 
 +  * VioHandle (HVIO) - input : Reserved word of 0s. 
 + 
 +===== Return Code ===== 
 ;rc (USHORT) - return:Return code descriptions are: ;rc (USHORT) - return:Return code descriptions are:
 *0 NO_ERROR *0 NO_ERROR
Line 60: Line 55:
 *494 ERROR_VIO_EXTENDED_SG *494 ERROR_VIO_EXTENDED_SG
  
-===Family API Considerations===+===== Remarks ===== 
 + 
 +==== Family API Considerations ===
 Request type = 6, Set Target VioSetMode Display Configuration, and request type = 5, Request type = 6, Set Target VioSetMode Display Configuration, and request type = 5,
 Set Underline Location, are not supported in the family API. Set Underline Location, are not supported in the family API.
  
 Some options operate differently in the DOS mode than in the OS/2 mode. Therefore, the following considerations applies to VioSetMode when coding for the DOS mode: Some options operate differently in the DOS mode than in the OS/2 mode. Therefore, the following considerations applies to VioSetMode when coding for the DOS mode:
-* VioSetMode clears the screen. 
  
-==Bindings== +  * VioSetMode clears the screen. 
-=== C === + 
-<PRE>+===== Bindings ===== 
 + 
 +==== C ==== 
 +<code c>
 typedef struct _VIOPALSTATE { typedef struct _VIOPALSTATE {
   USHORT  cb;                   /* Length of this structure in bytes */   USHORT  cb;                   /* Length of this structure in bytes */
Line 125: Line 125:
  
 USHORT           rc;            /* return code */ USHORT           rc;            /* return code */
-</PRE>+</code>
  
-===MASM=== +====MASM==== 
-<PRE>+<code asm>
 VIOPALSTATE struc VIOPALSTATE struc
   viopal_cb               dw ? ;Length of this structure in bytes   viopal_cb               dw ? ;Length of this structure in bytes
Line 177: Line 177:
  
 Returns WORD Returns WORD
-</PRE>+</code>
  
 [[http://www.edm2.com/index.php/VioSetState_(OS/2_1.x)]] [[http://www.edm2.com/index.php/VioSetState_(OS/2_1.x)]]
 +
 +{{page>en:templates:fapi}}