[prev in list] [next in list] [prev in thread] [next in thread] 

List:       wine-devel
Subject:    Re: [PATCH] msi: Fix a buffer overrun.
From:       Austin English <austinenglish () gmail ! com>
Date:       2017-06-29 16:27:24
Message-ID: CACC5Q1cQS6viCC+qQ8r7k1jxV+rRXUf9AZ+G81g2Dh0KsqcKGg () mail ! gmail ! com
[Download RAW message or body]

On Thu, Jun 29, 2017 at 12:09 AM, Zebediah Figura <z.figura12@gmail.com> wrote:
> Fixes https://bugs.winehq.org/show_bug.cgi?id=43257
> 
> Signed-off-by: Zebediah Figura <z.figura12@gmail.com>
> ---
> dlls/msi/package.c | 6 +++---
> 1 file changed, 3 insertions(+), 3 deletions(-)
> 
> diff --git a/dlls/msi/package.c b/dlls/msi/package.c
> index bf6ae10..3a75a1c 100644
> --- a/dlls/msi/package.c
> +++ b/dlls/msi/package.c
> @@ -1812,17 +1812,17 @@ INT MSI_ProcessMessage( MSIPACKAGE *package, INSTALLMESSAGE \
> eMessageType, MSIREC {
> WCHAR template_s[1024];
> WCHAR *template_rec, *template;
> -        DWORD length;
> 
> LoadStringW(msi_hInstance, IDS_INFO, template_s, 1024);
> 
> -        res = MSI_RecordGetStringW(record, 0, NULL, &length);
> +        res = MSI_RecordGetStringW(record, 0, NULL, &len);
> if (res != ERROR_SUCCESS && res != ERROR_MORE_DATA)
> return res;
> len++;
> template_rec = msi_alloc(len * sizeof(WCHAR));
> if (!template_rec) return ERROR_OUTOFMEMORY;
> -        MSI_RecordGetStringW(record, 0, template_rec, &length);
> +        MSI_RecordGetStringW(record, 0, template_rec, &len);
> +        len++;
> 
> template = msi_alloc((len + strlenW(template_s)) * sizeof(WCHAR));
> if (!template) return ERROR_OUTOFMEMORY;
> --
> 2.7.4
> 
> 
> 

Works for me, thanks.

-- 
-Austin
GPG: 14FB D7EA A041 937B


[prev in list] [next in list] [prev in thread] [next in thread] 

Configure | About | News | Add a list | Sponsored by KoreLogic