提交 a2940908 编写于 作者: M Mike Waychison 提交者: Tony Luck

efivars: String functions

Fix the string functions in the efivars driver to be called utf16_*
instead of utf8_* as the encoding is utf16, not utf8.

As well, rename utf16_strlen to utf16_strnlen as it takes a maxlength
argument and the name should be consistent with the standard C function
names.  utf16_strlen is still provided for convenience in a subsequent
patch.
Signed-off-by: NMike Waychison <mikew@google.com>
Signed-off-by: NTony Luck <tony.luck@intel.com>
上级 5ee9c198
...@@ -144,23 +144,29 @@ efivar_create_sysfs_entry(struct efivars *efivars, ...@@ -144,23 +144,29 @@ efivar_create_sysfs_entry(struct efivars *efivars,
/* Return the number of unicode characters in data */ /* Return the number of unicode characters in data */
static unsigned long static unsigned long
utf8_strlen(efi_char16_t *data, unsigned long maxlength) utf16_strnlen(efi_char16_t *s, size_t maxlength)
{ {
unsigned long length = 0; unsigned long length = 0;
while (*data++ != 0 && length < maxlength) while (*s++ != 0 && length < maxlength)
length++; length++;
return length; return length;
} }
static unsigned long
utf16_strlen(efi_char16_t *s)
{
return utf16_strnlen(s, ~0UL);
}
/* /*
* Return the number of bytes is the length of this string * Return the number of bytes is the length of this string
* Note: this is NOT the same as the number of unicode characters * Note: this is NOT the same as the number of unicode characters
*/ */
static inline unsigned long static inline unsigned long
utf8_strsize(efi_char16_t *data, unsigned long maxlength) utf16_strsize(efi_char16_t *data, unsigned long maxlength)
{ {
return utf8_strlen(data, maxlength/sizeof(efi_char16_t)) * sizeof(efi_char16_t); return utf16_strnlen(data, maxlength/sizeof(efi_char16_t)) * sizeof(efi_char16_t);
} }
static efi_status_t static efi_status_t
...@@ -518,7 +524,9 @@ static u64 efi_pstore_write(enum pstore_type_id type, unsigned int part, ...@@ -518,7 +524,9 @@ static u64 efi_pstore_write(enum pstore_type_id type, unsigned int part,
efivar_unregister(found); efivar_unregister(found);
if (size) if (size)
efivar_create_sysfs_entry(efivars, utf8_strsize(efi_name, DUMP_NAME_LEN * 2), efivar_create_sysfs_entry(efivars,
utf16_strsize(efi_name,
DUMP_NAME_LEN * 2),
efi_name, &vendor); efi_name, &vendor);
return part; return part;
...@@ -591,8 +599,8 @@ static ssize_t efivar_create(struct file *filp, struct kobject *kobj, ...@@ -591,8 +599,8 @@ static ssize_t efivar_create(struct file *filp, struct kobject *kobj,
* Does this variable already exist? * Does this variable already exist?
*/ */
list_for_each_entry_safe(search_efivar, n, &efivars->list, list) { list_for_each_entry_safe(search_efivar, n, &efivars->list, list) {
strsize1 = utf8_strsize(search_efivar->var.VariableName, 1024); strsize1 = utf16_strsize(search_efivar->var.VariableName, 1024);
strsize2 = utf8_strsize(new_var->VariableName, 1024); strsize2 = utf16_strsize(new_var->VariableName, 1024);
if (strsize1 == strsize2 && if (strsize1 == strsize2 &&
!memcmp(&(search_efivar->var.VariableName), !memcmp(&(search_efivar->var.VariableName),
new_var->VariableName, strsize1) && new_var->VariableName, strsize1) &&
...@@ -624,8 +632,8 @@ static ssize_t efivar_create(struct file *filp, struct kobject *kobj, ...@@ -624,8 +632,8 @@ static ssize_t efivar_create(struct file *filp, struct kobject *kobj,
/* Create the entry in sysfs. Locking is not required here */ /* Create the entry in sysfs. Locking is not required here */
status = efivar_create_sysfs_entry(efivars, status = efivar_create_sysfs_entry(efivars,
utf8_strsize(new_var->VariableName, utf16_strsize(new_var->VariableName,
1024), 1024),
new_var->VariableName, new_var->VariableName,
&new_var->VendorGuid); &new_var->VendorGuid);
if (status) { if (status) {
...@@ -654,8 +662,8 @@ static ssize_t efivar_delete(struct file *filp, struct kobject *kobj, ...@@ -654,8 +662,8 @@ static ssize_t efivar_delete(struct file *filp, struct kobject *kobj,
* Does this variable already exist? * Does this variable already exist?
*/ */
list_for_each_entry_safe(search_efivar, n, &efivars->list, list) { list_for_each_entry_safe(search_efivar, n, &efivars->list, list) {
strsize1 = utf8_strsize(search_efivar->var.VariableName, 1024); strsize1 = utf16_strsize(search_efivar->var.VariableName, 1024);
strsize2 = utf8_strsize(del_var->VariableName, 1024); strsize2 = utf16_strsize(del_var->VariableName, 1024);
if (strsize1 == strsize2 && if (strsize1 == strsize2 &&
!memcmp(&(search_efivar->var.VariableName), !memcmp(&(search_efivar->var.VariableName),
del_var->VariableName, strsize1) && del_var->VariableName, strsize1) &&
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册