[PATCH v8 7/9] ntdll: Return system info from NtQuerySystemInformation on Linux

Huw Davies huw at codeweavers.com
Wed Jul 11 03:45:55 CDT 2018


On Wed, Jun 20, 2018 at 11:18:50PM -0600, Alex Henrie wrote:
> Signed-off-by: Alex Henrie <alexhenrie24 at gmail.com>
> ---
>  dlls/ntdll/nt.c | 47 +++++++++++++++++++++++++++++++++++++++++++++++
>  1 file changed, 47 insertions(+)

These final three patches should be good if you make the
copy_smbios_string block changes I suggested.

> 
> diff --git a/dlls/ntdll/nt.c b/dlls/ntdll/nt.c
> index c46c3cd01d..5137b8e5dc 100644
> --- a/dlls/ntdll/nt.c
> +++ b/dlls/ntdll/nt.c
> @@ -88,6 +88,16 @@ struct smbios_bios {
>      UINT64 characteristics;
>  };
>  
> +struct smbios_system {
> +    BYTE type;
> +    BYTE length;
> +    WORD handle;
> +    BYTE vendor;
> +    BYTE product;
> +    BYTE version;
> +    BYTE serial;
> +};
> +
>  #include "poppack.h"
>  
>  /* Firmware table providers */
> @@ -1921,15 +1931,22 @@ static inline NTSTATUS get_firmware_info(SYSTEM_FIRMWARE_TABLE_INFORMATION *sfti
>          {
>              char bios_vendor[128], bios_version[128], bios_date[128];
>              size_t bios_vendor_len, bios_version_len, bios_date_len;
> +            char system_vendor[128], system_product[128], system_version[128], system_serial[128];
> +            size_t system_vendor_len, system_product_len, system_version_len, system_serial_len;
>              char *buffer = (char*)sfti->TableBuffer;
>              BYTE string_count;
>              struct smbios_prologue *prologue;
>              struct smbios_bios *bios;
> +            struct smbios_system *system;
>  
>  #define S(s) s, sizeof(s)
>              bios_vendor_len = get_smbios_string("/sys/class/dmi/id/bios_vendor", S(bios_vendor));
>              bios_version_len = get_smbios_string("/sys/class/dmi/id/bios_version", S(bios_version));
>              bios_date_len = get_smbios_string("/sys/class/dmi/id/bios_date", S(bios_date));
> +            system_vendor_len = get_smbios_string("/sys/class/dmi/id/sys_vendor", S(system_vendor));
> +            system_product_len = get_smbios_string("/sys/class/dmi/id/product", S(system_product));
> +            system_version_len = get_smbios_string("/sys/class/dmi/id/product_version", S(system_version));
> +            system_serial_len = get_smbios_string("/sys/class/dmi/id/product_serial", S(system_serial));
>  #undef S
>  
>              *required_len = sizeof(struct smbios_prologue);
> @@ -1937,6 +1954,10 @@ static inline NTSTATUS get_firmware_info(SYSTEM_FIRMWARE_TABLE_INFORMATION *sfti
>              *required_len += sizeof(struct smbios_bios);
>              *required_len += max(bios_vendor_len + bios_version_len + bios_date_len + 4, 2);
>  
> +            *required_len += sizeof(struct smbios_system);
> +            *required_len += max(system_vendor_len + system_product_len + system_version_len +
> +                                 system_serial_len + 5, 2);
> +
>              sfti->TableBufferLength = *required_len;
>  
>              *required_len += FIELD_OFFSET(SYSTEM_FIRMWARE_TABLE_INFORMATION, TableBuffer);
> @@ -1971,6 +1992,32 @@ static inline NTSTATUS get_firmware_info(SYSTEM_FIRMWARE_TABLE_INFORMATION *sfti
>                  copy_smbios_string(&buffer, bios_version, bios_version_len);
>                  copy_smbios_string(&buffer, bios_date, bios_date_len);
>                  memset(buffer, 0, 1);
> +                buffer++;
> +            }
> +            else
> +            {
> +                memset(buffer, 0, 2);
> +                buffer += 2;
> +            }
> +
> +            string_count = 0;
> +            system = (struct smbios_system*)buffer;
> +            system->type = 1;
> +            system->length = sizeof(struct smbios_system);
> +            system->handle = 0;
> +            system->vendor = system_vendor_len ? ++string_count : 0;
> +            system->product = system_product_len ? ++string_count : 0;
> +            system->version = system_version_len ? ++string_count : 0;
> +            system->serial = system_serial_len ? ++string_count : 0;
> +            buffer += sizeof(struct smbios_system);
> +
> +            if (string_count)
> +            {
> +                copy_smbios_string(&buffer, system_vendor, system_vendor_len);
> +                copy_smbios_string(&buffer, system_product, system_product_len);
> +                copy_smbios_string(&buffer, system_version, system_version_len);
> +                copy_smbios_string(&buffer, system_serial, system_serial_len);
> +                memset(buffer, 0, 1);
>              }
>              else
>              {
> -- 
> 2.17.1
> 
> 
> 



More information about the wine-devel mailing list