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 15CB44AC5A for ; Fri, 17 May 2024 20:00:31 +0000 (UTC) Received: from [127.0.1.1] (localhost [127.0.0.1]) by ffbox0-bg.mplayerhq.hu (Postfix) with ESMTP id 50FE668D12E; Fri, 17 May 2024 23:00:29 +0300 (EEST) Received: from JPN01-TYC-obe.outbound.protection.outlook.com (mail-tycjpn01on2103.outbound.protection.outlook.com [40.107.114.103]) by ffbox0-bg.mplayerhq.hu (Postfix) with ESMTPS id 955B368CA9C for ; Fri, 17 May 2024 23:00:21 +0300 (EEST) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=IYE1qQXCubCgjlwFuzPjTiJZqhxx9lRi6ITeaEwc1DmRG1m2kd8tQ3KoCDNCd7aA8Zs2dWilbfUp9cM9b90WHw3ginHuDBRBNL/INf6xs6kCcsjOWc/3MHTHKzNGf1X/IrDaUkE8BBqGe3PBQMZNObLYdWRo72p71Iv9AugHJq+/+VbXpGd6/EFG9xGa7Yn6W1EHTsKISQSLhz60TQn3FUX5ERlzkG3xueNJL7SwPfGkuWtmvr961TM2aDNT4+7hKFYH1j9L/hYfUIukNKBRSnyujm+16g7LmRk2HL1L0scgDaqjZmllgGANiZoPzn8QwPC4glf5W57lqR+shmlLSw== 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=JS+WCsjqdZn/wF89bBOP+H3g/xhOvmDG29SpT4HzKrQ=; b=YZ1oGhuLfdlvC4zCku4jzFo1WOTRaq+8bR4voDsSCkeAVMM+I76TEQkeB3GDQIWVDmPML8fNvUfx+tIjkdFH7E6Bg77Y8NcLeVFcLKdPzxWXxa9SSyXNhRLA1P/bGDxs2fjXsG+PuA7D6Vr4yQhDPzF64Fyb4u8M35qG/daFwbBPItyavLyzjR9p1QuZHILTSM9UVNau61RXvakc4y26q5I9x97f/kIYwJ9u4o8q7DOws7kN7o/KE/2eHv5CYU7eZ9OUrgNch/JSLfiaqXh4rhz59CaHF+n9ZQFlgpaqciEsWiMnpIjdtOHBf0SWj6SVN7YsH3LxZxEMRrwxf2LBvg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=es.takushoku-u.ac.jp; dmarc=pass action=none header.from=es.takushoku-u.ac.jp; dkim=pass header.d=es.takushoku-u.ac.jp; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=takushoku.onmicrosoft.com; s=selector2-takushoku-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=JS+WCsjqdZn/wF89bBOP+H3g/xhOvmDG29SpT4HzKrQ=; b=b2mnGOC4XjqH9qVC3MzokyamczjfxcrmpoIAJeytDZlTtJZRsc9JvowBL6zwlyXt6QoS4fAXqeZYVfizeYdKQqOdQ8OWgISLvqvRq2d6cj9R3QsCCSzzfpzbmsNGPWm5pT03WUSzGyV5M2oonouSwKPJvhBqqivCq3IUkMWQHaQ= Received: from OS0PR01MB6001.jpnprd01.prod.outlook.com (2603:1096:604:b7::12) by TYCPR01MB11291.jpnprd01.prod.outlook.com (2603:1096:400:3c1::11) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7587.30; Fri, 17 May 2024 20:00:17 +0000 Received: from OS0PR01MB6001.jpnprd01.prod.outlook.com ([fe80::181c:c1f4:9b58:f6cc]) by OS0PR01MB6001.jpnprd01.prod.outlook.com ([fe80::181c:c1f4:9b58:f6cc%6]) with mapi id 15.20.7587.028; Fri, 17 May 2024 20:00:17 +0000 From: WATANABE Osamu To: "ffmpeg-devel@ffmpeg.org" Thread-Topic: [PATCH] avcodec/jpeg2000dec: fix HT block decoder issue #10905 Thread-Index: AQHaqJTWziZE09NHiE2iAaYsAXmiVQ== Date: Fri, 17 May 2024 20:00:16 +0000 Message-ID: Accept-Language: en-US, ja-JP Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: authentication-results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=es.takushoku-u.ac.jp; x-ms-publictraffictype: Email x-ms-traffictypediagnostic: OS0PR01MB6001:EE_|TYCPR01MB11291:EE_ x-ms-office365-filtering-correlation-id: c8d536b7-2d74-4c67-9020-08dc76abf909 x-ms-exchange-senderadcheck: 1 x-ms-exchange-antispam-relay: 0 x-microsoft-antispam: BCL:0; ARA:13230031|376005|41320700004|1800799015|366007|38070700009; x-microsoft-antispam-message-info: =?iso-2022-jp?B?WVM4UHpoUHRZN01xajZZS0pmNy9kUjB3b1hqRnFzem13TXMveENhKzVD?= =?iso-2022-jp?B?bmNJSVZXT3ZaSmt2WFJYLzdkVmRCeTllNUdiUXFlT1RkbjJjM21GbGV6?= =?iso-2022-jp?B?VGZmQUdnZmRpYWRPTXZxSXVaSTBYSmlweFRsNFFVS1dqQjJaOEJCL0Fm?= =?iso-2022-jp?B?ejZvRnhSWlpTdEg4ZmlKbkhHKzhrd0IxNnE5aWFjU284UmhYaXRjWkxS?= =?iso-2022-jp?B?T0ZsQ2RxS3V0RDNseXFhc3hiRmZOV0dNNlJRTUJlcEtKRXA2RjdtWk9m?= =?iso-2022-jp?B?dUdodisrMEdVM3JaYkkwY1NGcjcvN3NtTXluRitYK0pkVFc2QlVJSVhW?= =?iso-2022-jp?B?Vi9MdWxrbytuaWQrTzFUeGQ3aGlXYkhXSWVXTWNrdDBWZ1RvWGFIYUlD?= =?iso-2022-jp?B?aXNUb1pXN1QrR21vMkhwdHNGYm1vL0wrbGJqdkNtdlNTOHBqNy9qZnR5?= =?iso-2022-jp?B?L1pRV3hZZTlHU0JoemxFSkFOVHptbFhoNHNUak9qZGtoZUdSTFlFNm9z?= =?iso-2022-jp?B?aGkrVmdYTTVmUVVJdVJXczVrMG05Z3RmZW1hZytscVdDeVRrVlJUMm53?= =?iso-2022-jp?B?cjVuN2FnUmlzSU5UN1Q2WkxFVmEwNnFFMUVqU0VIQzhaMjYwZDF3NnFQ?= =?iso-2022-jp?B?UGRwZWpoU1VDZUt4OFBWcDhzSHBiVWpuNTl5OHZTbk50WG1tSzZQTDBO?= =?iso-2022-jp?B?djM4R1JwaG4wVkxYN055SzJZYlJ3cVU2NUl3bFdqeWRrRU1yOGZMRGt2?= =?iso-2022-jp?B?bjZQWk1ET2lxNUVxRmdweFpCUUt4ZVdhbm1hQ1VkaTRibGZQQ0M1REg5?= =?iso-2022-jp?B?WlBkQjJJMlNmdFdoZlk5SnZiQUtXb2c0b09yYlBVL3VzRmcyRFJHN1Qz?= =?iso-2022-jp?B?bTBGckRpZW5Fb3BnbXpCVlNlUk5jODMrUDZ3TWNMNWYxR3BHcDc0b1dD?= =?iso-2022-jp?B?L3JxMVUyQVN3VEZlYUpPZjZ1UiswclZUeDZMNXU4SFBQc0NwQTFBbjhX?= =?iso-2022-jp?B?cTk5NldwZDZaTHVxWU9RNHQ2aVZZZjBsN3RpNDQ3SFUzRWFJYWdTVWdN?= =?iso-2022-jp?B?KzZWbHhaWVFlVVpDMndUbm9oVTFLVXlZZ2E1L0FFOVRndWpHVTE1ajk0?= =?iso-2022-jp?B?anZ1N3ZhdUpyckwwRmY3eE05S3R1cnFKVWZVME1JZUhzMXNoRXBZM1d2?= =?iso-2022-jp?B?QzhTN3orSXBIdEQ1YVltUG1ZS3QyUDVmbTF3RkNEQVF4Mi9IUVJ0N2w4?= =?iso-2022-jp?B?MDZEUnI1Y2tMc21wZ3duc1NWN2YvV0lnM1RjSkhvejJrbVF6QjRTOTBR?= =?iso-2022-jp?B?Z1ZIRGYycE0wUkdYNXZPVTVhQ2VxNG14OVFzTTA4R0xxSE9QZTJ4U3Fs?= =?iso-2022-jp?B?ZFN6ditrQlFIUzhxRVZLMW02Vk02V0VjZ3BtRjYwZy9oTC9XQldrbVEz?= =?iso-2022-jp?B?d1FJeE9DelphNEl2aHN6NXYzeXdaR0lXYzlUem9HSUZxanJwbi9hdmxj?= =?iso-2022-jp?B?YTJ3TTdveTBRVHN4Mk5KU1VPaG9NYXU4VE1BTm5KU1c4NnFZK0RZemlY?= =?iso-2022-jp?B?ZXBhOWE5RUVJVlorMDliZ0I2cmxJS0NmRlJDQ3E0OXFDRXcyQjFCeDYr?= =?iso-2022-jp?B?QnhoZ09UUnNIWnUxZERmcjZ5blV2TmY5MkNlMm9mNjcraGNYNE5zcGNV?= =?iso-2022-jp?B?VGc0NlRxSGlKSHJnOXlQaFF6bGhGUUd4aHdCU3Q4QjVUQWk2NzlXTTZy?= =?iso-2022-jp?B?ZTRvTXUvUnlDSm5YM3RtZlVINWIyWk9RclpCNHdYakNXU29WWDVsNkFv?= =?iso-2022-jp?B?c2Y3UjRsT0JsbnNWZDBwRFdNMVI1MlIwTjNXWmx6RkoyS0FKV0R1QjZS?= =?iso-2022-jp?B?V3A2LzFMenBZRTRWd2MzVzNOeHFLcEtuZVFWVmx1S2FJd3RHanF0ZVZ6?= =?iso-2022-jp?B?Y05sMlhiSkVOL1VvL2lXZ3lZU0hpZz09?= x-forefront-antispam-report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:OS0PR01MB6001.jpnprd01.prod.outlook.com; PTR:; CAT:NONE; SFS:(13230031)(376005)(41320700004)(1800799015)(366007)(38070700009); DIR:OUT; SFP:1102; x-ms-exchange-antispam-messagedata-chunkcount: 1 x-ms-exchange-antispam-messagedata-0: =?iso-2022-jp?B?Rm5ydnp0RFVDRHdGTHl1SDhTOGwyRGhlVmZoU1lEdWtaTlZvQXF1V2p3?= =?iso-2022-jp?B?dXpORVhBRmtSdER6bndNUnRwd3ZTa1diWUNSWUgyOGlvNHpMYjcrc1Q5?= =?iso-2022-jp?B?N3hmWWJNajV3TlFVOEVhcUpnbU0zTVVYYUNYaGtDK3pLTjVFN0RjR2dT?= =?iso-2022-jp?B?L3lzbCs5TS9Hc295dFNGaERUMnpSak5nK0RiMFZQMDVOb3RLdmQ2TVhZ?= =?iso-2022-jp?B?T1RseGkzUXNrMUtrd2swaDF3WGlvNWdvaCtZWTdSQk9mc1dpb1p4ejhr?= =?iso-2022-jp?B?RUZDOElWdkpTSTdxZHNON0ZIQ052anQ5VEFSRVFTSjFMdXk3MXBGaXlJ?= =?iso-2022-jp?B?U0lEbnVaNHBsRHBpTGZoV0VMQUNrLzIwVDVDM1RWSmVqMFFwcjdUVFEy?= =?iso-2022-jp?B?b1Iyb0ErUXFrcE9JOHpHRXN0MW51L1djbXNBUEhTRGtzOURzMnp0MHV3?= =?iso-2022-jp?B?Q0U5SkxVWm5lNUZpNGcwQ0xiK2dkQmpxa3hZSEtibkM1Rzl2R0hEczlW?= =?iso-2022-jp?B?Mi9JZ1o5aFdDWjBzdmR2QXA2MGtnMWtjY3ZheWQ2WmRpUENIVUdXUitO?= =?iso-2022-jp?B?dnM4ZUFiOGJWSXo4VDNGWlBvdHF5NG5jU2tjdm1EaWY1Q01kRkhJVlgv?= =?iso-2022-jp?B?dXRhVHByQVBxQU1CNkFlZzJ5TkdUTDlaK1JiSjNSbXNWT1lwdmdmV2RL?= =?iso-2022-jp?B?T2hMNUYvSk9Cak8vV216bDNsaC9sSEtISVZqWENET1ozTVJocXU5SVQ2?= =?iso-2022-jp?B?ZDMrSWdjZmVxUGo0YkZ0ZGxOVFF6SW10aGxFS045M0x0TXhaSGJGOVRH?= =?iso-2022-jp?B?OG1iQi8zaVZSM1ZVQ2JMRThqNjU5TWNwUjBMLzJRWGNCa3o2d0VmVjVE?= =?iso-2022-jp?B?SjlTRFYvb0VwVUduQXlsd2ZKc3hJdkpjdUZFbGx6ZUp2bk90RmJXWG91?= =?iso-2022-jp?B?MmRDeFhIUThsbE9iTzNQTGUzcm1OTW1HaDR0WkFLaEowaUxjZ0RTcC9n?= =?iso-2022-jp?B?S092VEVCZFhHWXhVaUJxUmhiaU9pZmZhNW5KQm1oUHVUVll6eHlMVGpE?= =?iso-2022-jp?B?cmhvZTNtUEM0MENCeEVtdWxtV2FIZU1DdTN5OHBrdWE0QUx4UlRaSUV1?= =?iso-2022-jp?B?Z3g0T3Z5TFExYlpqMHlqKzYrSGpjWXJuSDZxaXhDeVY5R25CMTZWcVZj?= =?iso-2022-jp?B?WDJLeXNtaXRWS0pOK3RkcWhMblRqb1VmM3I0dTF2djBqeGxCdFEreHBX?= =?iso-2022-jp?B?bkNBOW5ZYmErR0JxQWpPQ0dEa0F6cDNvSkl6Y01QNDBmT2NQcEdTQytn?= =?iso-2022-jp?B?WnlENHhpK2FqNFZUS0YvdkNaeUZoYXRvZFRjQ3RVajBWeHRyYjh5MGJG?= =?iso-2022-jp?B?VGxQZzJKV0d1MFBQRmtVVjJESm1scHcyUHhsdU9WUUQ1VmhTR1pLYXRk?= =?iso-2022-jp?B?YlVlUTBkK3RZZk0vQ2NwcXo2TDhDVk9DOUhZajVtNDlaOVR5bVg5RDgv?= =?iso-2022-jp?B?dWw0Zkw5Z3RDUTJFQ0l4dkRzU29JYmNkcUdERG5kQk1DV0FxMExFZ1dQ?= =?iso-2022-jp?B?Y0JHYitjYnBoWU9USmJkTmVRRjhiMy9HcDdOUFZ6WWQyOUJhbUh0Q29B?= =?iso-2022-jp?B?UjV0M0tXSzJLWVZZMEtoUng5eTlHYlJaMTZtTFNCejA2N3NMRG5DUTRB?= =?iso-2022-jp?B?OCtVdTlJRTRvV1pUU25FNlBOVS9LR2tyaURmVlVnNGxjYTJEdkJiWFl2?= =?iso-2022-jp?B?N294c3BTc1hOUXkyd1R4aXU3RzhqeEpyNUZHa2ZxaUZyeE8waUVLNFlU?= =?iso-2022-jp?B?UFlzRGVacXJOK0VNOFNheFRkZ1Q0Qk5xM0hicGxkZUlvT1FKZFNrUXNO?= =?iso-2022-jp?B?dnZ0blp1ZEc3Y2RVMXpsTXdKWkcxbzM0S1VlcFRjekY0cFhnOVM0VzVx?= =?iso-2022-jp?B?dC9vVzRUYjhOc1ZWa1pzRm0vcm10bjFlS0dDNHRSNG9yY2xIcFRsY0NO?= =?iso-2022-jp?B?bUIzb2lNT1NOcGRxZHpHY1RVamp6MHJjQWdIT1g2RjFlRHg5dUl2Mlpj?= =?iso-2022-jp?B?aVU2NlVrUnJKaFczYTdHZ2lNK05lWGlVVjlYaFdDYnpMaDhlaGJNSlFi?= =?iso-2022-jp?B?YjlacTBpQ0VxcXk5NW9USlo5Y0wvRzkrbnh2WEJGTzZBMkZDbjdDelN2?= =?iso-2022-jp?B?UnB6SjJEclI0ckJ3NkFBeU5zaURjYndmWWY0bElEUFVTWVJKUXd0dGpQ?= =?iso-2022-jp?B?VXBUOHhKOGZ1VXpTclBwRCtmUzBUeHBuTWZKaEJ3TUNVWWJRZ1BLOWpo?= =?iso-2022-jp?B?SzFLNDNyZWpvS2w2Z2Y4SjZFMU1Wa09QcjgwVmphTnErR0kxM05tZ0Nv?= =?iso-2022-jp?B?RGFYT0xubWh0ODdPbzdNTXc2OFFNcjNYNzh1Z3Z0UXJwS0JWV2hoV01Q?= =?iso-2022-jp?B?Rnc4dXd3TCtnWC9XNUVJWlE4Z3l0UFVLTmpvPQ==?= Content-ID: <1071C2DF81B0254091897112A012CEFB@jpnprd01.prod.outlook.com> MIME-Version: 1.0 X-OriginatorOrg: es.takushoku-u.ac.jp X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-AuthSource: OS0PR01MB6001.jpnprd01.prod.outlook.com X-MS-Exchange-CrossTenant-Network-Message-Id: c8d536b7-2d74-4c67-9020-08dc76abf909 X-MS-Exchange-CrossTenant-originalarrivaltime: 17 May 2024 20:00:16.8970 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 853333e5-13b1-4738-ae04-bfb589cf2665 X-MS-Exchange-CrossTenant-mailboxtype: HOSTED X-MS-Exchange-CrossTenant-userprincipalname: /OjZo8kM0zBP8NSMp2IYn1o+6ciM/CMSIMeb3VrrmMKJGZ/V9QWZldHGtYu5XewhryDTxbgJSwFQv5v9jhiy7P6vwlACVDbocqKkg8QXOiM= X-MS-Exchange-Transport-CrossTenantHeadersStamped: TYCPR01MB11291 Subject: [FFmpeg-devel] [PATCH] avcodec/jpeg2000dec: fix HT block decoder issue #10905 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: Pierre-Anthony Lemieux 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: Signed-off-by: Pierre-Anthony Lemieux --- libavcodec/jpeg2000htdec.c | 122 ++++++++++++----------- tests/ref/fate/jpeg2000dec-ds0_ht_01_b11 | 2 +- 2 files changed, 63 insertions(+), 61 deletions(-) diff --git a/libavcodec/jpeg2000htdec.c b/libavcodec/jpeg2000htdec.c index fa704b665e..62f70c32a8 100644 --- a/libavcodec/jpeg2000htdec.c +++ b/libavcodec/jpeg2000htdec.c @@ -196,7 +196,7 @@ static void jpeg2000_bitbuf_refill_forward(StateVars *buffer, const uint8_t *arr while (buffer->bits_left < 32) { buffer->tmp = 0xFF; buffer->bits = (buffer->last == 0xFF) ? 7 : 8; - if (buffer->pos <= length) { + if (buffer->pos < length) { buffer->tmp = array[buffer->pos]; buffer->pos += 1; buffer->last = buffer->tmp; @@ -508,17 +508,17 @@ static int jpeg2000_decode_sig_emb(const Jpeg2000DecoderContext *s, MelDecoderSt } av_always_inline -static int jpeg2000_get_state(int x1, int x2, int width, int shift_by, +static int jpeg2000_get_state(int x1, int x2, int stride, int shift_by, const uint8_t *block_states) { - return (block_states[(x1 + 1) * (width + 2) + (x2 + 1)] >> shift_by) & 1; + return (block_states[(x1 + 1) * stride + (x2 + 1)] >> shift_by) & 1; } av_always_inline -static void jpeg2000_modify_state(int x1, int x2, int width, - int value, uint8_t *block_states) +static void jpeg2000_modify_state(int x1, int x2, int stride, + int value, uint8_t *block_states) { - block_states[(x1 + 1) * (width + 2) + (x2 + 1)] |= value; + block_states[(x1 + 1) * stride + (x2 + 1)] |= value; } av_always_inline @@ -528,8 +528,8 @@ static int jpeg2000_decode_ht_cleanup_segment(const Jpeg2000DecoderContext *s, StateVars *mel_stream, StateVars *vlc_stream, StateVars *mag_sgn_stream, const uint8_t *Dcup, uint32_t Lcup, uint32_t Pcup, uint8_t pLSB, - int width, int height, int32_t *sample_buf, - uint8_t *block_states) + int width, int height, const int stride, + int32_t *sample_buf, uint8_t *block_states) { uint16_t q = 0; // Represents current quad position uint16_t q1, q2; @@ -958,32 +958,32 @@ static int jpeg2000_decode_ht_cleanup_segment(const Jpeg2000DecoderContext *s, j1 = 2 * y; j2 = 2 * x; - sample_buf[j2 + (j1 * width)] = (int32_t)*mu; - jpeg2000_modify_state(j1, j2, width, *sigma, block_states); + sample_buf[j2 + (j1 * stride)] = (int32_t)*mu; + jpeg2000_modify_state(j1, j2, stride, *sigma, block_states); sigma += 1; mu += 1; x1 = y != quad_height - 1 || is_border_y == 0; - sample_buf[j2 + ((j1 + 1) * width)] = ((int32_t)*mu) * x1; - jpeg2000_modify_state(j1 + 1, j2, width, (*sigma) * x1, block_states); + sample_buf[j2 + ((j1 + 1) * stride)] = ((int32_t)*mu) * x1; + jpeg2000_modify_state(j1 + 1, j2, stride, (*sigma) * x1, block_states); sigma += 1; mu += 1; x2 = x != quad_width - 1 || is_border_x == 0; - sample_buf[(j2 + 1) + (j1 * width)] = ((int32_t)*mu) * x2; - jpeg2000_modify_state(j1, j2 + 1, width, (*sigma) * x2, block_states); + sample_buf[(j2 + 1) + (j1 * stride)] = ((int32_t)*mu) * x2; + jpeg2000_modify_state(j1, j2 + 1, stride, (*sigma) * x2, block_states); sigma += 1; mu += 1; x3 = x1 | x2; - sample_buf[(j2 + 1) + (j1 + 1) * width] = ((int32_t)*mu) * x3; - jpeg2000_modify_state(j1 + 1, j2 + 1, width, (*sigma) * x3, block_states); + sample_buf[(j2 + 1) + (j1 + 1) * stride] = ((int32_t)*mu) * x3; + jpeg2000_modify_state(j1 + 1, j2 + 1, stride, (*sigma) * x3, block_states); sigma += 1; mu += 1; } } ret = 1; -free: + free: av_freep(&sigma_n); av_freep(&E); av_freep(&mu_n); @@ -992,39 +992,39 @@ free: static void jpeg2000_calc_mbr(uint8_t *mbr, const uint16_t i, const uint16_t j, const uint32_t mbr_info, uint8_t causal_cond, - uint8_t *block_states, int width) + uint8_t *block_states, int stride) { int local_mbr = 0; - local_mbr |= jpeg2000_get_state(i - 1, j - 1, width, HT_SHIFT_SIGMA, block_states); - local_mbr |= jpeg2000_get_state(i - 1, j + 0, width, HT_SHIFT_SIGMA, block_states); - local_mbr |= jpeg2000_get_state(i - 1, j + 1, width, HT_SHIFT_SIGMA, block_states); + local_mbr |= jpeg2000_get_state(i - 1, j - 1, stride, HT_SHIFT_SIGMA, block_states); + local_mbr |= jpeg2000_get_state(i - 1, j + 0, stride, HT_SHIFT_SIGMA, block_states); + local_mbr |= jpeg2000_get_state(i - 1, j + 1, stride, HT_SHIFT_SIGMA, block_states); - local_mbr |= jpeg2000_get_state(i + 0, j - 1, width, HT_SHIFT_SIGMA, block_states); - local_mbr |= jpeg2000_get_state(i + 0, j + 1, width, HT_SHIFT_SIGMA, block_states); + local_mbr |= jpeg2000_get_state(i + 0, j - 1, stride, HT_SHIFT_SIGMA, block_states); + local_mbr |= jpeg2000_get_state(i + 0, j + 1, stride, HT_SHIFT_SIGMA, block_states); - local_mbr |= jpeg2000_get_state(i + 1, j - 1, width, HT_SHIFT_SIGMA, block_states) * causal_cond; - local_mbr |= jpeg2000_get_state(i + 1, j + 0, width, HT_SHIFT_SIGMA, block_states) * causal_cond; - local_mbr |= jpeg2000_get_state(i + 1, j + 1, width, HT_SHIFT_SIGMA, block_states) * causal_cond; + local_mbr |= jpeg2000_get_state(i + 1, j - 1, stride, HT_SHIFT_SIGMA, block_states) * causal_cond; + local_mbr |= jpeg2000_get_state(i + 1, j + 0, stride, HT_SHIFT_SIGMA, block_states) * causal_cond; + local_mbr |= jpeg2000_get_state(i + 1, j + 1, stride, HT_SHIFT_SIGMA, block_states) * causal_cond; - local_mbr |= jpeg2000_get_state(i - 1, j - 1, width, HT_SHIFT_REF, block_states) * - jpeg2000_get_state(i - 1, j - 1, width, HT_SHIFT_SCAN, block_states); - local_mbr |= jpeg2000_get_state(i - 1, j + 0, width, HT_SHIFT_REF, block_states) * - jpeg2000_get_state(i - 1, j - 1, width, HT_SHIFT_SCAN, block_states); - local_mbr |= jpeg2000_get_state(i - 1, j + 1, width, HT_SHIFT_REF, block_states) * - jpeg2000_get_state(i - 1, j + 1, width, HT_SHIFT_SCAN, block_states); + local_mbr |= jpeg2000_get_state(i - 1, j - 1, stride, HT_SHIFT_REF, block_states) * + jpeg2000_get_state(i - 1, j - 1, stride, HT_SHIFT_SCAN, block_states); + local_mbr |= jpeg2000_get_state(i - 1, j + 0, stride, HT_SHIFT_REF, block_states) * + jpeg2000_get_state(i - 1, j - 1, stride, HT_SHIFT_SCAN, block_states); + local_mbr |= jpeg2000_get_state(i - 1, j + 1, stride, HT_SHIFT_REF, block_states) * + jpeg2000_get_state(i - 1, j + 1, stride, HT_SHIFT_SCAN, block_states); - local_mbr |= jpeg2000_get_state(i + 0, j - 1, width, HT_SHIFT_REF, block_states) * - jpeg2000_get_state(i + 0, j - 1, width, HT_SHIFT_SCAN, block_states); - local_mbr |= jpeg2000_get_state(i + 0, j + 1, width, HT_SHIFT_REF, block_states) * - jpeg2000_get_state(i + 0, j + 1, width, HT_SHIFT_SCAN, block_states); + local_mbr |= jpeg2000_get_state(i + 0, j - 1, stride, HT_SHIFT_REF, block_states) * + jpeg2000_get_state(i + 0, j - 1, stride, HT_SHIFT_SCAN, block_states); + local_mbr |= jpeg2000_get_state(i + 0, j + 1, stride, HT_SHIFT_REF, block_states) * + jpeg2000_get_state(i + 0, j + 1, stride, HT_SHIFT_SCAN, block_states); - local_mbr |= jpeg2000_get_state(i + 1, j - 1, width, HT_SHIFT_REF, block_states) * - jpeg2000_get_state(i + 1, j - 1, width, HT_SHIFT_SCAN, block_states) * causal_cond; - local_mbr |= jpeg2000_get_state(i + 1, j + 0, width, HT_SHIFT_REF, block_states) * - jpeg2000_get_state(i + 1, j + 0, width, HT_SHIFT_SCAN, block_states) * causal_cond; - local_mbr |= jpeg2000_get_state(i + 1, j + 1, width, HT_SHIFT_REF, block_states) * - jpeg2000_get_state(i + 1, j + 1, width, HT_SHIFT_SCAN, block_states) * causal_cond; + local_mbr |= jpeg2000_get_state(i + 1, j - 1, stride, HT_SHIFT_REF, block_states) * + jpeg2000_get_state(i + 1, j - 1, stride, HT_SHIFT_SCAN, block_states) * causal_cond; + local_mbr |= jpeg2000_get_state(i + 1, j + 0, stride, HT_SHIFT_REF, block_states) * + jpeg2000_get_state(i + 1, j + 0, stride, HT_SHIFT_SCAN, block_states) * causal_cond; + local_mbr |= jpeg2000_get_state(i + 1, j + 1, stride, HT_SHIFT_REF, block_states) * + jpeg2000_get_state(i + 1, j + 1, stride, HT_SHIFT_SCAN, block_states) * causal_cond; *mbr |= local_mbr; } @@ -1040,18 +1040,18 @@ static void jpeg2000_process_stripes_block(StateVars *sig_prop, int i_s, int j_s int modify_state, cond; uint8_t bit; uint8_t causal_cond = i != (i_s + height - 1); - int32_t *sp = &sample_buf[j + (i * (stride - 2))]; + int32_t *sp = &sample_buf[j + (i * (stride))]; uint8_t mbr = 0; if (jpeg2000_get_state(i, j, stride - 2, HT_SHIFT_SIGMA, block_states) == 0) - jpeg2000_calc_mbr(&mbr, i, j, mbr_info & 0x1EF, causal_cond, block_states, stride - 2); + jpeg2000_calc_mbr(&mbr, i, j, mbr_info & 0x1EF, causal_cond, block_states, stride); mbr_info >>= 3; cond = mbr != 0; bit = jpeg2000_peek_bit(sig_prop, magref_segment, magref_length); *sp |= (bit * cond) << pLSB; sig_prop->bits -= cond; modify_state = (((1 << HT_SHIFT_REF_IND) | (1 << HT_SHIFT_REF)) * cond) | 1 << HT_SHIFT_SCAN; - jpeg2000_modify_state(i, j, stride - 2, modify_state, block_states); + jpeg2000_modify_state(i, j, stride, modify_state, block_states); } } } @@ -1060,8 +1060,8 @@ static void jpeg2000_process_stripes_block(StateVars *sig_prop, int i_s, int j_s * See procedure decodeSigPropMag at Rec. ITU-T T.814, 7.4. */ av_noinline -static void jpeg2000_decode_sigprop_segment(Jpeg2000Cblk *cblk, uint16_t width, - uint16_t height, uint8_t *magref_segment, +static void jpeg2000_decode_sigprop_segment(Jpeg2000Cblk *cblk, uint16_t width, uint16_t height, + const int stride, uint8_t *magref_segment, uint32_t magref_length, uint8_t pLSB, int32_t *sample_buf, uint8_t *block_states) { @@ -1071,7 +1071,6 @@ static void jpeg2000_decode_sigprop_segment(Jpeg2000Cblk *cblk, uint16_t width, const uint16_t num_h_stripe = width / 4; int b_width = 4; int b_height = 4; - int stride = width + 2; int last_width; uint16_t i = 0, j = 0; @@ -1114,7 +1113,7 @@ static void jpeg2000_decode_sigprop_segment(Jpeg2000Cblk *cblk, uint16_t width, * See procedure decodeSigPropMag at Rec. ITU-T T.814, 7.5. */ static int -jpeg2000_decode_magref_segment( uint16_t width, uint16_t block_height, +jpeg2000_decode_magref_segment( uint16_t width, uint16_t block_height, const int stride, uint8_t *magref_segment,uint32_t magref_length, uint8_t pLSB, int32_t *sample_buf, uint8_t *block_states) { @@ -1134,7 +1133,7 @@ jpeg2000_decode_magref_segment( uint16_t width, uint16_t block_height, * We move column wise, going from one quad to another. See * Rec. ITU-T T.814, Figure 7. */ - sp = &sample_buf[j + i * width]; + sp = &sample_buf[j + i * stride]; if (jpeg2000_get_state(i, j, width, HT_SHIFT_SIGMA, block_states) != 0) { jpeg2000_modify_state(i, j, width, 1 << HT_SHIFT_REF_IND, block_states); *sp |= jpeg2000_import_magref_bit(&mag_ref, magref_segment, magref_length) << pLSB; @@ -1146,7 +1145,7 @@ jpeg2000_decode_magref_segment( uint16_t width, uint16_t block_height, height = block_height % 4; for (int j = 0; j < width; j++) { for (int i = i_start; i < i_start + height; i++) { - sp = &sample_buf[j + i * width]; + sp = &sample_buf[j + i * stride]; if (jpeg2000_get_state(i, j, width, HT_SHIFT_SIGMA, block_states) != 0) { jpeg2000_modify_state(i, j, width, 1 << HT_SHIFT_REF_IND, block_states); *sp |= jpeg2000_import_magref_bit(&mag_ref, magref_segment, magref_length) << pLSB; @@ -1194,6 +1193,9 @@ ff_jpeg2000_decode_htj2k(const Jpeg2000DecoderContext *s, Jpeg2000CodingStyle *c int32_t M_b = magp; + const int quad_buf_width = width + 4; + const int quad_buf_height = height + 4; + /* codeblock size as constrained by Rec. ITU-T T.800, Table A.18 */ av_assert0(width <= 1024U && height <= 1024U); av_assert0(width * height <= 4096); @@ -1261,23 +1263,23 @@ ff_jpeg2000_decode_htj2k(const Jpeg2000DecoderContext *s, Jpeg2000CodingStyle *c jpeg2000_init_mel_decoder(&mel_state); - sample_buf = av_calloc((width + 4) * (height + 4), sizeof(int32_t)); - block_states = av_calloc((width + 4) * (height + 4), sizeof(uint8_t)); + sample_buf = av_calloc(quad_buf_width * quad_buf_height, sizeof(int32_t)); + block_states = av_calloc(quad_buf_width * quad_buf_height, sizeof(uint8_t)); if (!sample_buf || !block_states) { ret = AVERROR(ENOMEM); goto free; } if ((ret = jpeg2000_decode_ht_cleanup_segment(s, cblk, t1, &mel_state, &mel, &vlc, - &mag_sgn, Dcup, Lcup, Pcup, pLSB, width, - height, sample_buf, block_states)) < 0) { + &mag_sgn, Dcup, Lcup, Pcup, pLSB, width, + height, quad_buf_width, sample_buf, block_states)) < 0) { av_log(s->avctx, AV_LOG_ERROR, "Bad HT cleanup segment\n"); goto free; } if (cblk->npasses > 1) - jpeg2000_decode_sigprop_segment(cblk, width, height, Dref, Lref, - pLSB - 1, sample_buf, block_states); + jpeg2000_decode_sigprop_segment(cblk, width, height, quad_buf_width, Dref, Lref, + pLSB - 1, sample_buf, block_states); if (cblk->npasses > 2) { @@ -1286,7 +1288,7 @@ ff_jpeg2000_decode_htj2k(const Jpeg2000DecoderContext *s, Jpeg2000CodingStyle *c ret = AVERROR_INVALIDDATA; goto free; } - if ((ret = jpeg2000_decode_magref_segment(width, height, Dref, Lref, + if ((ret = jpeg2000_decode_magref_segment(width, height, quad_buf_width, Dref, Lref, pLSB - 1, sample_buf, block_states)) < 0) goto free; } @@ -1297,14 +1299,14 @@ ff_jpeg2000_decode_htj2k(const Jpeg2000DecoderContext *s, Jpeg2000CodingStyle *c for (int y = 0; y < height; y++) { for (int x = 0; x < width; x++) { n = x + (y * t1->stride); - val = sample_buf[x + (y * width)]; + val = sample_buf[x + (y * quad_buf_width)]; /* Convert sign-magnitude to two's complement. */ val = val >> 31 ? 0x80000000 - val : val; val >>= (pLSB - 1); t1->data[n] = val; } } -free: + free: av_freep(&sample_buf); av_freep(&block_states); return ret; diff --git a/tests/ref/fate/jpeg2000dec-ds0_ht_01_b11 b/tests/ref/fate/jpeg2000dec-ds0_ht_01_b11 index af3eaa086d..d923cc2109 100644 --- a/tests/ref/fate/jpeg2000dec-ds0_ht_01_b11 +++ b/tests/ref/fate/jpeg2000dec-ds0_ht_01_b11 @@ -3,4 +3,4 @@ #codec_id 0: rawvideo #dimensions 0: 128x128 #sar 0: 0/1 -0, 0, 0, 1, 16384, 0x44426324 +0, 0, 0, 1, 16384, 0x04a3647e -- 2.25.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".