From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from ffbox0-bg.mplayerhq.hu (ffbox0-bg.ffmpeg.org [79.124.17.100]) by master.gitmailbox.com (Postfix) with ESMTP id B6BA94A4F9 for ; Fri, 29 Mar 2024 03:24:55 +0000 (UTC) Received: from [127.0.1.1] (localhost [127.0.0.1]) by ffbox0-bg.mplayerhq.hu (Postfix) with ESMTP id 352C268D736; Fri, 29 Mar 2024 05:24:52 +0200 (EET) Received: from EUR02-DB5-obe.outbound.protection.outlook.com (mail-db5eur02olkn2037.outbound.protection.outlook.com [40.92.50.37]) by ffbox0-bg.mplayerhq.hu (Postfix) with ESMTPS id 8C43568D66C for ; Fri, 29 Mar 2024 05:24:45 +0200 (EET) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=RvrRUn4rv1WRUxOKbljKUsDzKeJb7NrmrIo9qbEvj0UZsHAOVPKNe5uM5CciBHadolPW+yHZ6z8nTToDGprcvAxiqwTDGjbFKoPrSwWuJo/myyrFfZoWQHw2FY99IHo2KFF09ICK439Av1AfrgDWVIQap6W76/kTz9RNJ+p6Jq1aXKTwdUI/ae5e5vY4nm1wXfwj5faa6Un/y7/yB5PDSvQeZf0jWGH1cEUIjE56wrYD5HCBM7/y1eKSeHzGWRSzG83dlxHGo4Y6k/fIXk2jBVazRuPmmdCbaQjiWi9auVwMlMxJLw7cy2ExSezofNHG9kvwRGTu352q9NB8hIQglQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=GGFPXxR2SOAG8LqVAp2pSWoRBoJa1o1dJWHuZIo/tRk=; b=WiCBuMkjc149U+L7Ys3RkFCj9eV2ZNGS5HaHnstTc6YJjya+tBOmy/Ut84nr0M2rYQQn2yULmTsg3roUxtcfR1iu1vkoyxI0qlE9XQfYMzCjMn2xu3dDuApsb1Eo6ygtaSh1cyNaqPk5k1bKQBkNY31QT2Ek7fbWP2dVhppHAz4OD9QCVJrrylAWtVx9A8FBPDWxMACHarwwLth6r+74+0wj/XIdJWS1z3JbsnE0Amu5nvfv1zsz0VYzXxIh9v7j+BKGj+ogHV9rbjYox4VxVDfmWtvTtX9cyUk4MJ6qSTolOLLwQlVhRn+gPIXcAIpFabhnsvGbo6GYH314tjNp1Q== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=none; dmarc=none; dkim=none; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=outlook.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=GGFPXxR2SOAG8LqVAp2pSWoRBoJa1o1dJWHuZIo/tRk=; b=DIUH9HZp+m46rlYK2L9rC4yMJ1qSI4oH94VnM4ZCLJuo4T2EL0heeAgzv+ghJ3SfzDxXbg97NuRJGnaoEfM6eI8MrFIQZ0FTVJqxdK2FOCv90SMpiI+S1AwSuoQCV58gulYgMhtzRpw1gf8Q4vdm7V97N+OCW25AdPaD+6SHqSVUhZRsidIHMAd5m2VdBzoWGueQVIjZpZFOD2J8hDikF+G5Tmdw9CJ8Ie2l7pjZseZdbWfh079m/EqCAsVG7EaNUWT03awyIVAb2N4l16pr9SlFbveeKfZPZ8Faq+BwAtRGJ6A2h18+okdSE0Zo69+16gpI8xh7nIQfTWnL66PL0Q== Received: from GV1P250MB0737.EURP250.PROD.OUTLOOK.COM (2603:10a6:150:8e::17) by PR3P250MB0116.EURP250.PROD.OUTLOOK.COM (2603:10a6:102:173::7) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7409.39; Fri, 29 Mar 2024 03:24:39 +0000 Received: from GV1P250MB0737.EURP250.PROD.OUTLOOK.COM ([fe80::4a3b:cf76:cddc:c68d]) by GV1P250MB0737.EURP250.PROD.OUTLOOK.COM ([fe80::4a3b:cf76:cddc:c68d%4]) with mapi id 15.20.7409.039; Fri, 29 Mar 2024 03:24:39 +0000 From: Andreas Rheinhardt To: ffmpeg-devel@ffmpeg.org Date: Fri, 29 Mar 2024 04:24:27 +0100 Message-ID: X-Mailer: git-send-email 2.40.1 In-Reply-To: References: X-TMN: [skJXWpXBbZqUymF4rmBjyDwxhOcjZs0We2S6kt3rH/U=] X-ClientProxiedBy: FR0P281CA0061.DEUP281.PROD.OUTLOOK.COM (2603:10a6:d10:49::16) To GV1P250MB0737.EURP250.PROD.OUTLOOK.COM (2603:10a6:150:8e::17) X-Microsoft-Original-Message-ID: <20240329032429.2305146-2-andreas.rheinhardt@outlook.com> MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: GV1P250MB0737:EE_|PR3P250MB0116:EE_ X-MS-Office365-Filtering-Correlation-Id: b08e0fd4-6acc-4408-28c2-08dc4f9fc3ca X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: /zTVgZiF6Nbxblewnr1eJsBtUl7T9ApRunzvt47ONGf9NWoUJYosS74fVW/e67BTuxDRvQpd7xG9RWW6NVnq7I8IKbhtBhxyLGDCBlZ59SXzz3wDFLIWC1tZD9Hb1Dizk8EuqTonEDLDuv+gNjbWjB+kMXP4H0Ry2MdIU4PeRYZdoAcJjSKLoabpwzMYMYKeMF3SpkQvpef21RC/G21IDFfQtH2MZrXvJGz7p5dX7LIEN5rZeNHp56G2uoRWwFB+1xoe1huMCnPM8Lhi/HSf1U4fvel0XYZFqFKzasN2hZ4o3Ns5qr1iEzOIOeFpEsa4f4W6BYsnvrFsZPGP7AsrYbCZ2cs2rM3X3rHu5fCPqypXfetfxYHMkZ690YTrP6/zKroW3iyZFlx0/d8gLt0aV2X9HvcqSgNklIjRmuPWVY9g/TzZkfYPPdE688u8iDBLD1SNpumN47wkUpmRDnAPCsM8Vvgf3laMjKEeSUwMn062bf6ccaicSbOYTMVi4H0pfu/PnrgwG/LSTJ0U7ZHxPeRNX+C9gI+Lob/8As8+PO1gXSy890xzP6A34vAEZfbUOH6awB1FrZ2H/txOgKCEbyv039kHbzXrDdB7VLkweWZlqZJPeRfUNoMq3qyoSPGQ X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?us-ascii?Q?BsOUe+rKc5MJm3UBj1HrUHEF5vrW0zW3MTjAu5UoBCjpra6VjIuBfGBVpWq0?= =?us-ascii?Q?45b7gFggINfrJgPMimzpH1VKzszUpLGFyg2WAmDCoOYIPcGZ20iZA/BMhXdz?= =?us-ascii?Q?6VNaMljAC2V2Anz+TF4UGeDguzLxfWLNsBMHnsrmPk1qyHxUnoaltTkxKyau?= =?us-ascii?Q?Wll/nQuBPqgpfJlweel9SESY35yERUfeu9P+te55e3uobd+AxbvOL4FXoE9T?= =?us-ascii?Q?Y9hAG40O5ycw3RaYbAOBZ1y9VlAXD//2+9NmwzmZTUq+SiDvJp8lOKJqO4S9?= =?us-ascii?Q?0XwT8O5r/6QeCDA8GZja+32XLAjdXlv8uv3tjpw3E4u5Qs+vQdAkRLXOcsoG?= =?us-ascii?Q?tZ6jpyDrVblt+Rg+h/DBmfvWfrAoqfdb+K9DtaNOLE0609sN1UT+v6O0JUJA?= =?us-ascii?Q?4ZQB16dcVP2P52bfnyaoXwD4flJF0Cyl7QCqhWvhDdVncfwTtX8HDuttDnYU?= =?us-ascii?Q?jMfgiYnJtaYqQHFv9boZB1siD1iJrywgxS+7qR0NOaABre6rYJ6QXARVzO6i?= =?us-ascii?Q?0ozYJb65JnM6yG7+qKdgViybRJJ/arw36ZNvRYfUFJEn9LTHq6k28tecCEzn?= =?us-ascii?Q?/NkpLu8huChl34Uo8mdsbCaatLBpyNxYqKV+JfmcMUG31pY7opJnbwnqWpE1?= =?us-ascii?Q?jI6T7SuoMuE1BEE9eRZEfQxbFqx4IMVKWS4dEMbaCw6408XiQnWS9igxNsFf?= =?us-ascii?Q?txLmRXKWOsaEKHRdh0q/NBLpc/HKqySRZFIg4lFQdqBHnWxZgyeXcZMmT7Mp?= =?us-ascii?Q?JOzCNKDMSYSccX7u/cML+zYfW/il9Isw8Yf6C23ZeraFiOTCdAFPUrRUuOn8?= =?us-ascii?Q?aRNg6FfSE7z4kAQzOcwYlLv7B9EHtnOIHKnVLtkhIYcBA0riFS9bpJFZRXVc?= =?us-ascii?Q?h+K+HZLqXudkuIVcuuf64TRgBZpGFAaNV7xsQQOT7mnItFiA8UZGfQEiFFU0?= =?us-ascii?Q?C7VR4Ve5Nnyolsd8W2jAky90Kzne45oH/PLM1o/uuKetp/Wvn2ot9XNpJ3TU?= =?us-ascii?Q?iWI15zAvOcfCuNaGoWykugmuWXW2+5pJAFwr6Be/aOBkxtb/c+I0QKHdxApC?= =?us-ascii?Q?lp9nRhmFtW/hsDjmC/bBYT2/Ys8N9F0iWVXDzkEAZSLGF/k6nPx+rA2kjtbM?= =?us-ascii?Q?XI45Z0XHJH6/uPv/Au6zZ5I16mLB1wY/YryUv8MbYk4usfpz+tM8pdHefs3s?= =?us-ascii?Q?LEYg8TRJrrtRnMihuskCVsU1rdrgjq7s4YaykBCrH8ynW/YDzbY6Q+fZGwJi?= =?us-ascii?Q?to1nKg4n7rMI1/3Z5hig5oC4Q5FMxB9mWn0+beTnOA=3D=3D?= X-OriginatorOrg: outlook.com X-MS-Exchange-CrossTenant-Network-Message-Id: b08e0fd4-6acc-4408-28c2-08dc4f9fc3ca X-MS-Exchange-CrossTenant-AuthSource: GV1P250MB0737.EURP250.PROD.OUTLOOK.COM X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 29 Mar 2024 03:24:38.4849 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 84df9e7f-e9f6-40af-b435-aaaaaaaaaaaa X-MS-Exchange-CrossTenant-RMS-PersistedConsumerOrg: 00000000-0000-0000-0000-000000000000 X-MS-Exchange-Transport-CrossTenantHeadersStamped: PR3P250MB0116 Subject: [FFmpeg-devel] [PATCH 3/5] avcodec/pngdsp: Fix unaligned accesses, effective type violations X-BeenThere: ffmpeg-devel@ffmpeg.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: FFmpeg development discussions and patches List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Reply-To: FFmpeg development discussions and patches Cc: Andreas Rheinhardt Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Errors-To: ffmpeg-devel-bounces@ffmpeg.org Sender: "ffmpeg-devel" Archived-At: List-Archive: List-Post: Affected the lscr fate-test (only visible on x86 if the SSE2 is disabled). Signed-off-by: Andreas Rheinhardt --- libavcodec/pngdsp.c | 25 +++++++++++++++++++------ 1 file changed, 19 insertions(+), 6 deletions(-) diff --git a/libavcodec/pngdsp.c b/libavcodec/pngdsp.c index 65916b1386..50ee96a684 100644 --- a/libavcodec/pngdsp.c +++ b/libavcodec/pngdsp.c @@ -21,20 +21,33 @@ #include "config.h" #include "libavutil/attributes.h" +#include "libavutil/intreadwrite.h" +#include "libavutil/macros.h" #include "png.h" #include "pngdsp.h" +#if HAVE_FAST_64BIT +#define BITS 64 +typedef uint64_t uint_native; +#else +#define BITS 32 +typedef uint32_t uint_native; +#endif +#define RN AV_JOIN(AV_RN, BITS) +#define RNA AV_JOIN(AV_JOIN(AV_RN, BITS), A) +#define WN AV_JOIN(AV_WN, BITS) + // 0x7f7f7f7f or 0x7f7f7f7f7f7f7f7f or whatever, depending on the cpu's native arithmetic size -#define pb_7f (~0UL / 255 * 0x7f) -#define pb_80 (~0UL / 255 * 0x80) +#define pb_7f (~(uint_native)0 / 255 * 0x7f) +#define pb_80 (~(uint_native)0 / 255 * 0x80) static void add_bytes_l2_c(uint8_t *dst, uint8_t *src1, uint8_t *src2, int w) { long i; - for (i = 0; i <= w - (int) sizeof(long); i += sizeof(long)) { - long a = *(long *)(src1 + i); - long b = *(long *)(src2 + i); - *(long *)(dst + i) = ((a & pb_7f) + (b & pb_7f)) ^ ((a ^ b) & pb_80); + for (i = 0; i <= w - (int) sizeof(uint_native); i += sizeof(uint_native)) { + uint_native a = RNA(src1 + i); + uint_native b = RN (src2 + i); + WN(dst + i, ((a & pb_7f) + (b & pb_7f)) ^ ((a ^ b) & pb_80)); } for (; i < w; i++) dst[i] = src1[i] + src2[i]; -- 2.40.1 _______________________________________________ ffmpeg-devel mailing list ffmpeg-devel@ffmpeg.org https://ffmpeg.org/mailman/listinfo/ffmpeg-devel To unsubscribe, visit link above, or email ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".