Commit Graph

554 Commits

Author SHA1 Message Date
Keith Packard 679c7bd826 ignore edited man page 2006-11-08 21:39:28 -08:00
Keith Packard 81b7b489af Adapt to RandR updates that split object creation from screen association.
RandR DIX code is preparing for xf86 drivers that want to allocate RandR
objects at PreInit time. This patch adapts to that change without taking
advantage of it.
2006-11-08 21:38:00 -08:00
Keith Packard 81bace0c31 Merge branch 'modesetting-keithp' into modesetting
Conflicts in PipeSetMode were resolved to use the keithp changes
that pushed more modesetting stuff into the per-pipe function.

Switched availablePipes to num_pipes.

Used modesetting default output configuration.
2006-11-08 20:23:20 -08:00
Eric Anholt 713c5b0899 Change the output and pipe "is it on/off" field name to "enabled". 2006-11-08 19:55:31 -08:00
Eric Anholt ff77e9d84f Clean up i830_crt_detect_load() a bit more.
ADPA might not have been set right in some cases (DPMS-off monitor, for
example), and a wait for vsync that the bios does was missing.
2006-11-08 19:53:31 -08:00
Eric Anholt 9b267014b5 Go back to only setting up outputs that have a display connected. 2006-11-08 19:39:18 -08:00
Eric Anholt 35ab689bbd Fix i830DisableUnusedFunctions after pipe structure change.
Using "pipe" instead of the index "i" meant pipe(3) got referenced instead of
a nice small integer.  Oops.
2006-11-08 19:35:49 -08:00
Keith Packard f1ff01e31e Eliminate operatingDevices member and PIPE_* values.
operatingDevices and MonType1/MonType2 duplicate information already stored
in the device structures. Eliminate them and replace uses with direct
references to the appropriate other data.
(cherry picked from 3ab7f96932 commit)
2006-11-07 15:17:27 -08:00
Keith Packard 0b2d36d4f0 Use pI830->availablePipes instead of MAX_DISPLAY_PIPES everywhere
(cherry picked from e4bcec796e commit)
2006-11-07 15:13:23 -08:00
Eric Anholt d0ef9e99ac Restore PFIT_CONTROL before turning the LVDS back on in the restore method. 2006-11-06 18:30:46 -08:00
Eric Anholt 94a3731c2b Move PFIT_CONTROL disable for G965 up before post_set_mode.
Also, remove setting of some other random registers that appears to have
been spammed in at the same time, and don't try to disable on the I830, before
this register existed.
2006-11-06 18:28:55 -08:00
Keith Packard beb89163d7 DSPSURF must be page aligned. Place intra-screen offset in DSPBASE.
DSPASURF/DSPBSURF can only take page aligned values, ignoring
the lower order bits. So, place the offset for the output
within the frame buffer in the DSPABASE/DSPBBASE registers instead.
2006-11-05 19:06:45 -08:00
Keith Packard 997e8c9bb4 Don't allocate stuff in the first 256K of video memory (GATT?)
Letting the ring buffer or other objects be allocated within the lowest
portion of memory appears to trash some memory mapping data; I'm assuming
this is the GATT table on the 965. Just marking this out of bounds for
allocation fixes this problem.
2006-11-05 18:56:33 -08:00
Keith Packard 5a355c7261 Fix CRT output on 965 chipset.
A few more register settings are needed to get CRT output working on the
965 chipset, in particular the the SDVO/UDI clock multiplier register
needed to get set to the default value (3). No, I really don't know what
this does, but it does get the CRT running at a wide range of sizes.
2006-11-05 18:51:28 -08:00
Keith Packard 68c3185046 Avoid crashing when disabling sdvo output. XXX 2006-11-05 13:30:32 -08:00
Keith Packard 15ef08046b Move remaining pipe mode setting logic to i830PipeSetMode 2006-11-05 13:29:56 -08:00
Keith Packard 7fcb555735 Rename availablePipes to num_pipes 2006-11-04 00:52:21 -08:00
Keith Packard 3ab7f96932 Eliminate operatingDevices member and PIPE_* values.
operatingDevices and MonType1/MonType2 duplicate information already stored
in the device structures. Eliminate them and replace uses with direct
references to the appropriate other data.
2006-11-04 00:46:18 -08:00
Keith Packard e4bcec796e Use pI830->availablePipes instead of MAX_DISPLAY_PIPES everywhere 2006-11-03 23:29:12 -08:00
Keith Packard b7262a9a91 Finish removing persistant vbe data 2006-11-03 23:24:07 -08:00
Keith Packard 4625073244 Oops, martian memset of randr modes pointer 2006-11-03 23:23:38 -08:00
Keith Packard 719ad68515 Use VBE only temporarily to fetch BIOS rom image
(cherry picked from 6a9386651785afc70a29e355255e8295b321f28e commit)
2006-11-03 21:48:45 -08:00
Eric Anholt 27df2ff790 Report pipe status (and status mismatches) in i830DescribeOutputConfiguration() 2006-11-03 16:39:49 -08:00
Eric Anholt ecbe73b940 Merge branch 'modesetting-origin' into modesetting
Conflicts:

	src/i830_display.c
2006-11-03 15:59:59 -08:00
Eric Anholt 561af00797 Add support for load-based CRT detection. 2006-11-03 15:57:34 -08:00
Eric Anholt e416b426d8 Print out modelines as info, not error (which had been used for debugging). 2006-11-03 15:25:41 -08:00
Eric Anholt 282a9e073e Don't memset the modes pointer on init, which was dereferencing NULL. 2006-11-03 13:46:09 -08:00
Keith Packard 9681602177 Create I830PipeRec to hold pipe-specific data. Remove unused I830 members.
I830 contained six parallel arrays for pipe-specific data; these
have been moved to a I830PipeRec structure instead.

I830 also contained several unused members:

   unsigned int bios_version;
   Bool newPipeSwitch;
   Bool fakeSwitch;
   int fixedPipe;

These have been removed, along with the code that set them.
2006-11-03 12:55:25 -08:00
Eric Anholt 0510671a6c Fix a pasteo in I965 register restore. 2006-11-03 10:58:46 -08:00
Keith Packard 2c9ab6e059 set the v_sync_off_high to zero. XXX should check docs 2006-11-02 13:44:59 -08:00
Keith Packard 56f6d4f1bb Disable the panel fitter when not using it. Cleans up SDVO DVI output.
The panel fitter appears to exist on the 965 hardware (at least) and
causes troubles with DVI output over SDVO when enabled. This patch
checks to see if the panel fitter is pointing at the pipe being configured
and disables it unconditionally in that case. The LVDS driver will configure
it correctly if necessary afterwards.
2006-11-02 13:44:59 -08:00
Keith Packard f22d9bcc25 Add another couple of new registers 2006-11-02 13:44:59 -08:00
Eric Anholt a9eac38bcd Remove duplicated register defs that were just added. 2006-11-02 13:24:54 -08:00
Eric Anholt 7887c76062 Add airlied's I2C code, ifdeffed out.
I've gone back to compare our behavior to it several times, so I'll just keep
the code in tree for now.
2006-11-02 13:19:06 -08:00
Eric Anholt 87b15cfbf7 Remove dead specifiedMonitor field. 2006-11-02 13:16:44 -08:00
Keith Packard 2636d68663 Dump more registers for debug purposes 2006-11-02 11:57:11 -08:00
Keith Packard 786ec54c4c Add a few more registers from the 965 spec 2006-11-02 11:56:50 -08:00
Keith Packard 85e32ad2da ch7xxxSaveRegs receives real type instead of void * 2006-11-02 11:56:12 -08:00
Eric Anholt ffbd6ca09b Remove dead VESARec struct. 2006-11-01 13:05:44 -08:00
Eric Anholt 97c3a1b242 Remove the refresh rate appended to some mode names.
This gets the SDVO and CRT outputs I have to have at least 1 common mode
according to RandR.
2006-11-01 13:04:08 -08:00
Eric Anholt 7971c40155 Attempt to pull monitor physical size information out of DDC EDID data. 2006-11-01 12:42:56 -08:00
Eric Anholt fb94c12109 Move mode lists from per-pipe to per-output.
This should let RandR do the right thing in exposing the modes to userland.

As a side effect of getting this working, the SDVO pixel clock range code
was fixed and the mode valid tests for various outputs got extended.  Also,
LVDS grew a get_modes for the fixed panel mode.

Note that we now no longer do automatic enabling of outputs at xrandr -s 0,
hotkey, or VT switch.  That will be left to generic RandR code later.  Also,
generic modes and user-defined modes are once again not validated into the
lists, so this is a regression there.
2006-11-01 12:23:50 -08:00
Eric Anholt f30d7f912f Update for the move of RandR phyiscal size information. 2006-11-01 11:50:51 -08:00
Eric Anholt 7195dfabd5 Give each output a get_modes function and expose those modes through RandR.
The get_modes should return the probed modes only.  The driver should then
append to the list (for example, compatible modes listed in other outputs,
or standard VESA modes) to create the list to expose through RandR.  That
isn't done yet.
2006-10-31 17:10:08 -08:00
Eric Anholt cc3728be24 Add compat definitions for M_T_PREFERRED and M_T_DRIVER for older X Servers. 2006-10-31 15:00:36 -08:00
Eric Anholt a71f283650 Connect output detection up to RandR. 2006-10-31 14:46:23 -08:00
Eric Anholt 68cef9f4e0 Move output connection detection to a per-output method.
This will be used by RandR, and should let us clean up some of the initial
display configuration, hopefully.

Also, analog hotplug-based detection is now enabled on G965.
2006-10-31 14:32:00 -08:00
Eric Anholt 9fd719fce2 Move SDVOB_PRESERVE_MASK next to SDVOC_PRESERVE_MASK. 2006-10-31 14:29:44 -08:00
Eric Anholt 4f5d4d8870 i830SetLVDSPanelPower is now a static function in i830_lvds.c, so remove it. 2006-10-31 13:37:23 -08:00
Eric Anholt 49bbdf16c0 Fix many inconsistencies in the SDVO code compared to the spec.
Also, fix some struct padding  so that the right bits are sent out.
2006-10-31 11:42:03 -08:00