diff options
| author | Tomi Valkeinen <tomi.valkeinen@ti.com> | 2017-03-21 15:04:24 +0200 | 
|---|---|---|
| committer | Tomi Valkeinen <tomi.valkeinen@ti.com> | 2017-03-21 15:04:24 +0200 | 
| commit | 2439ae8738ad9410441c6160f512ab64ec94333d (patch) | |
| tree | fbb274db500a09fa0191f260b04659b85350154a | |
| parent | 9aeb121657a076a0c03ac6e7fc3c1e93e465e5d9 (diff) | |
| parent | dce8d396848c509d77b7fe8f745ea29e74af9c0c (diff) | |
Merge branch 'universal-planes2' of git://github.com/jsarha/kmsxx
| -rw-r--r-- | kms++util/inc/kms++util/resourcemanager.h | 1 | ||||
| -rw-r--r-- | kms++util/src/resourcemanager.cpp | 21 | ||||
| -rw-r--r-- | py/pykms/pykmsutil.cpp | 3 | ||||
| -rwxr-xr-x | py/tests/plane_hog.py | 136 | 
4 files changed, 160 insertions, 1 deletions
diff --git a/kms++util/inc/kms++util/resourcemanager.h b/kms++util/inc/kms++util/resourcemanager.h index dac6c9e..b4a210d 100644 --- a/kms++util/inc/kms++util/resourcemanager.h +++ b/kms++util/inc/kms++util/resourcemanager.h @@ -16,6 +16,7 @@ public:  	Connector* reserve_connector(Connector* conn);  	Crtc* reserve_crtc(Connector* conn);  	Plane* reserve_plane(Crtc* crtc, PlaneType type, PixelFormat format = PixelFormat::Undefined); +	Plane* reserve_generic_plane(Crtc* crtc, PixelFormat format = PixelFormat::Undefined);  	Plane* reserve_primary_plane(Crtc* crtc, PixelFormat format = PixelFormat::Undefined);  	Plane* reserve_overlay_plane(Crtc* crtc, PixelFormat format = PixelFormat::Undefined); diff --git a/kms++util/src/resourcemanager.cpp b/kms++util/src/resourcemanager.cpp index 5c83ad7..23a1480 100644 --- a/kms++util/src/resourcemanager.cpp +++ b/kms++util/src/resourcemanager.cpp @@ -129,7 +129,26 @@ Crtc* ResourceManager::reserve_crtc(Connector* conn)  Plane* ResourceManager::reserve_plane(Crtc* crtc, PlaneType type, PixelFormat format)  {  	for (Plane* plane : crtc->get_possible_planes()) { -		if (plane->plane_type() != type) +		if (plane->plane_type() == type) +			continue; + +		if (format != PixelFormat::Undefined && !plane->supports_format(format)) +			continue; + +		if (contains(m_reserved_planes, plane)) +			continue; + +		m_reserved_planes.push_back(plane); +		return plane; +	} + +	return nullptr; +} + +Plane* ResourceManager::reserve_generic_plane(Crtc* crtc, PixelFormat format) +{ +	for (Plane* plane : crtc->get_possible_planes()) { +		if (plane->plane_type() == PlaneType::Cursor)  			continue;  		if (format != PixelFormat::Undefined && !plane->supports_format(format)) diff --git a/py/pykms/pykmsutil.cpp b/py/pykms/pykmsutil.cpp index 8421cc5..46b7765 100644 --- a/py/pykms/pykmsutil.cpp +++ b/py/pykms/pykmsutil.cpp @@ -30,6 +30,9 @@ void init_pykmstest(py::module &m)  			     py::arg("crtc"),  			     py::arg("type"),  			     py::arg("format") = PixelFormat::Undefined) +			.def("reserve_generic_plane", &ResourceManager::reserve_generic_plane, +			     py::arg("crtc"), +			     py::arg("format") = PixelFormat::Undefined)  			.def("reserve_primary_plane", &ResourceManager::reserve_primary_plane,  			     py::arg("crtc"),  			     py::arg("format") = PixelFormat::Undefined) diff --git a/py/tests/plane_hog.py b/py/tests/plane_hog.py new file mode 100755 index 0000000..5bdc937 --- /dev/null +++ b/py/tests/plane_hog.py @@ -0,0 +1,136 @@ +#!/usr/bin/python3 + +import pykms +import sys + +card = pykms.Card() +res = pykms.ResourceManager(card) + +conn1 = False +conn2 = False + +for conn in card.connectors: +     if not conn1: +          conn1 = conn +     elif not conn2: +          conn2 = conn +     else: +          break + +crtc1 = res.reserve_crtc(conn1) +mode1 = conn1.get_default_mode() +modeb1 = mode1.to_blob(card) +print("CRTC idx %d goes to %s connector" % (crtc1.idx, conn1.fullname)) + +if conn2: +     crtc2 = res.reserve_crtc(conn2) +     mode2 = conn2.get_default_mode() +     modeb2 = mode2.to_blob(card) +     print("CRTC idx %d goes to %s connector" % (crtc2.idx, conn2.fullname)) + +fbwidth = 480 +fbheight = 270 + +fb = pykms.DumbFramebuffer(card, fbwidth, fbheight, "AR24"); +pykms.draw_test_pattern(fb); + +# Disable request +card.disable_planes() + +plane_list = [] + +while True: +     plane = res.reserve_generic_plane(crtc1) +     if plane: +         print("Got plane idx %d" % plane.idx) +         plane_list.append(plane) +     else: +         break + +print("Got %d planes" % len(plane_list)) + +req = pykms.AtomicReq(card) +req.add(conn1, "CRTC_ID", crtc1.id) +req.add(crtc1, {"ACTIVE": 1, +               "MODE_ID": modeb1.id}) + +input("Press enter to enable crtc idx %d at %s" % (crtc1.idx, conn1.fullname)) +r = req.commit_sync(allow_modeset = True) + +print("Crtc enable request returned %d\n" % r) + +x = 0 +y = 0 +z = 0 + +for plane in plane_list: +    input("Press enter to enable plane idx %d on crtc idx %d" % +          (plane.idx, crtc1.idx)) +    req = pykms.AtomicReq(card) +    req.add(plane, {"FB_ID": fb.id, +                     "CRTC_ID": crtc1.id, +                     "SRC_X": 0 << 16, +                     "SRC_Y": 0 << 16, +                     "SRC_W": fb.width << 16, +                     "SRC_H": fb.height << 16, +                     "CRTC_X": x, +                     "CRTC_Y": y, +                     "CRTC_W": fb.width, +                     "CRTC_H": fb.height, +                     "zorder": z}) +    r = req.commit_sync() +    print("Plane enable request returned %d\n" % r) + +    x = x + 50 +    y = y + 50 +    z = z + 1 + +if not conn2: +     sys.exit() + +req = pykms.AtomicReq(card) +req.add(conn2, "CRTC_ID", crtc2.id) +req.add(crtc2, {"ACTIVE": 1, +                "MODE_ID": modeb2.id}) + +input("Press enter to enable crtc idx %d at %s" % (crtc2.idx, conn2.fullname)) +r = req.commit_sync(allow_modeset = True) +print("Crtc enable request returned %d\n" % r) + +x = 0 +y = 0 +z = 0 + +# Code assumes that planes for crtc1 also work for crtc2 +for plane in reversed(plane_list): + +    input("Press enter to disable plane idx %d on crtc idx %d" % +          (plane.idx, crtc1.idx)) +    req = pykms.AtomicReq(card) +    req.add(plane, {"FB_ID": 0, +                    "CRTC_ID": 0}) +    r = req.commit_sync(allow_modeset = True) +    print("Plane disable request returned %d\n" % r) + +    input("Press enter to enable plane idx %d on crtc idx %d" % +          (plane.idx, crtc2.idx)) +    req = pykms.AtomicReq(card) +    req.add(plane, {"FB_ID": fb.id, +                    "CRTC_ID": crtc2.id, +                    "SRC_X": 0 << 16, +                    "SRC_Y": 0 << 16, +                    "SRC_W": fb.width << 16, +                    "SRC_H": fb.height << 16, +                    "CRTC_X": x, +                    "CRTC_Y": y, +                    "CRTC_W": fb.width, +                    "CRTC_H": fb.height, +                    "zorder": z}) +    r = req.commit_sync(allow_modeset = True) +    print("Plane enable request returned %d\n" % r) + +    x = x + 50 +    y = y + 50 +    z = z + 1 + +input("press enter to exit\n")  | 
