Patch Detail
Show a patch.
GET /api/patches/822/?format=api
{ "id": 822, "url": "https://patchwork.libcamera.org/api/patches/822/?format=api", "web_url": "https://patchwork.libcamera.org/patch/822/", "project": { "id": 1, "url": "https://patchwork.libcamera.org/api/projects/1/?format=api", "name": "libcamera", "link_name": "libcamera", "list_id": "libcamera_core", "list_email": "libcamera-devel@lists.libcamera.org", "web_url": "", "scm_url": "", "webscm_url": "" }, "msgid": "<20190329152705.29988-1-laurent.pinchart@ideasonboard.com>", "date": "2019-03-29T15:27:05", "name": "[libcamera-devel] qcam: Add JPEG format support", "commit_ref": "80e236e19b61a1267948433fd6855da138d6f527", "pull_url": null, "state": "accepted", "archived": false, "hash": "9b951595e2e51652bea9391338c69d79ea1dd50e", "submitter": { "id": 2, "url": "https://patchwork.libcamera.org/api/people/2/?format=api", "name": "Laurent Pinchart", "email": "laurent.pinchart@ideasonboard.com" }, "delegate": null, "mbox": "https://patchwork.libcamera.org/patch/822/mbox/", "series": [ { "id": 224, "url": "https://patchwork.libcamera.org/api/series/224/?format=api", "web_url": "https://patchwork.libcamera.org/project/libcamera/list/?series=224", "date": "2019-03-29T15:27:05", "name": "[libcamera-devel] qcam: Add JPEG format support", "version": 1, "mbox": "https://patchwork.libcamera.org/series/224/mbox/" } ], "comments": "https://patchwork.libcamera.org/api/patches/822/comments/", "check": "pending", "checks": "https://patchwork.libcamera.org/api/patches/822/checks/", "tags": {}, "headers": { "Return-Path": "<laurent.pinchart@ideasonboard.com>", "Received": [ "from perceval.ideasonboard.com (perceval.ideasonboard.com\n\t[IPv6:2001:4b98:dc2:55:216:3eff:fef7:d647])\n\tby lancelot.ideasonboard.com (Postfix) with ESMTPS id 01A66600FB\n\tfor <libcamera-devel@lists.libcamera.org>;\n\tFri, 29 Mar 2019 16:27:22 +0100 (CET)", "from pendragon.bb.dnainternet.fi\n\t(dfj612yhrgyx302h3jwwy-3.rev.dnainternet.fi\n\t[IPv6:2001:14ba:21f5:5b00:ce28:277f:58d7:3ca4])\n\tby perceval.ideasonboard.com (Postfix) with ESMTPSA id 77E509A3\n\tfor <libcamera-devel@lists.libcamera.org>;\n\tFri, 29 Mar 2019 16:27:22 +0100 (CET)" ], "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com;\n\ts=mail; t=1553873242;\n\tbh=wCpn4PlmVl4G5k+uLj4w9rV7JfRjUGR0sIUHMG7XC/c=;\n\th=From:To:Subject:Date:From;\n\tb=NE8iZA++GT+g0aZhA88OTowS36UA9e7Sa0GMRZTeXnH4vEr43WMIfkMyEy/DAEAeE\n\tLKTOpjIyBQ8kzqalpcBopWRf36CAXP1sxsc1QUBTmirFFbLrCgm3agz9j7wPs0eqVi\n\t+ZYDPYVxQecBrHU8b4JNkpZWgY8x24SX++rSLnM4=", "From": "Laurent Pinchart <laurent.pinchart@ideasonboard.com>", "To": "libcamera-devel@lists.libcamera.org", "Date": "Fri, 29 Mar 2019 17:27:05 +0200", "Message-Id": "<20190329152705.29988-1-laurent.pinchart@ideasonboard.com>", "X-Mailer": "git-send-email 2.19.2", "MIME-Version": "1.0", "Content-Transfer-Encoding": "8bit", "Subject": "[libcamera-devel] [PATCH] qcam: Add JPEG format support", "X-BeenThere": "libcamera-devel@lists.libcamera.org", "X-Mailman-Version": "2.1.23", "Precedence": "list", "List-Id": "<libcamera-devel.lists.libcamera.org>", "List-Unsubscribe": "<https://lists.libcamera.org/options/libcamera-devel>,\n\t<mailto:libcamera-devel-request@lists.libcamera.org?subject=unsubscribe>", "List-Archive": "<https://lists.libcamera.org/pipermail/libcamera-devel/>", "List-Post": "<mailto:libcamera-devel@lists.libcamera.org>", "List-Help": "<mailto:libcamera-devel-request@lists.libcamera.org?subject=help>", "List-Subscribe": "<https://lists.libcamera.org/listinfo/libcamera-devel>,\n\t<mailto:libcamera-devel-request@lists.libcamera.org?subject=subscribe>", "X-List-Received-Date": "Fri, 29 Mar 2019 15:27:23 -0000" }, "content": "When the camera provides MJPEG, use the QImage JPEG decompression code\nto convert that to RGB.\n\nSigned-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>\n---\n src/qcam/format_converter.cpp | 16 +++++++++++++++-\n src/qcam/format_converter.h | 9 ++++++++-\n src/qcam/main_window.cpp | 2 +-\n src/qcam/viewfinder.cpp | 4 ++--\n src/qcam/viewfinder.h | 2 +-\n 5 files changed, 27 insertions(+), 6 deletions(-)", "diff": "diff --git a/src/qcam/format_converter.cpp b/src/qcam/format_converter.cpp\nindex 6979a054c0ca..bda9057e17b6 100644\n--- a/src/qcam/format_converter.cpp\n+++ b/src/qcam/format_converter.cpp\n@@ -9,6 +9,8 @@\n \n #include <linux/videodev2.h>\n \n+#include <QImage>\n+\n #include \"format_converter.h\"\n \n #define RGBSHIFT\t\t8\n@@ -45,16 +47,28 @@ int FormatConverter::configure(unsigned int format, unsigned int width,\n \t\ty_pos_ = 0;\n \t\tcb_pos_ = 1;\n \t\tbreak;\n+\tcase V4L2_PIX_FMT_MJPEG:\n+\t\tbreak;\n \tdefault:\n \t\treturn -EINVAL;\n \t};\n \n+\tformat_ = format;\n \twidth_ = width;\n \theight_ = height;\n \n \treturn 0;\n }\n \n+void FormatConverter::convert(const unsigned char *src, size_t size,\n+\t\t\t QImage *dst)\n+{\n+\tif (format_ == V4L2_PIX_FMT_MJPEG)\n+\t\tdst->loadFromData(src, size, \"JPEG\");\n+\telse\n+\t\tconvertYUV(src, dst->bits());\n+}\n+\n static void yuv_to_rgb(int y, int u, int v, int *r, int *g, int *b)\n {\n \tint c = y - 16;\n@@ -65,7 +79,7 @@ static void yuv_to_rgb(int y, int u, int v, int *r, int *g, int *b)\n \t*b = CLIP(( 298 * c + 516 * d + 128) >> RGBSHIFT);\n }\n \n-void FormatConverter::convert(const unsigned char *src, unsigned char *dst)\n+void FormatConverter::convertYUV(const unsigned char *src, unsigned char *dst)\n {\n \tunsigned int src_x, src_y, dst_x, dst_y;\n \tunsigned int src_stride;\ndiff --git a/src/qcam/format_converter.h b/src/qcam/format_converter.h\nindex 196064c74f65..396d0bea116a 100644\n--- a/src/qcam/format_converter.h\n+++ b/src/qcam/format_converter.h\n@@ -7,15 +7,22 @@\n #ifndef __QCAM_FORMAT_CONVERTER_H__\n #define __QCAM_FORMAT_CONVERTER_H__\n \n+#include <stddef.h>\n+\n+class QImage;\n+\n class FormatConverter\n {\n public:\n \tint configure(unsigned int format, unsigned int width,\n \t\t unsigned int height);\n \n-\tvoid convert(const unsigned char *src, unsigned char *dst);\n+\tvoid convert(const unsigned char *src, size_t size, QImage *dst);\n \n private:\n+\tvoid convertYUV(const unsigned char *src, unsigned char *dst);\n+\n+\tunsigned int format_;\n \tunsigned int width_;\n \tunsigned int height_;\n \tunsigned int y_pos_;\ndiff --git a/src/qcam/main_window.cpp b/src/qcam/main_window.cpp\nindex a148aa4d117f..fea701422015 100644\n--- a/src/qcam/main_window.cpp\n+++ b/src/qcam/main_window.cpp\n@@ -222,7 +222,7 @@ int MainWindow::display(Buffer *buffer)\n \n \tPlane &plane = buffer->planes().front();\n \tunsigned char *raw = static_cast<unsigned char *>(plane.mem());\n-\tviewfinder_->display(raw);\n+\tviewfinder_->display(raw, buffer->bytesused());\n \n \treturn 0;\n }\ndiff --git a/src/qcam/viewfinder.cpp b/src/qcam/viewfinder.cpp\nindex 5841dc032967..224a227ddd5b 100644\n--- a/src/qcam/viewfinder.cpp\n+++ b/src/qcam/viewfinder.cpp\n@@ -16,9 +16,9 @@ ViewFinder::ViewFinder(QWidget *parent)\n {\n }\n \n-void ViewFinder::display(const unsigned char *raw)\n+void ViewFinder::display(const unsigned char *raw, size_t size)\n {\n-\tconverter_.convert(raw, image_->bits());\n+\tconverter_.convert(raw, size, image_);\n \n \tQPixmap pixmap = QPixmap::fromImage(*image_);\n \tsetPixmap(pixmap);\ndiff --git a/src/qcam/viewfinder.h b/src/qcam/viewfinder.h\nindex df4901699a14..c9ca98913e05 100644\n--- a/src/qcam/viewfinder.h\n+++ b/src/qcam/viewfinder.h\n@@ -20,7 +20,7 @@ public:\n \n \tint setFormat(unsigned int format, unsigned int width,\n \t\t unsigned int height);\n-\tvoid display(const unsigned char *rgb);\n+\tvoid display(const unsigned char *rgb, size_t size);\n \n private:\n \tunsigned int format_;\n", "prefixes": [ "libcamera-devel" ] }