1<html> 2<head> 3<title>Changes</title> 4</head> 5<body> 6<p><h2>Changes done for each driverversion:</h2></p> 7<p><h1>head (0.17-1, Rudolf)</h1></p> 8<ul> 9 <li><strong>General:</strong> 10 <ul> 11 <li>Fixed acceleration engine management regarding sync_to_token: no more updating glitches should occur now. 12 </ul> 13</ul> 14 15<p><h1>mga_driver 0.16 (Rudolf)</h1></p> 16<ul> 17 <li><strong>G450/G550:</strong> 18 <ul> 19 <li>Fixed CRTC1 DPMS fault introduced in V0.15 (which could result in turned-off/black screen on boot)! 20 </ul> 21 <li><strong>General:</strong> 22 <ul> 23 <li>Expanded modelist to include suggested modes above 1600x1200 upto 2048x1536 resolution: Done by Andrew Bachmann; 24 <li>CRTC timing restriction checking updated: Modelists exported adhere to every cards max. CRTC capability now: the oldest cards support upto and including 1600x1200, while the newest cards support upto and including 2048x1536 resolution. 25 </ul> 26</ul> 27<p><h1>mga_driver 0.15 (Rudolf)</h1></p> 28<ul> 29 <li><strong>G400/G400MAX:</strong> 30 <ul> 31 <li>Secondary head (maven) sync polarity programming fixed/implemented for monitor mode: this never worked correctly yet; 32 <li>Fixed TVout aspect ratio, size, position and distortions; also removed refreshrate dependancies. This means the PAL and NTSC Desktop modes 640x480, 800x600 and 1024x768 are fully OK now; 33 <li>Implemented the PAL and NTSC Video VCD and DVD TVout modes: being 640x480 and 720x480 for NTSC; 768x576 and 720x576 for PAL. Checkout the <a href="http://web.inter.nl.net/users/be-hold/BeOS/MGAdriver/tools.html#tools">tools</a> and <a href="http://web.inter.nl.net/users/be-hold/BeOS/MGAdriver/dvdvideo.html">VCD/DVD on TV</a> stuff; 34 <li>Checked out the overscanning rubbish visible on the top of the screen on the secondary head if spaces with virtual height are used. This cannot be fixed decently for monitor mode due to a MAVEN hardware design fault; fixed TVout modes via a vertical sync 'tweak' though. Also updated the workaround code for non-virtual and virtual-width-only modes to respect RAM size and non-accelerated modes; 35 <li>Updated ProposeMode RAM and virtual width requirement checks for dualhead modes. 36 </ul> 37 <li><strong>G450:</strong> 38 <ul> 39 <li>Updated ProposeMode RAM and virtual width requirement checks for dualhead modes; 40 <li>Added full DPMS support for secondary head; 41 <li>Disabled G400 MAVEN design fault workaround code as the new 'on die MAVEN' is OK. 42 </ul> 43 <li><strong>G550:</strong> 44 <ul> 45 <li>Updated ProposeMode RAM and virtual width requirement checks for dualhead modes; 46 <li>Added full DPMS support for secondary head; 47 <li>Disabled G400 MAVEN design fault workaround code as the new 'on die MAVEN' is OK. 48 </ul> 49 <li><strong>General:</strong> 50 <ul> 51 <li>Retrace sync fix: sync now actually happens during retrace; 52 <li>BWindowScreen R3-style function update for acceleration and page flipping/virtualscreens in apps ('Allegro' update): fixed cloning accelerants, fixed acceleration in clones; 53 <li>CRTC timing restriction checking updated; 54 <li>Kernel driver now signals abort on not being able to setup the INT routine instead of letting the machine freeze during accelerant initialisation; 55 <li>Primary head sync polarity programming fixed: this never worked correctly; 56 <li>Fixed/updated DPMS functionality on primary head as only part of it was working; 57 <li>DPMS compatibility update for use with sync_on_green: Secondary head DPMS remains operational; primary head will only blank the display while keeping it's sync in place; 58 <li>Modified the default settings file for use of the hardcursor ('hardcursor true'). It turns out BDirectWindow windowed mode needs this setting for it to be enabled ('Chart' demo app for instance). If you want a cursor on both heads using dualhead you need to change the settings file back to 'hardcursor false' yourself now. 59 </ul> 60</ul> 61<p><h1>mga_driver 0.14 (Rudolf)</h1></p> 62<ul> 63 <li><strong>Millenium I:</strong> 64 <ul> 65 <li>Enabled Millenium I support; 66 <li>Fixed the kernel driver for working Millenium I support; 67 <li>'Pins' V1 card-config BIOS test readout implemented: This is not useable yet due to lack of info; 68 <li>Implemented hardcursor support; 69 <li>Fixed 2D acceleration: added software adress linearisation switch; 70 <li>Fixed mode setup for 800x600 in 8, 15 and 16bit color, and 1600x1200 in 8 bit color by implementing framebuffer slopspace; 71 <li>Fixed output brightness (sync_on_green error); 72 <li>Fixed ScreenPrefs refreshrate trouble; 73 <li>Tuned BWindowScreen support (MOVE_DISPLAY syncs to retrace now). 74 </ul> 75 <li><strong>Millenium II:</strong> 76 <ul> 77 <li>Implemented hardcursor support; 78 <li>Fixed 2D acceleration problem: added software adress linearisation switch; 79 <li>Fixed mode setup for 800x600 in 8, 15 and 16bit color, and 1600x1200 in 8 bit color by implementing framebuffer slopspace; 80 <li>Fixed output brightness (sync_on_green error); 81 <li>Fixed ScreenPrefs refreshrate trouble; 82 <li>2D acceleration is operational now: removed read access on a write only register; 83 <li>Tuned BWindowScreen support (MOVE_DISPLAY syncs to retrace now). 84 </ul> 85 <li><strong>G100:</strong> 86 <ul> 87 <li>2D engine update (removed read access on a write only register): acceleration also works now if card is used as secondary videocard. 88 </ul> 89 <li><strong>G200:</strong> 90 <ul> 91 <li>Improved overlay support for virtual workspaces (will improve more later on). 92 </ul> 93 <li><strong>G400/G400MAX:</strong> 94 <ul> 95 <li>Re-implemented videoPLL setup for monitormode; 96 <li>Re-implemented videoPLL setup for TVout mode; 97 <li>Re-implemented TVout functionality: output quality is still the same, but some handy logging is implemented for instance now. The Linux code has gone; 98 <li>Fixed the low contrast/intensity setting of the TVout picture and tuned the colorburst signal; 99 <li>Improved non-coldstarted dualhead and TVout support; 100 <li>BWindowScreen support update for dualhead and TVout use; 101 <li>Improved hardcursor support for dualhead stretch and switch modes, in standard and virtual spaces; 102 <li>Improved overlay support for virtual workspaces and dualhead switch mode with TVout enabled (will improve more later on). 103 </ul> 104 <li><strong>G450:</strong> 105 <ul> 106 <li>Implemented videoPLL setup for monitor mode <strong>and</strong> TVout mode with 'on the fly' loopback filter configuration; 107 <li>Checked and updated pins readout for all VCO reported specs; 108 <li>Implemented basic TVout support; 109 <li>Fixed a small bug in all PLL's that prevented TVout color from working correctly. This bug was also responsible for 'jumping' refreshrate changes on moving the corresponding slider in Be's screenprefs panel. The refreshrates and system speed are thus set more accurately now; 110 <li>Fixed the low contrast/intensity setting of the TVout picture and tuned the colorburst signal; 111 <li>Improved/fixed non-coldstarted dualhead and TVout support; 112 <li>Setup TVout picture vertical sizing and positioning: the DVD and VCD modes are operational! (Checkout the <a href="http://web.inter.nl.net/users/be-hold/BeOS/MGAdriver/tools.html#tools">tools</a> and <a href="http://web.inter.nl.net/users/be-hold/BeOS/MGAdriver/dvdvideo.html">VCD/DVD on TV</a> stuff); 113 <li>BWindowScreen support update for dualhead and TVout use; 114 <li>Improved hardcursor support for dualhead stretch and switch modes, in standard and virtual spaces; 115 <li>Improved overlay support for virtual workspaces and dualhead switch mode with TVout enabled (will improve more later on); 116 <li>Enabled sync signals to both the analog output connectors instead of not touching them. This might fix some 'secondary head non-working' problems, and some 'secondary card use' problems. 117 </ul> 118 <li><strong>G550:</strong> 119 <ul> 120 <li>Implemented videoPLL setup for monitor mode <strong>and</strong> TVout mode with 'on the fly' loopback filter configuration; 121 <li>Checked and updated pins readout for all VCO reported specs; 122 <li>Implemented basic TVout support; 123 <li>Fixed a small bug in all PLL's that prevented TVout color from working correctly. This bug was also responsible for 'jumping' refreshrate changes on moving the corresponding slider in Be's screenprefs panel. The refreshrates and system speed are thus set more accurately now; 124 <li>Fixed the low contrast/intensity setting of the TVout picture and tuned the colorburst signal; 125 <li>Fixed non-coldstarted dualhead and TVout support; 126 <li>Setup TVout picture vertical sizing and positioning: the DVD and VCD modes are operational! 127(Checkout the <a href="http://web.inter.nl.net/users/be-hold/BeOS/MGAdriver/tools.html#tools">tools</a> and <a href="http://web.inter.nl.net/users/be-hold/BeOS/MGAdriver/dvdvideo.html">VCD/DVD on TV</a> stuff); 128 <li>BWindowScreen support update for dualhead and TVout use; 129 <li>Improved hardcursor support for dualhead stretch and switch modes, in standard and virtual spaces; 130 <li>Improved overlay support for virtual workspaces and dualhead switch mode with TVout enabled (will improve more later on); 131 <li>Enabled sync signals to both the analog output connectors instead of not touching them. This might fix some 'secondary head non-working' problems, and some 'secondary card use' problems. 132 </ul> 133 <li><strong>General:</strong> 134 <ul> 135 <li>Implemented framebuffer slopspace. This 'feature' is needed for (decent) standard mode support on older cards (before G100), and also enables very flexible non-standard mode support on all cards (in horizontal pixel multiples of 8 pixels); 136 <li>Implemented support for primary head 'sync on green'. The driver config file mga.settings is used to enable/disable this function. Sync on green is functional on Millenium I upto and including G200 cards. G400, G450 and G550 cards apparantly miss the needed wiring on the videocard to actually support this; 137 <li>Shutdown kernel driver Matrox Mystique 170/220 recognition. These cards are not supported, so the driver may not interfere with possible other drivers that *do* support these cards; 138 <li>Prevented the driver from using the motherboard interrupts IRQ0, 1 or 2 if assigned to the Matrox card: otherwise the system may crash or hang on boot. Thanks to Sunlung Suen for nailing this one; 139 <li>Removed read access on a write only register. This fixes 2D acceleration on Millenium 2 cards and G100 acceleration not working if used as secondary videocard. Because this register was used incorrectly on all cards it might fix other (sporadic) problems also. 140 <li>Added BeOS BWindowScreen bug workaround ('ProposeMode limitation check' setup error): BWindowScreen is working fully in every valid configuration 'guaranteed' now! 141 <li>Fixed a MOVE_DISPLAY bug: horizontal move instructions where not correctly carried out for 16 and 32bit colormodes. for 16bit moves the X-coordinate was divided by two, for 32bit moves it was divided by four. This fix definately improves support for large virtual workspaces including BWindowScreen; 142 <li>Added BWindowScreen support for extremely large virtual spaces. Overlay can always be used (on G200 and later cards), 2D acceleration functions are only exported if they support a certain size; 143 <li>Fixed errors in displaymode list exported by the driver: corrected 1152x864 modes timing errors; modes beyond cardspecs are nolonger exported. 144 </ul> 145</ul> 146<p><h1>mga_driver 0.13 beta2 (Rudolf)</h1></p> 147<ul> 148 <li><strong>Millenium II:</strong> 149 <ul> 150 <li>No improvements (for this version). 151 </ul> 152 <li><strong>G100:</strong> 153 <ul> 154 <li>Removed another hardcursor bug that prevented it to work correctly on some occasions (bitmap trouble), 155 <li>Verified and improved coldstart support via actual use as secondary videocard. 156 </ul> 157 <li><strong>G200:</strong> 158 <ul> 159 <li>Implemented 'hardware zooming' in overlay. Also fixed bottom and right-most 'line' distortions sometimes visible, 160 <li>Completed 'official' card coldstart and verified it via actual use as secondary videocard, 161 <li>Minimized 'high-resolution video on high-resolution desktop' (downscaling) distortions in overlay by setting up G200 memory access priority. Note: This is a 'known limitation' of the G200 cards, their memory bandwidth is limited. G400 and later cards do not suffer from this on overlay... 162 </ul> 163 <li><strong>G400/G400MAX:</strong> 164 <ul> 165 <li>Implemented 'hardware zooming' in overlay. Also fixed bottom and right-most 'line' distortions sometimes visible, 166 <li>Completed 'official' card coldstart and verified it via actual use as secondary videocard, 167 <li>Toggled (and verified) NTSC/PAL TV output so it matches with dualheadsetup setting, 168 <li>Included TV-adapter cable detection (currently only used on cross-connecting heads), 169 <li>Modified dualhead implementation for head cross-connecting and overlay, 170 <li>Added analog amplification setting for secondary head (monitor mode: prevents analog flat-panels from being driven into saturation which resulted in bright, distorted colors). 171 </ul> 172 <li><strong>G450:</strong> 173 <ul> 174 <li>Implemented 'hardware zooming' in overlay. Also fixed bottom and right-most 'line' distortions sometimes visible, 175 <li>System PLL is programmed according to pins reported specs, 176 <li>Implemented full card coldstart support: Not yet verified, but should work as secondary videocard, 177 <li>Included TV-adapter cable detection: Analog VGA output connector is automatically chosen like the card's BIOS does if the card has a primary DVI connector, 178 <li>Extended/fixed/changed dualhead implementation for cross-connecting heads, overlay use, and (coldstarted) VGA-BIOS independent functionality (not yet verified, but should work OK). 179 </ul> 180 <li><strong>G550:</strong> 181 <ul> 182 <li>Implemented 'hardware zooming' in overlay. Also fixed bottom and right-most 'line' distortions sometimes visible, 183 <li>System PLL is programmed according to pins reported specs, 184 <li>Implemented full card coldstart support and verified it via actual use as secondary videocard, 185 <li>Included TV-adapter cable detection: Analog VGA output connector is automatically chosen like the card's BIOS does if the card has a primary DVI connector, 186 <li>Extended/fixed/changed dualhead implementation for cross-connecting heads, overlay use, and (coldstarted) VGA-BIOS independent functionality. 187 </ul> 188 <li><strong>General:</strong> 189 <ul> 190 <li>Re-included the 'Be screenprefs Panel' lower-refreshrate limit at 48Hz, 'mistakenly' removed in V0.13 beta1, 191 <li>Verified the high-refreshrate limits, works nicely according to specs and pins. G200 for instance can do 1600x1200x32 in max. 60Hz, 192 <li>The 'mga.settings' file 'usebios' option default setting for the driver is (re)set to 'false', so the G100-G550 cards will be fully started now. Please report if you encounter problems!! 193 <li>The 'mga.settings' file 'hardcursor' option default setting is (re)set to 'false', so dualhead works OK 'out of the box'. This is a failsafe setting: if you only use singlehead mode you can manually re-enable it, 194 <li>Finally completed the 'migration' to the new PINS implementation. The old version is completely removed now! (pre G100 PINS readout will be implemented also, and some minor modifications might still be done in the future to support new features the driver will get.) 195 </ul> 196</ul> 197<p><h1>mga_driver 0.13 beta1 (Rudolf)</h1></p> 198<ul> 199 <li><strong>Millenium II:</strong> 200 <ul> 201 <li>No improvements. 202 </ul> 203 <li><strong>G100:</strong> 204 <ul> 205 <li>'Pins' card-config BIOS readout re-implemented / expanded, 206 <li>Complete 'official' card coldstart, 207 <li>SDRAM card CAS latency tuning included, 208 <li>Hardware cursor / 2D support fixed, 209 <li>RAM amount detection fixed, 210 <li>PLL timebase detection included, 211 <li>Improved BWindowScreen support, 212 <li>System, RAM and DAC speeds more accurately set. 213 </ul> 214 <li><strong>G200:</strong> 215 <ul> 216 <li>'Pins' card-config BIOS readout re-implemented / expanded, 217 <li>More official card coldstart, 218 <li>RAM amount detection fixed, 219 <li>B_YCbCr422 (is YUY2) hardware overlay colorkeying completed, 220 <li>PLL timebase detection included, 221 <li>Improved BWindowScreen support, 222 <li>System, RAM and DAC speeds more accurately set. 223 </ul> 224 <li><strong>G400/G400MAX:</strong> 225 <ul> 226 <li>'Pins' card-config BIOS readout re-implemented / expanded, 227 <li>Improved card coldstart, 228 <li>RAM amount detection fixed, 229 <li>B_YCbCr422 (is YUY2) hardware overlay colorkeying completed, 230 <li>PLL timebase detection included, 231 <li>Improved BWindowScreen support, 232 <li>System and DAC speeds more accurately set. 233 </ul> 234 <li><strong>G450:</strong> 235 <ul> 236 <li>'Pins' card-config BIOS readout re-implemented / expanded, 237 <li>RAM amount detection fixed, 238 <li>B_YCbCr422 (is YUY2) hardware overlay colorkeying completed, 239 <li>DAC speeds more accurately set, 240 <li>PLL timebase detection included, 241 <li>Improved BWindowScreen support, 242 <li>PLL loopback filters configured 'on the fly'. 243 </ul> 244 <li><strong>G550:</strong> 245 <ul> 246 <li>'Pins' card-config BIOS readout re-implemented / expanded, 247 <li>RAM amount detection fixed, 248 <li>B_YCbCr422 (is YUY2) hardware overlay colorkeying completed, 249 <li>DAC speeds more accurately set, 250 <li>PLL timebase detection included, 251 <li>Improved BWindowScreen support, 252 <li>PLL loopback filters configured 'on the fly'. 253 </ul> 254</ul> 255REMARK: Re-implementing Pins is something that has it's repercussions throughout the entire driver. Most improvements are at least somewhat connected to this. Pins describes the actual specifications of your videocard. It provides info on type, amount, speed and configuration of cardRAM. It tells the driver if TVout or DVI exist on your card. It also specifies largely what the other specifications are for every individual MGA card outthere.<br> 256<hr> 257<p><h1>mga_driver 0.13 alpha2 (Apsed)</h1></p> 258<p> 259<ul> 260<li> TODO cleaning code styling 261<li> TODO use of pseudo-dma 262<li> TODO g550 dual 263<li> TODO get card properties, not using fake bios setup 264<li> TODO ? remove preR5 cloning area bug turnaround 265<li> TODO implementation of GET_ACCELERANT_DEVICE_INFO following cards 266<li> 09/06/2002 267<li> merge of overlay implementation by Rudolf for G200-G550 (no colorkeying yet, but scaling and filtering work now) 268<li> Millenium2 workish with strang 269<li> 12/05/2002 270<li> Millenium2 not working 271<li> 08/05/2002 272<li> cleanup LOG scheme for efficiency?, and to log some confiruration parameters from testers 273<li> 04/05/2002 274<li> ioctl DEVICE_NAME implementation 275<li> use Be Driver Settings API instead ./config/*.h files 276<li> uses #define for registers, ? is more efficient, so mga_regs.c "moved" in mga_macros.h 277<li> corrected G200 PIXPLLP.pixplls value from Matrox doc, no visible effect 278<li> logging revisited to use vsprintf instead poor emulation 279<li> 24/04/2002 280<li> some modifications to cleanup G200 geometry and colors problems: most important: YDSTORG set to 0 and PIXRDMSK to 0xff 281<li> Mark Watson's G400 driver renamed mga driver, because it shall work not only with G400 282<li> Mark Watson's texts or unused files from previous release moved in MarkWatson directory 283<li> mgaGx00 directory moved one level up, renamed mga and #include cleaned 284</ul> 285<hr> 286<p><h1>G400 driver 0.13 alpha1 (Rudolf)</h1></p> 287<p> 288<ul> 289<li>Hardware overlay, no scaling, filtering or colorkeying yet. 290</ul> 291<hr> 292</p> 293<p><h1>G400 driver 0.12 (last version done by Mark Watson)</h1></p> 294<p> 295<ul> 296<li>uses patch from Jean-Michel Batto to enable support for the G550 297</ul> 298<p><h1>G400 driver 0.11</h1></p> 299<p> 300<ul> 301<li>Dualhead support for the G450 (NOTE: no TVout though....) 302</ul> 303</p> 304<p><h1>G400 driver 0.10b</h1></p> 305<p> 306<ul> 307<li>Clears ZORG on G450, this fixes blitting crash (no reboot from win required) 308</ul> 309</p> 310<p><h1>G400 driver 0.10a</h1></p> 311<p> 312<ul> 313<li>(whistles)....This release never happened:-) 314</ul> 315</p> 316<p><h1>G400 driver 0.10</h1></p> 317<p> 318<ul> 319<li>TVout support (for medium resolution modes - picture placement still off) 320<li>G450 support (must reboot from windows to prevent crash in screen to screen blit) 321<li>Adjusted G100/G200 to use bios initialisation (colours still broken...) 322</ul> 323</p> 324<p><h1>G400 driver 0.09(a)</h1></p> 325<p> 326<ul> 327<li>0.09 was initially (well for 3 months!) released with singlehead broken... 328<li>Fixed G400 crash when cold booting (no idea why it works, but it does...) 329<li>Preliminary G100 support (you must reboot from another OS, as with G200 - also only 32-bit) 330</ul> 331</p> 332<p><h1>G400 driver 0.08</h1></p> 333<p> 334<ul> 335<li>Preliminary G200 support 336<li>Removed DMA stuff (just wastes memory ATM) 337<li>More sensible use of CRTC/DAC connection on dualhead 338<li>MAVEN border is black! 339</ul> 340</p> 341<p><h1>G400 driver 0.07</h1></p> 342<p> 343<ul> 344<li>PCI retries re-enabled (did not fix problem) 345<li>DualHead support 346<li>DMA preliminaries(just wastes 1MB RAM ATM) 347</ul> 348</p> 349<p><h1>G400 driver 0.06</h1></p> 350<p> 351<ul> 352<li>Supports custom monitor timing 353<li>PCI retries disabled 354<li>Detects amount of card RAM 355<li>SDRAM support 356<li>Uses VBI instead of VSYNC interrupt (more blanking time after waiting for retrace) 357<li>CRTC unlocked at init 358</ul> 359</p> 360<p><h1>G400 driver 0.05</h1></p> 361<p> 362<ul> 363<li>Refresh rate set much more accurately. 364<li>H-Sync, V-Sync polarity is REALLY set! 365<li>Fix for R4.5.0 implemented, but still best to upgrade. 366<li>Memory priority requests are set 367<li>Benaphore for engine synchronisation initialised properly 368<li>Synchronisation now always waits for idle if it has to wait, rather than attempting (and sometimes failing) to wait for individual operations. 369<li>Pixel clock of display mode reported accurately (so refresh rate reported correctly) 370<li>Maximum pixel clock reported correctly 371</ul> 372</p> 373<p><h1>G400 driver 0.04</h1></p> 374<p> 375<ul> 376<li>Discovered driver only works with R4.5.2, no fix (yet?) (please upgrade) 377<li>Removed MAX hack (problem was not with MAX cards, but with Be version - see above) 378<li>Adjusted vertical sync to give more precise refresh rates (still could be better) 379<li>Fixed bug with MOVE_DISPLAY (occurred when returning from fullscreen apps) 380<li>Adjusted mouse pointer positioning, so hot spot is in the correct place. 381</ul> 382</p> 383<p><h1>G400 driver 0.03a</h1></p> 384<p> 385<ul> 386<li>Reworked interrupt code, now uses correct method. 387</ul> 388</p> 389<p><h1>G400 driver 0.03</h1></p> 390<p> 391<ul> 392<li>Vertical blank interrupt fixed - no longer steals interrupts! 393<li>Polarity is set for VSYNC and HSYNC 394<li>refresh with low dot clock is now correct 395<li>logfile now has 3 levels (1 - all, 2 - info, 3 - error) 396<li>ROM is now mapped in a better way (thanx for the info) 397<li>Sounds like init is failing for some G400MAX owners. Please try new version first, but if it still fails please do the following (it sets it up as a standard G400 without using the BIOS): 398<ul> 399<li>cd accelerent/mgag400 400<li>mv mga_fake_info.c mga_info.c 401</ul> 402</ul> 403</p> 404</body> 405</html> 406