- Ada 98.7%
- Makefile 1.1%
- Shell 0.2%
|
Patrick Rudolph
3c3828add5
hw-gfx-gma-i2c: Reduce EDID I2C timeout
The GMBUS statemachine on Intel C200 chipset is broken and never sets the HW_RDY, TIMEOUT nor the NAK bit. Due to this silicon bug it runs into the software timeout when no external display is connected. Reduce the software timeout from 500msec to 50msec, the same limit that is being used in the Linux kernel. Reduces boot time on Lenovo X220 by 450msec when no external HDMI is connected on the displayport connector. TEST=Displayport monitor still works. TEST=HDMI monitor using passive Displayport adapter cable still works. TEST=LVDS is still working. Change-Id: Ic8a357fdf345f32fd377b6d83efaa2550f607cac Signed-off-by: Patrick Rudolph <patrick.rudolph@9elements.com> Reviewed-on: https://review.coreboot.org/c/libgfxinit/+/89635 Reviewed-by: Angel Pons <th3fanbus@gmail.com> Tested-by: Angel Pons <th3fanbus@gmail.com> Reviewed-by: Naresh <naresh.solanki.2011@gmail.com> Reviewed-by: Tim Wawrzynczak <inforichland@gmail.com> |
||
|---|---|---|
| common | hw-gfx-gma-i2c: Reduce EDID I2C timeout | |
| configs | gma: Begin Alder Lake (ADL) integration | |
| gfxtest | gfxtest: Handle 64-bit aperture base and register location | |
| .gitignore | Initial upstream commit | |
| COPYING | Initial upstream commit | |
| Makefile |
Add linux user-space app gfx_test
|
|
| Makefile.inc |
Add linux user-space app gfx_test
|
|
| README.md | README: Fix hyphenations in markdown | |
| TODO | gma skl: Disable DDI clocks on reset path | |
libgfxinit
libgfxinit is a graphics initialization (aka modesetting) library for embedded environments. It currently supports only Intel hardware, more specifically the Intel Core processor line.
It can query and set up most kinds of displays based on their EDID information. You can, however, also specify particular mode lines.
libgfxinit is written in SPARK, an Ada subset with formal verification aspects. Absence of runtime errors can be proved automatically with SPARK GPL 2016.
Building on Linux
Prerequisites
For compilation, the GNAT Ada compiler is required. Usual package
names in Linux distributions are gcc-ada and gnat.
Grab the Sources
You'll need libhwbase and libgfxinit. Best is to clone the repositories into a common parent directory (this way libgfxinit will know where to find libhwbase).
$ mkdir gfxfun && cd gfxfun
$ git clone https://review.coreboot.org/p/libhwbase.git
$ git clone https://review.coreboot.org/p/libgfxinit.git
Configure and Install libhwbase
Both libraries are currently configured by hand-written config files.
You can either write your own .config, link one of the shipped files
in configs/, e.g.:
$ ln -s configs/linux libhwbase/.config
or overwrite the config filename by specifying cnf=<configfile> on
the make command line.
By default most debug messages won't be compiled into the binary. To
include them into the build, set DEBUG=1 on the command line or in
your .config.
Let's install libhwbase. We'll need configs/linux to build regular
Linux executables:
$ cd libhwbase
$ make DEBUG=1 cnf=configs/linux install
By default this installs into a new subdirectory dest. You can however
overwrite this decision by specifying DESTDIR=.
Build libgfxinit/gfx_test
libgfxinit is configured and installed in the same manner as described above. You will have to select a configuration matching your hardware.
The makefile knows an additional target gfx_test to build a small
Linux test application:
$ cd ../libgfxinit
$ make DEBUG=1 cnf=configs/sandybridge gfx_test
The resulting binary is build/gfx_test.
Testing libgfxinit on Linux
gfx_test sets up its own framebuffer in the stolen memory. It
backs any current framebuffer mapping and contents up first and
restores it before exiting. This works somehow even while the i915
driver is running. A wrapper script gfxtest/gfx_test.sh is
provided to help with the setup. It switches to a text console first
and tries to unload the i915 driver. But ignores failures to do
so (it won't work if you still have any application running that
uses the gfx driver, e.g. an X server).
# gfxtest/gfx_test.sh
If you chose the right config above, you should be presented with a
nice test image. But please be prepared that your console might be
stuck in that state afterwards. You can try to run it with i915
deactivated then (e.g. when booting with nomodeset in the kernel
command line or with i915 blacklisted) and loading it afterwards.