Hello community,

here is the log from the commit of package shim for openSUSE:Factory checked in 
at 2013-02-23 16:45:49
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/shim (Old)
 and      /work/SRC/openSUSE:Factory/.shim.new (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Package is "shim", Maintainer is "[email protected]"

Changes:
--------
--- /work/SRC/openSUSE:Factory/shim/shim.changes        2013-02-11 
14:54:57.000000000 +0100
+++ /work/SRC/openSUSE:Factory/.shim.new/shim.changes   2013-02-23 
16:45:51.000000000 +0100
@@ -1,0 +2,6 @@
+Thu Feb 21 10:08:12 UTC 2013 - [email protected]
+
+- Add shim-bnc804631-fix-broken-bootpath.patch to fix the broken
+  bootpath generated in generate_path(). (bnc#804631)
+
+-------------------------------------------------------------------

New:
----
  shim-bnc804631-fix-broken-bootpath.patch

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Other differences:
------------------
++++++ shim.spec ++++++
--- /var/tmp/diff_new_pack.b5SreF/_old  2013-02-23 16:45:53.000000000 +0100
+++ /var/tmp/diff_new_pack.b5SreF/_new  2013-02-23 16:45:53.000000000 +0100
@@ -52,6 +52,8 @@
 Patch9:         shim-mokmanager-support-crypt-hash-method.patch
 # PATCH-FIX-OPENSUSE shim-keep-unsigned-mokmanager.patch [email protected] -- Keep 
MokManager.efi and sign it with the openSUSE key later
 Patch10:        shim-keep-unsigned-mokmanager.patch
+# PATCH-FIX-UPSTREAM shim-bnc804631-fix-broken-bootpath.patch bnc#804631 
[email protected] -- Fix the broken bootpath generated in generate_path()
+Patch11:        shim-bnc804631-fix-broken-bootpath.patch
 BuildRequires:  gnu-efi >= 3.0q
 BuildRequires:  mozilla-nss-tools
 BuildRequires:  openssl >= 0.9.8
@@ -83,6 +85,7 @@
 %patch8 -p1
 %patch9 -p1
 %patch10 -p1
+%patch11 -p1
 
 %build
 chmod +x "make-certs"

++++++ shim-bnc804631-fix-broken-bootpath.patch ++++++
>From 6b70850baa958b196ec332cf0224ffa9d5a81f5f Mon Sep 17 00:00:00 2001
From: Gary Ching-Pang Lin <[email protected]>
Date: Thu, 21 Feb 2013 17:49:29 +0800
Subject: [PATCH] Fix the broken bootpath

- The file path from DevicePathToStr may use slash as the file
  seperator. Change all slashes to backslashes to avoid the strange
  bootpath.
- Remove the redundant backslashes.
- ImagePath no longer requires the leading backslash.
- Fix a memory leak

Based on the patch from Michal Marek <[email protected]>
---
 shim.c |   22 +++++++++++++++++-----
 1 file changed, 17 insertions(+), 5 deletions(-)

diff --git a/shim.c b/shim.c
index 37a5898..690d064 100644
--- a/shim.c
+++ b/shim.c
@@ -919,15 +919,25 @@ static EFI_STATUS generate_path(EFI_LOADED_IMAGE *li, 
CHAR16 *ImagePath,
 
        pathlen = StrLen(bootpath);
 
+       /*
+        * DevicePathToStr() concatenates two nodes with '/'.
+        * Convert '/' to '\\'.
+        */
+       for (i = 0; i < pathlen; i++) {
+               if (bootpath[i] == '/')
+                       bootpath[i] = '\\';
+       }
        for (i=pathlen; i>0; i--) {
-               if (bootpath[i] == '\\')
+               if (bootpath[i] == '\\' && bootpath[i-1] != '\\')
                        break;
        }
+       if (bootpath[i] == '\\')
+               bootpath[i+1] = '\0';
+       else
+               bootpath[0] = '\0';
 
-       bootpath[i+1] = '\0';
-
-       if (i == 0 || bootpath[i-i] == '\\')
-               bootpath[i] = '\0';
+       while (*ImagePath == '\\')
+               ImagePath++;
 
        *PathName = AllocatePool(StrSize(bootpath) + StrSize(ImagePath));
 
@@ -944,6 +954,8 @@ static EFI_STATUS generate_path(EFI_LOADED_IMAGE *li, 
CHAR16 *ImagePath,
        *grubpath = FileDevicePath(device, *PathName);
 
 error:
+       FreePool(bootpath);
+
        return efi_status;
 }
 
-- 
1.7.10.4


-- 
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to