diff options
| author | Tomi Valkeinen <tomi.valkeinen@ti.com> | 2019-11-06 17:28:56 +0200 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2019-11-06 17:28:56 +0200 | 
| commit | d6dc724f16672cbb3eed382815514f4c9a0246d4 (patch) | |
| tree | 2dc92e3848cb6de85cf29646418b6deac3dbb250 /py | |
| parent | 9d142cb7ec175a8394f47aee61ca8a1951dd6170 (diff) | |
| parent | 3009db77d599c6a397c24ba1a4e84c53299162c0 (diff) | |
Merge pull request #40 from tomba/work
Misc improvements
Diffstat (limited to 'py')
| -rw-r--r-- | py/pykms/pykmsbase.cpp | 16 | ||||
| -rwxr-xr-x | py/tests/test.py | 2 | 
2 files changed, 9 insertions, 9 deletions
diff --git a/py/pykms/pykmsbase.cpp b/py/pykms/pykmsbase.cpp index b4dc090..c039833 100644 --- a/py/pykms/pykmsbase.cpp +++ b/py/pykms/pykmsbase.cpp @@ -122,14 +122,14 @@ void init_pykmsbase(py::module &m)  			;  	py::class_<Blob>(m, "Blob") -			.def("__init__", [](Blob& instance, Card& card, py::buffer buf) { -					py::buffer_info info = buf.request(); -					if (info.ndim != 1) -						throw std::runtime_error("Incompatible buffer dimension!"); +			.def(py::init([](Card& card, py::buffer buf) { +				py::buffer_info info = buf.request(); +				if (info.ndim != 1) +					throw std::runtime_error("Incompatible buffer dimension!"); -					new (&instance) Blob(card, info.ptr, info.size * info.itemsize); -				}, -				py::keep_alive<1, 3>())	// Keep Card alive until this is destructed +				return new Blob(card, info.ptr, info.size * info.itemsize); +			}), +			py::keep_alive<1, 2>())	// Keep Card alive until this is destructed  			.def_property_readonly("data", &Blob::data) @@ -167,7 +167,7 @@ void init_pykmsbase(py::module &m)  			.def("offset", &DumbFramebuffer::offset)  			; -	py::class_<ExtFramebuffer, Framebuffer>(m, "ExtFramebuffer") +	py::class_<DmabufFramebuffer, Framebuffer>(m, "DmabufFramebuffer")  			.def(py::init<Card&, uint32_t, uint32_t, PixelFormat, vector<int>, vector<uint32_t>, vector<uint32_t>>(),  			     py::keep_alive<1, 2>())	// Keep Card alive until this is destructed  			; diff --git a/py/tests/test.py b/py/tests/test.py index 83cf16a..3f9e205 100755 --- a/py/tests/test.py +++ b/py/tests/test.py @@ -28,7 +28,7 @@ else:  	origfb = pykms.DumbFramebuffer(card, mode.hdisplay, mode.vdisplay, "XR24");  if args.dmabuf: -	fb = pykms.ExtFramebuffer(card, origfb.width, origfb.height, origfb.format, +        fb = pykms.DmabufFramebuffer(card, origfb.width, origfb.height, origfb.format,  		[origfb.fd(0)], [origfb.stride(0)], [origfb.offset(0)])  else:  	fb = origfb  | 
