On Tue, Aug 16, 2022 at 7:40 PM Yongxin Liu <yongxin....@windriver.com> wrote:
>
> Any comments?

Waiting for this to hit master, then will cherry-pick to kirkstone.

Steve

> > -----Original Message-----
> > From: openembedded-core@lists.openembedded.org <openembedded-
> > c...@lists.openembedded.org> On Behalf Of Yongxin Liu
> > Sent: Friday, August 5, 2022 10:42
> > To: richard.pur...@linuxfoundation.org; st...@sakoman.com; openembedded-
> > c...@lists.openembedded.org
> > Cc: MacLeod, Randy <randy.macl...@windriver.com>
> > Subject: [OE-core][master][kirkstone][PATCH v2] grub2: fix several CVEs
> >
> > Backport CVE patches from upstream to fix:
> >   CVE-2021-3695
> >   CVE-2021-3696
> >   CVE-2021-3697
> >   CVE-2022-28733
> >   CVE-2022-28734
> >   CVE-2022-28735
> >
> > Backport the following 5 patches to make CVE patches be applied smoothly.
> >   video-Remove-trailing-whitespaces.patch
> >   video-readers-jpeg-Abort-sooner-if-a-read-operation-.patch
> >   video-readers-jpeg-Refuse-to-handle-multiple-start-o.patch
> >
> > Signed-off-by: Yongxin Liu <yongxin....@windriver.com>
> > ---
> >
> > V1->V2:
> >
> > Remove CVE-2022-28736 related patches.
> > CVE-2022-28736 related patches conflict with some grub patches in
> > meta-secure-core layers. So remove those patches.
> > Untill we find a better solution, just ignore CVE-2022-28736 for now.
> >
> > ---
> >  ...g-Drop-greyscale-support-to-fix-heap.patch | 179 +++++
> >  ...ng-Avoid-heap-OOB-R-W-inserting-huff.patch |  50 ++
> >  ...peg-Block-int-underflow-wild-pointer.patch |  84 +++
> >  ...3-net-ip-Do-IP-fragment-maths-safely.patch |  63 ++
> >  ...or-out-on-headers-with-LF-without-CR.patch |  58 ++
> >  ...Fix-OOB-write-for-split-http-headers.patch |  56 ++
> >  ...ct-non-kernel-files-in-the-shim_lock.patch | 111 +++
> >  .../video-Remove-trailing-whitespaces.patch   | 693 ++++++++++++++++++
> >  ...eg-Abort-sooner-if-a-read-operation-.patch | 264 +++++++
> >  ...eg-Refuse-to-handle-multiple-start-o.patch |  53 ++
> >  meta/recipes-bsp/grub/grub2.inc               |  10 +
> >  11 files changed, 1621 insertions(+)
> >  create mode 100644 meta/recipes-bsp/grub/files/CVE-2021-3695-video-
> > readers-png-Drop-greyscale-support-to-fix-heap.patch
> >  create mode 100644 meta/recipes-bsp/grub/files/CVE-2021-3696-video-
> > readers-png-Avoid-heap-OOB-R-W-inserting-huff.patch
> >  create mode 100644 meta/recipes-bsp/grub/files/CVE-2021-3697-video-
> > readers-jpeg-Block-int-underflow-wild-pointer.patch
> >  create mode 100644 meta/recipes-bsp/grub/files/CVE-2022-28733-net-ip-Do-
> > IP-fragment-maths-safely.patch
> >  create mode 100644 meta/recipes-bsp/grub/files/CVE-2022-28734-net-http-
> > Error-out-on-headers-with-LF-without-CR.patch
> >  create mode 100644 meta/recipes-bsp/grub/files/CVE-2022-28734-net-http-
> > Fix-OOB-write-for-split-http-headers.patch
> >  create mode 100644 meta/recipes-bsp/grub/files/CVE-2022-28735-kern-efi-
> > sb-Reject-non-kernel-files-in-the-shim_lock.patch
> >  create mode 100644 meta/recipes-bsp/grub/files/video-Remove-trailing-
> > whitespaces.patch
> >  create mode 100644 meta/recipes-bsp/grub/files/video-readers-jpeg-Abort-
> > sooner-if-a-read-operation-.patch
> >  create mode 100644 meta/recipes-bsp/grub/files/video-readers-jpeg-Refuse-
> > to-handle-multiple-start-o.patch
> >
> > diff --git a/meta/recipes-bsp/grub/files/CVE-2021-3695-video-readers-png-
> > Drop-greyscale-support-to-fix-heap.patch b/meta/recipes-
> > bsp/grub/files/CVE-2021-3695-video-readers-png-Drop-greyscale-support-to-
> > fix-heap.patch
> > new file mode 100644
> > index 0000000000..7f7bb1acfe
> > --- /dev/null
> > +++ b/meta/recipes-bsp/grub/files/CVE-2021-3695-video-readers-png-Drop-
> > greyscale-support-to-fix-heap.patch
> > @@ -0,0 +1,179 @@
> > +From e623866d9286410156e8b9d2c82d6253a1b22d08 Mon Sep 17 00:00:00 2001
> > +From: Daniel Axtens <d...@axtens.net>
> > +Date: Tue, 6 Jul 2021 18:51:35 +1000
> > +Subject: [PATCH] video/readers/png: Drop greyscale support to fix heap
> > + out-of-bounds write
> > +
> > +A 16-bit greyscale PNG without alpha is processed in the following loop:
> > +
> > +      for (i = 0; i < (data->image_width * data->image_height);
> > +        i++, d1 += 4, d2 += 2)
> > +     {
> > +       d1[R3] = d2[1];
> > +       d1[G3] = d2[1];
> > +       d1[B3] = d2[1];
> > +     }
> > +
> > +The increment of d1 is wrong. d1 is incremented by 4 bytes per iteration,
> > +but there are only 3 bytes allocated for storage. This means that image
> > +data will overwrite somewhat-attacker-controlled parts of memory - 3
> > bytes
> > +out of every 4 following the end of the image.
> > +
> > +This has existed since greyscale support was added in 2013 in commit
> > +3ccf16dff98f (grub-core/video/readers/png.c: Support grayscale).
> > +
> > +Saving starfield.png as a 16-bit greyscale image without alpha in the
> > gimp
> > +and attempting to load it causes grub-emu to crash - I don't think this
> > code
> > +has ever worked.
> > +
> > +Delete all PNG greyscale support.
> > +
> > +Fixes: CVE-2021-3695
> > +
> > +Signed-off-by: Daniel Axtens <d...@axtens.net>
> > +Reviewed-by: Daniel Kiper <daniel.ki...@oracle.com>
> > +
> > +Upstream-Status: Backport
> > +CVE: CVE-2021-3695
> > +
> > +Reference to upstream patch:
> > +https://git.savannah.gnu.org/cgit/grub.git/commit/?id=e623866d9286410156e
> > 8b9d2c82d6253a1b22d08
> > +
> > +Signed-off-by: Yongxin Liu <yongxin....@windriver.com>
> > +---
> > + grub-core/video/readers/png.c | 87 +++--------------------------------
> > + 1 file changed, 7 insertions(+), 80 deletions(-)
> > +
> > +diff --git a/grub-core/video/readers/png.c b/grub-
> > core/video/readers/png.c
> > +index 35ae553c8..a3161e25b 100644
> > +--- a/grub-core/video/readers/png.c
> > ++++ b/grub-core/video/readers/png.c
> > +@@ -100,7 +100,7 @@ struct grub_png_data
> > +
> > +   unsigned image_width, image_height;
> > +   int bpp, is_16bit;
> > +-  int raw_bytes, is_gray, is_alpha, is_palette;
> > ++  int raw_bytes, is_alpha, is_palette;
> > +   int row_bytes, color_bits;
> > +   grub_uint8_t *image_data;
> > +
> > +@@ -296,13 +296,13 @@ grub_png_decode_image_header (struct grub_png_data
> > *data)
> > +     data->bpp = 3;
> > +   else
> > +     {
> > +-      data->is_gray = 1;
> > +-      data->bpp = 1;
> > ++      return grub_error (GRUB_ERR_BAD_FILE_TYPE,
> > ++                     "png: color type not supported");
> > +     }
> > +
> > +   if ((color_bits != 8) && (color_bits != 16)
> > +       && (color_bits != 4
> > +-      || !(data->is_gray || data->is_palette)))
> > ++      || !data->is_palette))
> > +     return grub_error (GRUB_ERR_BAD_FILE_TYPE,
> > +                        "png: bit depth must be 8 or 16");
> > +
> > +@@ -331,7 +331,7 @@ grub_png_decode_image_header (struct grub_png_data
> > *data)
> > +     }
> > +
> > + #ifndef GRUB_CPU_WORDS_BIGENDIAN
> > +-  if (data->is_16bit || data->is_gray || data->is_palette)
> > ++  if (data->is_16bit || data->is_palette)
> > + #endif
> > +     {
> > +       data->image_data = grub_calloc (data->image_height, data-
> > >row_bytes);
> > +@@ -899,27 +899,8 @@ grub_png_convert_image (struct grub_png_data *data)
> > +       int shift;
> > +       int mask = (1 << data->color_bits) - 1;
> > +       unsigned j;
> > +-      if (data->is_gray)
> > +-    {
> > +-      /* Generic formula is
> > +-         (0xff * i) / ((1U << data->color_bits) - 1)
> > +-         but for allowed bit depth of 1, 2 and for it's
> > +-         equivalent to
> > +-         (0xff / ((1U << data->color_bits) - 1)) * i
> > +-         Precompute the multipliers to avoid division.
> > +-      */
> > +-
> > +-      const grub_uint8_t multipliers[5] = { 0xff, 0xff, 0x55, 0x24,
> > 0x11 };
> > +-      for (i = 0; i < (1U << data->color_bits); i++)
> > +-        {
> > +-          grub_uint8_t col = multipliers[data->color_bits] * i;
> > +-          palette[i][0] = col;
> > +-          palette[i][1] = col;
> > +-          palette[i][2] = col;
> > +-        }
> > +-    }
> > +-      else
> > +-    grub_memcpy (palette, data->palette, 3 << data->color_bits);
> > ++
> > ++      grub_memcpy (palette, data->palette, 3 << data->color_bits);
> > +       d1c = d1;
> > +       d2c = d2;
> > +       for (j = 0; j < data->image_height; j++, d1c += data->image_width
> > * 3,
> > +@@ -957,60 +938,6 @@ grub_png_convert_image (struct grub_png_data *data)
> > +       return;
> > +     }
> > +
> > +-  if (data->is_gray)
> > +-    {
> > +-      switch (data->bpp)
> > +-    {
> > +-    case 4:
> > +-      /* 16-bit gray with alpha.  */
> > +-      for (i = 0; i < (data->image_width * data->image_height);
> > +-           i++, d1 += 4, d2 += 4)
> > +-        {
> > +-          d1[R4] = d2[3];
> > +-          d1[G4] = d2[3];
> > +-          d1[B4] = d2[3];
> > +-          d1[A4] = d2[1];
> > +-        }
> > +-      break;
> > +-    case 2:
> > +-      if (data->is_16bit)
> > +-        /* 16-bit gray without alpha.  */
> > +-        {
> > +-          for (i = 0; i < (data->image_width * data->image_height);
> > +-               i++, d1 += 4, d2 += 2)
> > +-            {
> > +-              d1[R3] = d2[1];
> > +-              d1[G3] = d2[1];
> > +-              d1[B3] = d2[1];
> > +-            }
> > +-        }
> > +-      else
> > +-        /* 8-bit gray with alpha.  */
> > +-        {
> > +-          for (i = 0; i < (data->image_width * data->image_height);
> > +-               i++, d1 += 4, d2 += 2)
> > +-            {
> > +-              d1[R4] = d2[1];
> > +-              d1[G4] = d2[1];
> > +-              d1[B4] = d2[1];
> > +-              d1[A4] = d2[0];
> > +-            }
> > +-        }
> > +-      break;
> > +-      /* 8-bit gray without alpha.  */
> > +-    case 1:
> > +-      for (i = 0; i < (data->image_width * data->image_height);
> > +-           i++, d1 += 3, d2++)
> > +-        {
> > +-          d1[R3] = d2[0];
> > +-          d1[G3] = d2[0];
> > +-          d1[B3] = d2[0];
> > +-        }
> > +-      break;
> > +-    }
> > +-      return;
> > +-    }
> > +-
> > +     {
> > +   /* Only copy the upper 8 bit.  */
> > + #ifndef GRUB_CPU_WORDS_BIGENDIAN
> > +--
> > +2.34.1
> > +
> > diff --git a/meta/recipes-bsp/grub/files/CVE-2021-3696-video-readers-png-
> > Avoid-heap-OOB-R-W-inserting-huff.patch b/meta/recipes-bsp/grub/files/CVE-
> > 2021-3696-video-readers-png-Avoid-heap-OOB-R-W-inserting-huff.patch
> > new file mode 100644
> > index 0000000000..f06514e665
> > --- /dev/null
> > +++ b/meta/recipes-bsp/grub/files/CVE-2021-3696-video-readers-png-Avoid-
> > heap-OOB-R-W-inserting-huff.patch
> > @@ -0,0 +1,50 @@
> > +From 210245129c932dc9e1c2748d9d35524fb95b5042 Mon Sep 17 00:00:00 2001
> > +From: Daniel Axtens <d...@axtens.net>
> > +Date: Tue, 6 Jul 2021 23:25:07 +1000
> > +Subject: [PATCH] video/readers/png: Avoid heap OOB R/W inserting huff
> > table
> > + items
> > +
> > +In fuzzing we observed crashes where a code would attempt to be inserted
> > +into a huffman table before the start, leading to a set of heap OOB reads
> > +and writes as table entries with negative indices were shifted around and
> > +the new code written in.
> > +
> > +Catch the case where we would underflow the array and bail.
> > +
> > +Fixes: CVE-2021-3696
> > +
> > +Signed-off-by: Daniel Axtens <d...@axtens.net>
> > +Reviewed-by: Daniel Kiper <daniel.ki...@oracle.com>
> > +
> > +Upstream-Status: Backport
> > +CVE: CVE-2021-3696
> > +
> > +Reference to upstream patch:
> > +https://git.savannah.gnu.org/cgit/grub.git/commit/?id=210245129c932dc9e1c
> > 2748d9d35524fb95b5042
> > +
> > +Signed-off-by: Yongxin Liu <yongxin....@windriver.com>
> > +---
> > + grub-core/video/readers/png.c | 7 +++++++
> > + 1 file changed, 7 insertions(+)
> > +
> > +diff --git a/grub-core/video/readers/png.c b/grub-
> > core/video/readers/png.c
> > +index a3161e25b..d7ed5aa6c 100644
> > +--- a/grub-core/video/readers/png.c
> > ++++ b/grub-core/video/readers/png.c
> > +@@ -438,6 +438,13 @@ grub_png_insert_huff_item (struct huff_table *ht,
> > int code, int len)
> > +   for (i = len; i < ht->max_length; i++)
> > +     n += ht->maxval[i];
> > +
> > ++  if (n > ht->num_values)
> > ++    {
> > ++      grub_error (GRUB_ERR_BAD_FILE_TYPE,
> > ++              "png: out of range inserting huffman table item");
> > ++      return;
> > ++    }
> > ++
> > +   for (i = 0; i < n; i++)
> > +     ht->values[ht->num_values - i] = ht->values[ht->num_values - i - 1];
> > +
> > +--
> > +2.34.1
> > +
> > diff --git a/meta/recipes-bsp/grub/files/CVE-2021-3697-video-readers-jpeg-
> > Block-int-underflow-wild-pointer.patch b/meta/recipes-bsp/grub/files/CVE-
> > 2021-3697-video-readers-jpeg-Block-int-underflow-wild-pointer.patch
> > new file mode 100644
> > index 0000000000..e9fc52df86
> > --- /dev/null
> > +++ b/meta/recipes-bsp/grub/files/CVE-2021-3697-video-readers-jpeg-Block-
> > int-underflow-wild-pointer.patch
> > @@ -0,0 +1,84 @@
> > +From 22a3f97d39f6a10b08ad7fd1cc47c4dcd10413f6 Mon Sep 17 00:00:00 2001
> > +From: Daniel Axtens <d...@axtens.net>
> > +Date: Wed, 7 Jul 2021 15:38:19 +1000
> > +Subject: [PATCH] video/readers/jpeg: Block int underflow -> wild pointer
> > write
> > +
> > +Certain 1 px wide images caused a wild pointer write in
> > +grub_jpeg_ycrcb_to_rgb(). This was caused because in
> > grub_jpeg_decode_data(),
> > +we have the following loop:
> > +
> > +for (; data->r1 < nr1 && (!data->dri || rst);
> > +     data->r1++, data->bitmap_ptr += (vb * data->image_width - hb * nc1)
> > * 3)
> > +
> > +We did not check if vb * width >= hb * nc1.
> > +
> > +On a 64-bit platform, if that turns out to be negative, it will underflow,
> > +be interpreted as unsigned 64-bit, then be added to the 64-bit pointer,
> > so
> > +we see data->bitmap_ptr jump, e.g.:
> > +
> > +0x6180_0000_0480 to
> > +0x6181_0000_0498
> > +     ^
> > +     ~--- carry has occurred and this pointer is now far away from
> > +          any object.
> > +
> > +On a 32-bit platform, it will decrement the pointer, creating a pointer
> > +that won't crash but will overwrite random data.
> > +
> > +Catch the underflow and error out.
> > +
> > +Fixes: CVE-2021-3697
> > +
> > +Signed-off-by: Daniel Axtens <d...@axtens.net>
> > +Reviewed-by: Daniel Kiper <daniel.ki...@oracle.com>
> > +
> > +Upstream-Status: Backport
> > +CVE: CVE-2021-3697
> > +
> > +Reference to upstream patch:
> > +https://git.savannah.gnu.org/cgit/grub.git/commit/?id=22a3f97d39f6a10b08a
> > d7fd1cc47c4dcd10413f6
> > +
> > +Signed-off-by: Yongxin Liu <yongxin....@windriver.com>
> > +---
> > + grub-core/video/readers/jpeg.c | 10 +++++++++-
> > + 1 file changed, 9 insertions(+), 1 deletion(-)
> > +
> > +diff --git a/grub-core/video/readers/jpeg.c b/grub-
> > core/video/readers/jpeg.c
> > +index 579bbe8a4..09596fbf5 100644
> > +--- a/grub-core/video/readers/jpeg.c
> > ++++ b/grub-core/video/readers/jpeg.c
> > +@@ -23,6 +23,7 @@
> > + #include <grub/mm.h>
> > + #include <grub/misc.h>
> > + #include <grub/bufio.h>
> > ++#include <grub/safemath.h>
> > +
> > + GRUB_MOD_LICENSE ("GPLv3+");
> > +
> > +@@ -699,6 +700,7 @@ static grub_err_t
> > + grub_jpeg_decode_data (struct grub_jpeg_data *data)
> > + {
> > +   unsigned c1, vb, hb, nr1, nc1;
> > ++  unsigned stride_a, stride_b, stride;
> > +   int rst = data->dri;
> > +   grub_err_t err = GRUB_ERR_NONE;
> > +
> > +@@ -711,8 +713,14 @@ grub_jpeg_decode_data (struct grub_jpeg_data *data)
> > +     return grub_error (GRUB_ERR_BAD_FILE_TYPE,
> > +                    "jpeg: attempted to decode data before start of
> > stream");
> > +
> > ++  if (grub_mul(vb, data->image_width, &stride_a) ||
> > ++      grub_mul(hb, nc1, &stride_b) ||
> > ++      grub_sub(stride_a, stride_b, &stride))
> > ++    return grub_error (GRUB_ERR_BAD_FILE_TYPE,
> > ++                   "jpeg: cannot decode image with these dimensions");
> > ++
> > +   for (; data->r1 < nr1 && (!data->dri || rst);
> > +-       data->r1++, data->bitmap_ptr += (vb * data->image_width - hb *
> > nc1) * 3)
> > ++       data->r1++, data->bitmap_ptr += stride * 3)
> > +     for (c1 = 0;  c1 < nc1 && (!data->dri || rst);
> > +     c1++, rst--, data->bitmap_ptr += hb * 3)
> > +       {
> > +--
> > +2.34.1
> > +
> > diff --git a/meta/recipes-bsp/grub/files/CVE-2022-28733-net-ip-Do-IP-
> > fragment-maths-safely.patch b/meta/recipes-bsp/grub/files/CVE-2022-28733-
> > net-ip-Do-IP-fragment-maths-safely.patch
> > new file mode 100644
> > index 0000000000..8bf9090f94
> > --- /dev/null
> > +++ b/meta/recipes-bsp/grub/files/CVE-2022-28733-net-ip-Do-IP-fragment-
> > maths-safely.patch
> > @@ -0,0 +1,63 @@
> > +From 3e4817538de828319ba6d59ced2fbb9b5ca13287 Mon Sep 17 00:00:00 2001
> > +From: Daniel Axtens <d...@axtens.net>
> > +Date: Mon, 20 Dec 2021 19:41:21 +1100
> > +Subject: [PATCH] net/ip: Do IP fragment maths safely
> > +
> > +We can receive packets with invalid IP fragmentation information. This
> > +can lead to rsm->total_len underflowing and becoming very large.
> > +
> > +Then, in grub_netbuff_alloc(), we add to this very large number, which
> > can
> > +cause it to overflow and wrap back around to a small positive number.
> > +The allocation then succeeds, but the resulting buffer is too small and
> > +subsequent operations can write past the end of the buffer.
> > +
> > +Catch the underflow here.
> > +
> > +Fixes: CVE-2022-28733
> > +
> > +Signed-off-by: Daniel Axtens <d...@axtens.net>
> > +Reviewed-by: Daniel Kiper <daniel.ki...@oracle.com>
> > +
> > +Upstream-Status: Backport
> > +CVE: CVE-2022-28733
> > +
> > +Reference to upstream patch:
> > +https://git.savannah.gnu.org/cgit/grub.git/commit/?id=3e4817538de828319ba
> > 6d59ced2fbb9b5ca13287
> > +
> > +Signed-off-by: Yongxin Liu <yongxin....@windriver.com>
> > +
> > +---
> > + grub-core/net/ip.c | 10 +++++++++-
> > + 1 file changed, 9 insertions(+), 1 deletion(-)
> > +
> > +diff --git a/grub-core/net/ip.c b/grub-core/net/ip.c
> > +index e3d62e97f..3c3d0be0e 100644
> > +--- a/grub-core/net/ip.c
> > ++++ b/grub-core/net/ip.c
> > +@@ -25,6 +25,7 @@
> > + #include <grub/net/netbuff.h>
> > + #include <grub/mm.h>
> > + #include <grub/priority_queue.h>
> > ++#include <grub/safemath.h>
> > + #include <grub/time.h>
> > +
> > + struct iphdr {
> > +@@ -512,7 +513,14 @@ grub_net_recv_ip4_packets (struct grub_net_buff *nb,
> > +     {
> > +       rsm->total_len = (8 * (grub_be_to_cpu16 (iph->frags) & OFFSET_MASK)
> > +                     + (nb->tail - nb->data));
> > +-      rsm->total_len -= ((iph->verhdrlen & 0xf) * sizeof
> > (grub_uint32_t));
> > ++
> > ++      if (grub_sub (rsm->total_len, (iph->verhdrlen & 0xf) * sizeof
> > (grub_uint32_t),
> > ++                &rsm->total_len))
> > ++    {
> > ++      grub_dprintf ("net", "IP reassembly size underflow\n");
> > ++      return GRUB_ERR_NONE;
> > ++    }
> > ++
> > +       rsm->asm_netbuff = grub_netbuff_alloc (rsm->total_len);
> > +       if (!rsm->asm_netbuff)
> > +     {
> > +--
> > +2.34.1
> > +
> > diff --git a/meta/recipes-bsp/grub/files/CVE-2022-28734-net-http-Error-
> > out-on-headers-with-LF-without-CR.patch b/meta/recipes-bsp/grub/files/CVE-
> > 2022-28734-net-http-Error-out-on-headers-with-LF-without-CR.patch
> > new file mode 100644
> > index 0000000000..f31167d315
> > --- /dev/null
> > +++ b/meta/recipes-bsp/grub/files/CVE-2022-28734-net-http-Error-out-on-
> > headers-with-LF-without-CR.patch
> > @@ -0,0 +1,58 @@
> > +From b26b4c08e7119281ff30d0fb4a6169bd2afa8fe4 Mon Sep 17 00:00:00 2001
> > +From: Daniel Axtens <d...@axtens.net>
> > +Date: Tue, 8 Mar 2022 19:04:40 +1100
> > +Subject: [PATCH] net/http: Error out on headers with LF without CR
> > +
> > +In a similar vein to the previous patch, parse_line() would write
> > +a NUL byte past the end of the buffer if there was an HTTP header
> > +with a LF rather than a CRLF.
> > +
> > +RFC-2616 says:
> > +
> > +  Many HTTP/1.1 header field values consist of words separated by LWS
> > +  or special characters. These special characters MUST be in a quoted
> > +  string to be used within a parameter value (as defined in section 3.6).
> > +
> > +We don't support quoted sections or continuation lines, etc.
> > +
> > +If we see an LF that's not part of a CRLF, bail out.
> > +
> > +Fixes: CVE-2022-28734
> > +
> > +Signed-off-by: Daniel Axtens <d...@axtens.net>
> > +Reviewed-by: Daniel Kiper <daniel.ki...@oracle.com>
> > +
> > +Upstream-Status: Backport
> > +CVE: CVE-2022-28734
> > +
> > +Reference to upstream patch:
> > +https://git.savannah.gnu.org/cgit/grub.git/commit/?id=b26b4c08e7119281ff3
> > 0d0fb4a6169bd2afa8fe4
> > +
> > +Signed-off-by: Yongxin Liu <yongxin....@windriver.com>
> > +---
> > + grub-core/net/http.c | 8 ++++++++
> > + 1 file changed, 8 insertions(+)
> > +
> > +diff --git a/grub-core/net/http.c b/grub-core/net/http.c
> > +index 33a0a28c4..9291a13e2 100644
> > +--- a/grub-core/net/http.c
> > ++++ b/grub-core/net/http.c
> > +@@ -68,7 +68,15 @@ parse_line (grub_file_t file, http_data_t data, char
> > *ptr, grub_size_t len)
> > +   char *end = ptr + len;
> > +   while (end > ptr && *(end - 1) == '\r')
> > +     end--;
> > ++
> > ++  /* LF without CR. */
> > ++  if (end == ptr + len)
> > ++    {
> > ++      data->errmsg = grub_strdup (_("invalid HTTP header - LF without
> > CR"));
> > ++      return GRUB_ERR_NONE;
> > ++    }
> > +   *end = 0;
> > ++
> > +   /* Trailing CRLF.  */
> > +   if (data->in_chunk_len == 1)
> > +     {
> > +--
> > +2.34.1
> > +
> > diff --git a/meta/recipes-bsp/grub/files/CVE-2022-28734-net-http-Fix-OOB-
> > write-for-split-http-headers.patch b/meta/recipes-bsp/grub/files/CVE-2022-
> > 28734-net-http-Fix-OOB-write-for-split-http-headers.patch
> > new file mode 100644
> > index 0000000000..e0ca1eec44
> > --- /dev/null
> > +++ b/meta/recipes-bsp/grub/files/CVE-2022-28734-net-http-Fix-OOB-write-
> > for-split-http-headers.patch
> > @@ -0,0 +1,56 @@
> > +From ec6bfd3237394c1c7dbf2fd73417173318d22f4b Mon Sep 17 00:00:00 2001
> > +From: Daniel Axtens <d...@axtens.net>
> > +Date: Tue, 8 Mar 2022 18:17:03 +1100
> > +Subject: [PATCH] net/http: Fix OOB write for split http headers
> > +
> > +GRUB has special code for handling an http header that is split
> > +across two packets.
> > +
> > +The code tracks the end of line by looking for a "\n" byte. The
> > +code for split headers has always advanced the pointer just past the
> > +end of the line, whereas the code that handles unsplit headers does
> > +not advance the pointer. This extra advance causes the length to be
> > +one greater, which breaks an assumption in parse_line(), leading to
> > +it writing a NUL byte one byte past the end of the buffer where we
> > +reconstruct the line from the two packets.
> > +
> > +It's conceivable that an attacker controlled set of packets could
> > +cause this to zero out the first byte of the "next" pointer of the
> > +grub_mm_region structure following the current_line buffer.
> > +
> > +Do not advance the pointer in the split header case.
> > +
> > +Fixes: CVE-2022-28734
> > +
> > +Signed-off-by: Daniel Axtens <d...@axtens.net>
> > +Reviewed-by: Daniel Kiper <daniel.ki...@oracle.com>
> > +
> > +Upstream-Status: Backport
> > +CVE: CVE-2022-28734
> > +
> > +Reference to upstream patch:
> > +https://git.savannah.gnu.org/cgit/grub.git/commit/?id=ec6bfd3237394c1c7db
> > f2fd73417173318d22f4b
> > +
> > +Signed-off-by: Yongxin Liu <yongxin....@windriver.com>
> > +---
> > + grub-core/net/http.c | 4 +---
> > + 1 file changed, 1 insertion(+), 3 deletions(-)
> > +
> > +diff --git a/grub-core/net/http.c b/grub-core/net/http.c
> > +index f8d7bf0cd..33a0a28c4 100644
> > +--- a/grub-core/net/http.c
> > ++++ b/grub-core/net/http.c
> > +@@ -190,9 +190,7 @@ http_receive (grub_net_tcp_socket_t sock
> > __attribute__ ((unused)),
> > +       int have_line = 1;
> > +       char *t;
> > +       ptr = grub_memchr (nb->data, '\n', nb->tail - nb->data);
> > +-      if (ptr)
> > +-        ptr++;
> > +-      else
> > ++      if (ptr == NULL)
> > +         {
> > +           have_line = 0;
> > +           ptr = (char *) nb->tail;
> > +--
> > +2.34.1
> > +
> > diff --git a/meta/recipes-bsp/grub/files/CVE-2022-28735-kern-efi-sb-
> > Reject-non-kernel-files-in-the-shim_lock.patch b/meta/recipes-
> > bsp/grub/files/CVE-2022-28735-kern-efi-sb-Reject-non-kernel-files-in-the-
> > shim_lock.patch
> > new file mode 100644
> > index 0000000000..7a59f10bfb
> > --- /dev/null
> > +++ b/meta/recipes-bsp/grub/files/CVE-2022-28735-kern-efi-sb-Reject-non-
> > kernel-files-in-the-shim_lock.patch
> > @@ -0,0 +1,111 @@
> > +From 6fe755c5c07bb386fda58306bfd19e4a1c974c53 Mon Sep 17 00:00:00 2001
> > +From: Julian Andres Klode <julian.kl...@canonical.com>
> > +Date: Thu, 2 Dec 2021 15:03:53 +0100
> > +Subject: [PATCH] kern/efi/sb: Reject non-kernel files in the shim_lock
> > + verifier
> > +
> > +We must not allow other verifiers to pass things like the GRUB modules.
> > +Instead of maintaining a blocklist, maintain an allowlist of things
> > +that we do not care about.
> > +
> > +This allowlist really should be made reusable, and shared by the
> > +lockdown verifier, but this is the minimal patch addressing
> > +security concerns where the TPM verifier was able to mark modules
> > +as verified (or the OpenPGP verifier for that matter), when it
> > +should not do so on shim-powered secure boot systems.
> > +
> > +Fixes: CVE-2022-28735
> > +
> > +Signed-off-by: Julian Andres Klode <julian.kl...@canonical.com>
> > +Reviewed-by: Daniel Kiper <daniel.ki...@oracle.com>
> > +
> > +Upstream-Status: Backport
> > +CVE:CVE-2022-28735
> > +
> > +Reference to upstream patch:
> > +https://git.savannah.gnu.org/cgit/grub.git/commit/?id=6fe755c5c07bb386fda
> > 58306bfd19e4a1c974c53
> > +
> > +Signed-off-by: Yongxin Liu <yongxin....@windriver.com>
> > +---
> > + grub-core/kern/efi/sb.c | 39 ++++++++++++++++++++++++++++++++++++---
> > + include/grub/verify.h   |  1 +
> > + 2 files changed, 37 insertions(+), 3 deletions(-)
> > +
> > +diff --git a/grub-core/kern/efi/sb.c b/grub-core/kern/efi/sb.c
> > +index c52ec6226..89c4bb3fd 100644
> > +--- a/grub-core/kern/efi/sb.c
> > ++++ b/grub-core/kern/efi/sb.c
> > +@@ -119,10 +119,11 @@ shim_lock_verifier_init (grub_file_t io
> > __attribute__ ((unused)),
> > +                      void **context __attribute__ ((unused)),
> > +                      enum grub_verify_flags *flags)
> > + {
> > +-  *flags = GRUB_VERIFY_FLAGS_SKIP_VERIFICATION;
> > ++  *flags = GRUB_VERIFY_FLAGS_NONE;
> > +
> > +   switch (type & GRUB_FILE_TYPE_MASK)
> > +     {
> > ++    /* Files we check. */
> > +     case GRUB_FILE_TYPE_LINUX_KERNEL:
> > +     case GRUB_FILE_TYPE_MULTIBOOT_KERNEL:
> > +     case GRUB_FILE_TYPE_BSD_KERNEL:
> > +@@ -130,11 +131,43 @@ shim_lock_verifier_init (grub_file_t io
> > __attribute__ ((unused)),
> > +     case GRUB_FILE_TYPE_PLAN9_KERNEL:
> > +     case GRUB_FILE_TYPE_EFI_CHAINLOADED_IMAGE:
> > +       *flags = GRUB_VERIFY_FLAGS_SINGLE_CHUNK;
> > ++      return GRUB_ERR_NONE;
> > +
> > +-      /* Fall through. */
> > ++    /* Files that do not affect secureboot state. */
> > ++    case GRUB_FILE_TYPE_NONE:
> > ++    case GRUB_FILE_TYPE_LOOPBACK:
> > ++    case GRUB_FILE_TYPE_LINUX_INITRD:
> > ++    case GRUB_FILE_TYPE_OPENBSD_RAMDISK:
> > ++    case GRUB_FILE_TYPE_XNU_RAMDISK:
> > ++    case GRUB_FILE_TYPE_SIGNATURE:
> > ++    case GRUB_FILE_TYPE_PUBLIC_KEY:
> > ++    case GRUB_FILE_TYPE_PUBLIC_KEY_TRUST:
> > ++    case GRUB_FILE_TYPE_PRINT_BLOCKLIST:
> > ++    case GRUB_FILE_TYPE_TESTLOAD:
> > ++    case GRUB_FILE_TYPE_GET_SIZE:
> > ++    case GRUB_FILE_TYPE_FONT:
> > ++    case GRUB_FILE_TYPE_ZFS_ENCRYPTION_KEY:
> > ++    case GRUB_FILE_TYPE_CAT:
> > ++    case GRUB_FILE_TYPE_HEXCAT:
> > ++    case GRUB_FILE_TYPE_CMP:
> > ++    case GRUB_FILE_TYPE_HASHLIST:
> > ++    case GRUB_FILE_TYPE_TO_HASH:
> > ++    case GRUB_FILE_TYPE_KEYBOARD_LAYOUT:
> > ++    case GRUB_FILE_TYPE_PIXMAP:
> > ++    case GRUB_FILE_TYPE_GRUB_MODULE_LIST:
> > ++    case GRUB_FILE_TYPE_CONFIG:
> > ++    case GRUB_FILE_TYPE_THEME:
> > ++    case GRUB_FILE_TYPE_GETTEXT_CATALOG:
> > ++    case GRUB_FILE_TYPE_FS_SEARCH:
> > ++    case GRUB_FILE_TYPE_LOADENV:
> > ++    case GRUB_FILE_TYPE_SAVEENV:
> > ++    case GRUB_FILE_TYPE_VERIFY_SIGNATURE:
> > ++      *flags = GRUB_VERIFY_FLAGS_SKIP_VERIFICATION;
> > ++      return GRUB_ERR_NONE;
> > +
> > ++    /* Other files. */
> > +     default:
> > +-      return GRUB_ERR_NONE;
> > ++      return grub_error (GRUB_ERR_ACCESS_DENIED, N_("prohibited by
> > secure boot policy"));
> > +     }
> > + }
> > +
> > +diff --git a/include/grub/verify.h b/include/grub/verify.h
> > +index cd129c398..672ae1692 100644
> > +--- a/include/grub/verify.h
> > ++++ b/include/grub/verify.h
> > +@@ -24,6 +24,7 @@
> > +
> > + enum grub_verify_flags
> > +   {
> > ++    GRUB_VERIFY_FLAGS_NONE          = 0,
> > +     GRUB_VERIFY_FLAGS_SKIP_VERIFICATION     = 1,
> > +     GRUB_VERIFY_FLAGS_SINGLE_CHUNK  = 2,
> > +     /* Defer verification to another authority. */
> > +--
> > +2.34.1
> > +
> > diff --git a/meta/recipes-bsp/grub/files/video-Remove-trailing-
> > whitespaces.patch b/meta/recipes-bsp/grub/files/video-Remove-trailing-
> > whitespaces.patch
> > new file mode 100644
> > index 0000000000..2db9bcbbc5
> > --- /dev/null
> > +++ b/meta/recipes-bsp/grub/files/video-Remove-trailing-whitespaces.patch
> > @@ -0,0 +1,693 @@
> > +From 1f48917d8ddb490dcdc70176e0f58136b7f7811a Mon Sep 17 00:00:00 2001
> > +From: Elyes Haouas <ehao...@noos.fr>
> > +Date: Fri, 4 Mar 2022 07:42:13 +0100
> > +Subject: [PATCH] video: Remove trailing whitespaces
> > +
> > +Signed-off-by: Elyes Haouas <ehao...@noos.fr>
> > +Reviewed-by: Daniel Kiper <daniel.ki...@oracle.com>
> > +
> > +Upstream-Status: Backport
> > +
> > +Reference to upstream patch:
> > +https://git.savannah.gnu.org/cgit/grub.git/commit/?id=1f48917d8ddb490dcdc
> > 70176e0f58136b7f7811a
> > +
> > +Signed-off-by: Yongxin Liu <yongxin....@windriver.com>
> > +---
> > + grub-core/video/bochs.c             |  2 +-
> > + grub-core/video/capture.c           |  2 +-
> > + grub-core/video/cirrus.c            |  4 ++--
> > + grub-core/video/coreboot/cbfb.c     |  2 +-
> > + grub-core/video/efi_gop.c           | 22 +++++++++----------
> > + grub-core/video/fb/fbblit.c         |  8 +++----
> > + grub-core/video/fb/video_fb.c       | 10 ++++-----
> > + grub-core/video/i386/pc/vbe.c       | 34 ++++++++++++++---------------
> > + grub-core/video/i386/pc/vga.c       |  6 ++---
> > + grub-core/video/ieee1275.c          |  4 ++--
> > + grub-core/video/radeon_fuloong2e.c  |  6 ++---
> > + grub-core/video/radeon_yeeloong3a.c |  6 ++---
> > + grub-core/video/readers/png.c       |  2 +-
> > + grub-core/video/readers/tga.c       |  2 +-
> > + grub-core/video/sis315_init.c       |  2 +-
> > + grub-core/video/sis315pro.c         |  8 +++----
> > + grub-core/video/sm712.c             | 10 ++++-----
> > + grub-core/video/video.c             |  8 +++----
> > + 18 files changed, 69 insertions(+), 69 deletions(-)
> > +
> > +diff --git a/grub-core/video/bochs.c b/grub-core/video/bochs.c
> > +index 30ea1bd82..edc651697 100644
> > +--- a/grub-core/video/bochs.c
> > ++++ b/grub-core/video/bochs.c
> > +@@ -212,7 +212,7 @@ find_card (grub_pci_device_t dev, grub_pci_id_t pciid,
> > void *data)
> > +
> > +   if (((class >> 16) & 0xffff) != 0x0300 || pciid != 0x11111234)
> > +     return 0;
> > +-
> > ++
> > +   addr = grub_pci_make_address (dev, GRUB_PCI_REG_ADDRESS_REG0);
> > +   framebuffer.base = grub_pci_read (addr) & GRUB_PCI_ADDR_MEM_MASK;
> > +   if (!framebuffer.base)
> > +diff --git a/grub-core/video/capture.c b/grub-core/video/capture.c
> > +index 4d3195e01..c653d89f9 100644
> > +--- a/grub-core/video/capture.c
> > ++++ b/grub-core/video/capture.c
> > +@@ -92,7 +92,7 @@ grub_video_capture_start (const struct
> > grub_video_mode_info *mode_info,
> > +   framebuffer.ptr = grub_calloc (framebuffer.mode_info.height,
> > framebuffer.mode_info.pitch);
> > +   if (!framebuffer.ptr)
> > +     return grub_errno;
> > +-
> > ++
> > +   err = grub_video_fb_create_render_target_from_pointer
> > (&framebuffer.render_target,
> > +                                                      
> > &framebuffer.mode_info,
> > +                                                      framebuffer.ptr);
> > +diff --git a/grub-core/video/cirrus.c b/grub-core/video/cirrus.c
> > +index e2149e8ce..f5542ccdc 100644
> > +--- a/grub-core/video/cirrus.c
> > ++++ b/grub-core/video/cirrus.c
> > +@@ -354,11 +354,11 @@ grub_video_cirrus_setup (unsigned int width,
> > unsigned int height,
> > +     grub_uint8_t sr_ext = 0, hidden_dac = 0;
> > +
> > +     grub_vga_set_geometry (&config, grub_vga_cr_write);
> > +-
> > ++
> > +     grub_vga_gr_write (GRUB_VGA_GR_MODE_256_COLOR |
> > GRUB_VGA_GR_MODE_READ_MODE1,
> > +                    GRUB_VGA_GR_MODE);
> > +     grub_vga_gr_write (GRUB_VGA_GR_GR6_GRAPHICS_MODE, GRUB_VGA_GR_GR6);
> > +-
> > ++
> > +     grub_vga_sr_write (GRUB_VGA_SR_MEMORY_MODE_NORMAL,
> > GRUB_VGA_SR_MEMORY_MODE);
> > +
> > +     grub_vga_cr_write ((config.pitch >>
> > CIRRUS_CR_EXTENDED_DISPLAY_PITCH_SHIFT)
> > +diff --git a/grub-core/video/coreboot/cbfb.c b/grub-
> > core/video/coreboot/cbfb.c
> > +index 9af81fa5b..986003c51 100644
> > +--- a/grub-core/video/coreboot/cbfb.c
> > ++++ b/grub-core/video/coreboot/cbfb.c
> > +@@ -106,7 +106,7 @@ grub_video_cbfb_setup (unsigned int width, unsigned
> > int height,
> > +
> > +   grub_video_fb_set_palette (0, GRUB_VIDEO_FBSTD_NUMCOLORS,
> > +                          grub_video_fbstd_colors);
> > +-
> > ++
> > +   return err;
> > + }
> > +
> > +diff --git a/grub-core/video/efi_gop.c b/grub-core/video/efi_gop.c
> > +index b7590dc6c..7a5054631 100644
> > +--- a/grub-core/video/efi_gop.c
> > ++++ b/grub-core/video/efi_gop.c
> > +@@ -273,7 +273,7 @@ grub_video_gop_iterate (int (*hook) (const struct
> > grub_video_mode_info *info, vo
> > +       grub_efi_status_t status;
> > +       struct grub_efi_gop_mode_info *info = NULL;
> > +       struct grub_video_mode_info mode_info;
> > +-
> > ++
> > +       status = efi_call_4 (gop->query_mode, gop, mode, &size, &info);
> > +
> > +       if (status)
> > +@@ -390,7 +390,7 @@ grub_video_gop_setup (unsigned int width, unsigned
> > int height,
> > +       found = 1;
> > +     }
> > +     }
> > +-
> > ++
> > +   if (!found)
> > +     {
> > +       unsigned mode;
> > +@@ -399,7 +399,7 @@ grub_video_gop_setup (unsigned int width, unsigned
> > int height,
> > +     {
> > +       grub_efi_uintn_t size;
> > +       grub_efi_status_t status;
> > +-
> > ++
> > +       status = efi_call_4 (gop->query_mode, gop, mode, &size, &info);
> > +       if (status)
> > +         {
> > +@@ -472,11 +472,11 @@ grub_video_gop_setup (unsigned int width, unsigned
> > int height,
> > +   framebuffer.ptr = (void *) (grub_addr_t) gop->mode->fb_base;
> > +   framebuffer.offscreen
> > +     = grub_malloc (framebuffer.mode_info.height
> > +-               * framebuffer.mode_info.width
> > ++               * framebuffer.mode_info.width
> > +                * sizeof (struct grub_efi_gop_blt_pixel));
> > +
> > +   buffer = framebuffer.offscreen;
> > +-
> > ++
> > +   if (!buffer)
> > +     {
> > +       grub_dprintf ("video", "GOP: couldn't allocate shadow\n");
> > +@@ -485,11 +485,11 @@ grub_video_gop_setup (unsigned int width, unsigned
> > int height,
> > +                                  &framebuffer.mode_info);
> > +       buffer = framebuffer.ptr;
> > +     }
> > +-
> > ++
> > +   grub_dprintf ("video", "GOP: initialising FB @ %p %dx%dx%d\n",
> > +             framebuffer.ptr, framebuffer.mode_info.width,
> > +             framebuffer.mode_info.height, framebuffer.mode_info.bpp);
> > +-
> > ++
> > +   err = grub_video_fb_create_render_target_from_pointer
> > +     (&framebuffer.render_target, &framebuffer.mode_info, buffer);
> > +
> > +@@ -498,15 +498,15 @@ grub_video_gop_setup (unsigned int width, unsigned
> > int height,
> > +       grub_dprintf ("video", "GOP: Couldn't create FB target\n");
> > +       return err;
> > +     }
> > +-
> > ++
> > +   err = grub_video_fb_set_active_render_target
> > (framebuffer.render_target);
> > +-
> > ++
> > +   if (err)
> > +     {
> > +       grub_dprintf ("video", "GOP: Couldn't set FB target\n");
> > +       return err;
> > +     }
> > +-
> > ++
> > +   err = grub_video_fb_set_palette (0, GRUB_VIDEO_FBSTD_NUMCOLORS,
> > +                                grub_video_fbstd_colors);
> > +
> > +@@ -514,7 +514,7 @@ grub_video_gop_setup (unsigned int width, unsigned
> > int height,
> > +     grub_dprintf ("video", "GOP: Couldn't set palette\n");
> > +   else
> > +     grub_dprintf ("video", "GOP: Success\n");
> > +-
> > ++
> > +   return err;
> > + }
> > +
> > +diff --git a/grub-core/video/fb/fbblit.c b/grub-core/video/fb/fbblit.c
> > +index d55924837..1010ef393 100644
> > +--- a/grub-core/video/fb/fbblit.c
> > ++++ b/grub-core/video/fb/fbblit.c
> > +@@ -466,7 +466,7 @@ grub_video_fbblit_replace_24bit_indexa (struct
> > grub_video_fbblit_info *dst,
> > +       for (i = 0; i < width; i++)
> > +         {
> > +       register grub_uint32_t col;
> > +-      if (*srcptr == 0xf0)
> > ++      if (*srcptr == 0xf0)
> > +         col = palette[16];
> > +       else
> > +         col = palette[*srcptr & 0xf];
> > +@@ -478,7 +478,7 @@ grub_video_fbblit_replace_24bit_indexa (struct
> > grub_video_fbblit_info *dst,
> > +       *dstptr++ = col >> 0;
> > +       *dstptr++ = col >> 8;
> > +       *dstptr++ = col >> 16;
> > +-#endif
> > ++#endif
> > +       srcptr++;
> > +         }
> > +
> > +@@ -651,7 +651,7 @@ grub_video_fbblit_blend_24bit_indexa (struct
> > grub_video_fbblit_info *dst,
> > +       for (i = 0; i < width; i++)
> > +         {
> > +       register grub_uint32_t col;
> > +-      if (*srcptr != 0xf0)
> > ++      if (*srcptr != 0xf0)
> > +         {
> > +           col = palette[*srcptr & 0xf];
> > + #ifdef GRUB_CPU_WORDS_BIGENDIAN
> > +@@ -662,7 +662,7 @@ grub_video_fbblit_blend_24bit_indexa (struct
> > grub_video_fbblit_info *dst,
> > +           *dstptr++ = col >> 0;
> > +           *dstptr++ = col >> 8;
> > +           *dstptr++ = col >> 16;
> > +-#endif
> > ++#endif
> > +         }
> > +       else
> > +         dstptr += 3;
> > +diff --git a/grub-core/video/fb/video_fb.c b/grub-
> > core/video/fb/video_fb.c
> > +index ae6b89f9a..fa4ebde26 100644
> > +--- a/grub-core/video/fb/video_fb.c
> > ++++ b/grub-core/video/fb/video_fb.c
> > +@@ -754,7 +754,7 @@ grub_video_fb_unmap_color_int (struct
> > grub_video_fbblit_info * source,
> > +           *alpha = 0;
> > +           return;
> > +         }
> > +-
> > ++
> > +       /* If we have an out-of-bounds color, return transparent black.
> > */
> > +       if (color > 255)
> > +         {
> > +@@ -1141,7 +1141,7 @@ grub_video_fb_scroll (grub_video_color_t color, int
> > dx, int dy)
> > +       /* If everything is aligned on 32-bit use 32-bit copy.  */
> > +       if ((grub_addr_t) grub_video_fb_get_video_ptr (&target, src_x,
> > src_y)
> > +       % sizeof (grub_uint32_t) == 0
> > +-      && (grub_addr_t) grub_video_fb_get_video_ptr (&target, dst_x,
> > dst_y)
> > ++      && (grub_addr_t) grub_video_fb_get_video_ptr (&target, dst_x,
> > dst_y)
> > +       % sizeof (grub_uint32_t) == 0
> > +       && linelen % sizeof (grub_uint32_t) == 0
> > +       && linedelta % sizeof (grub_uint32_t) == 0)
> > +@@ -1155,7 +1155,7 @@ grub_video_fb_scroll (grub_video_color_t color, int
> > dx, int dy)
> > +       else if ((grub_addr_t) grub_video_fb_get_video_ptr (&target, src_x,
> > src_y)
> > +            % sizeof (grub_uint16_t) == 0
> > +            && (grub_addr_t) grub_video_fb_get_video_ptr (&target,
> > +-                                                         dst_x, dst_y)
> > ++                                                         dst_x, dst_y)
> > +            % sizeof (grub_uint16_t) == 0
> > +            && linelen % sizeof (grub_uint16_t) == 0
> > +            && linedelta % sizeof (grub_uint16_t) == 0)
> > +@@ -1170,7 +1170,7 @@ grub_video_fb_scroll (grub_video_color_t color, int
> > dx, int dy)
> > +     {
> > +       grub_uint8_t *src, *dst;
> > +       DO_SCROLL
> > +-    }
> > ++    }
> > +     }
> > +
> > +   /* 4. Fill empty space with specified color.  In this implementation
> > +@@ -1615,7 +1615,7 @@ grub_video_fb_setup (unsigned int mode_type,
> > unsigned int mode_mask,
> > +       framebuffer.render_target = framebuffer.back_target;
> > +       return GRUB_ERR_NONE;
> > +     }
> > +-
> > ++
> > +       mode_info->mode_type &= ~(GRUB_VIDEO_MODE_TYPE_DOUBLE_BUFFERED
> > +                             | GRUB_VIDEO_MODE_TYPE_UPDATING_SWAP);
> > +
> > +diff --git a/grub-core/video/i386/pc/vbe.c b/grub-
> > core/video/i386/pc/vbe.c
> > +index b7f911926..0e65b5206 100644
> > +--- a/grub-core/video/i386/pc/vbe.c
> > ++++ b/grub-core/video/i386/pc/vbe.c
> > +@@ -219,7 +219,7 @@ grub_vbe_disable_mtrr (int mtrr)
> > + }
> > +
> > + /* Call VESA BIOS 0x4f09 to set palette data, return status.  */
> > +-static grub_vbe_status_t
> > ++static grub_vbe_status_t
> > + grub_vbe_bios_set_palette_data (grub_uint32_t color_count,
> > +                             grub_uint32_t start_index,
> > +                             struct grub_vbe_palette_data *palette_data)
> > +@@ -237,7 +237,7 @@ grub_vbe_bios_set_palette_data (grub_uint32_t
> > color_count,
> > + }
> > +
> > + /* Call VESA BIOS 0x4f00 to get VBE Controller Information, return
> > status.  */
> > +-grub_vbe_status_t
> > ++grub_vbe_status_t
> > + grub_vbe_bios_get_controller_info (struct grub_vbe_info_block *ci)
> > + {
> > +   struct grub_bios_int_registers regs;
> > +@@ -251,7 +251,7 @@ grub_vbe_bios_get_controller_info (struct
> > grub_vbe_info_block *ci)
> > + }
> > +
> > + /* Call VESA BIOS 0x4f01 to get VBE Mode Information, return status.  */
> > +-grub_vbe_status_t
> > ++grub_vbe_status_t
> > + grub_vbe_bios_get_mode_info (grub_uint32_t mode,
> > +                          struct grub_vbe_mode_info_block *mode_info)
> > + {
> > +@@ -285,7 +285,7 @@ grub_vbe_bios_set_mode (grub_uint32_t mode,
> > + }
> > +
> > + /* Call VESA BIOS 0x4f03 to return current VBE Mode, return status.  */
> > +-grub_vbe_status_t
> > ++grub_vbe_status_t
> > + grub_vbe_bios_get_mode (grub_uint32_t *mode)
> > + {
> > +   struct grub_bios_int_registers regs;
> > +@@ -298,7 +298,7 @@ grub_vbe_bios_get_mode (grub_uint32_t *mode)
> > +   return regs.eax & 0xffff;
> > + }
> > +
> > +-grub_vbe_status_t
> > ++grub_vbe_status_t
> > + grub_vbe_bios_getset_dac_palette_width (int set, int *dac_mask_size)
> > + {
> > +   struct grub_bios_int_registers regs;
> > +@@ -346,7 +346,7 @@ grub_vbe_bios_get_memory_window (grub_uint32_t window,
> > + }
> > +
> > + /* Call VESA BIOS 0x4f06 to set scanline length (in bytes), return
> > status.  */
> > +-grub_vbe_status_t
> > ++grub_vbe_status_t
> > + grub_vbe_bios_set_scanline_length (grub_uint32_t length)
> > + {
> > +   struct grub_bios_int_registers regs;
> > +@@ -354,14 +354,14 @@ grub_vbe_bios_set_scanline_length (grub_uint32_t
> > length)
> > +   regs.ecx = length;
> > +   regs.eax = 0x4f06;
> > +   /* BL = 2, Set Scan Line in Bytes.  */
> > +-  regs.ebx = 0x0002;
> > ++  regs.ebx = 0x0002;
> > +   regs.flags = GRUB_CPU_INT_FLAGS_DEFAULT;
> > +   grub_bios_interrupt (0x10, &regs);
> > +   return regs.eax & 0xffff;
> > + }
> > +
> > + /* Call VESA BIOS 0x4f06 to return scanline length (in bytes), return
> > status.  */
> > +-grub_vbe_status_t
> > ++grub_vbe_status_t
> > + grub_vbe_bios_get_scanline_length (grub_uint32_t *length)
> > + {
> > +   struct grub_bios_int_registers regs;
> > +@@ -377,7 +377,7 @@ grub_vbe_bios_get_scanline_length (grub_uint32_t
> > *length)
> > + }
> > +
> > + /* Call VESA BIOS 0x4f07 to set display start, return status.  */
> > +-static grub_vbe_status_t
> > ++static grub_vbe_status_t
> > + grub_vbe_bios_set_display_start (grub_uint32_t x, grub_uint32_t y)
> > + {
> > +   struct grub_bios_int_registers regs;
> > +@@ -390,7 +390,7 @@ grub_vbe_bios_set_display_start (grub_uint32_t x,
> > grub_uint32_t y)
> > +   regs.edx = y;
> > +   regs.eax = 0x4f07;
> > +   /* BL = 80h, Set Display Start during Vertical Retrace.  */
> > +-  regs.ebx = 0x0080;
> > ++  regs.ebx = 0x0080;
> > +   regs.flags = GRUB_CPU_INT_FLAGS_DEFAULT;
> > +   grub_bios_interrupt (0x10, &regs);
> > +
> > +@@ -401,7 +401,7 @@ grub_vbe_bios_set_display_start (grub_uint32_t x,
> > grub_uint32_t y)
> > + }
> > +
> > + /* Call VESA BIOS 0x4f07 to get display start, return status.  */
> > +-grub_vbe_status_t
> > ++grub_vbe_status_t
> > + grub_vbe_bios_get_display_start (grub_uint32_t *x,
> > +                              grub_uint32_t *y)
> > + {
> > +@@ -419,7 +419,7 @@ grub_vbe_bios_get_display_start (grub_uint32_t *x,
> > + }
> > +
> > + /* Call VESA BIOS 0x4f0a.  */
> > +-grub_vbe_status_t
> > ++grub_vbe_status_t
> > + grub_vbe_bios_get_pm_interface (grub_uint16_t *segment, grub_uint16_t
> > *offset,
> > +                             grub_uint16_t *length)
> > + {
> > +@@ -896,7 +896,7 @@ vbe2videoinfo (grub_uint32_t mode,
> > +     case GRUB_VBE_MEMORY_MODEL_YUV:
> > +       mode_info->mode_type |= GRUB_VIDEO_MODE_TYPE_YUV;
> > +       break;
> > +-
> > ++
> > +     case GRUB_VBE_MEMORY_MODEL_DIRECT_COLOR:
> > +       mode_info->mode_type |= GRUB_VIDEO_MODE_TYPE_RGB;
> > +       break;
> > +@@ -923,10 +923,10 @@ vbe2videoinfo (grub_uint32_t mode,
> > +       break;
> > +     case 8:
> > +       mode_info->bytes_per_pixel = 1;
> > +-      break;
> > ++      break;
> > +     case 4:
> > +       mode_info->bytes_per_pixel = 0;
> > +-      break;
> > ++      break;
> > +     }
> > +
> > +   if (controller_info.version >= 0x300)
> > +@@ -976,7 +976,7 @@ grub_video_vbe_iterate (int (*hook) (const struct
> > grub_video_mode_info *info, vo
> > +
> > + static grub_err_t
> > + grub_video_vbe_setup (unsigned int width, unsigned int height,
> > +-                      grub_video_mode_type_t mode_type,
> > ++                      grub_video_mode_type_t mode_type,
> > +                   grub_video_mode_type_t mode_mask)
> > + {
> > +   grub_uint16_t *p;
> > +@@ -1193,7 +1193,7 @@ grub_video_vbe_print_adapter_specific_info (void)
> > +             controller_info.version & 0xFF,
> > +             controller_info.oem_software_rev >> 8,
> > +             controller_info.oem_software_rev & 0xFF);
> > +-
> > ++
> > +   /* The total_memory field is in 64 KiB units.  */
> > +   grub_printf_ (N_("              total memory: %d KiB\n"),
> > +             (controller_info.total_memory << 6));
> > +diff --git a/grub-core/video/i386/pc/vga.c b/grub-
> > core/video/i386/pc/vga.c
> > +index b2f776c99..50d0b5e02 100644
> > +--- a/grub-core/video/i386/pc/vga.c
> > ++++ b/grub-core/video/i386/pc/vga.c
> > +@@ -48,7 +48,7 @@ static struct
> > +   int back_page;
> > + } framebuffer;
> > +
> > +-static unsigned char
> > ++static unsigned char
> > + grub_vga_set_mode (unsigned char mode)
> > + {
> > +   struct grub_bios_int_registers regs;
> > +@@ -182,10 +182,10 @@ grub_video_vga_setup (unsigned int width, unsigned
> > int height,
> > +
> > +   is_target = 1;
> > +   err = grub_video_fb_set_active_render_target
> > (framebuffer.render_target);
> > +-
> > ++
> > +   if (err)
> > +     return err;
> > +-
> > ++
> > +   err = grub_video_fb_set_palette (0, GRUB_VIDEO_FBSTD_NUMCOLORS,
> > +                                grub_video_fbstd_colors);
> > +
> > +diff --git a/grub-core/video/ieee1275.c b/grub-core/video/ieee1275.c
> > +index f437fb0df..ca3d3c3b2 100644
> > +--- a/grub-core/video/ieee1275.c
> > ++++ b/grub-core/video/ieee1275.c
> > +@@ -233,7 +233,7 @@ grub_video_ieee1275_setup (unsigned int width,
> > unsigned int height,
> > +       /* TODO. */
> > +       return grub_error (GRUB_ERR_IO, "can't set mode %dx%d", width,
> > height);
> > +     }
> > +-
> > ++
> > +   err = grub_video_ieee1275_fill_mode_info (dev, &framebuffer.mode_info);
> > +   if (err)
> > +     {
> > +@@ -260,7 +260,7 @@ grub_video_ieee1275_setup (unsigned int width,
> > unsigned int height,
> > +
> > +   grub_video_ieee1275_set_palette (0,
> > framebuffer.mode_info.number_of_colors,
> > +                                grub_video_fbstd_colors);
> > +-
> > ++
> > +   return err;
> > + }
> > +
> > +diff --git a/grub-core/video/radeon_fuloong2e.c b/grub-
> > core/video/radeon_fuloong2e.c
> > +index b4da34b5e..40917acb7 100644
> > +--- a/grub-core/video/radeon_fuloong2e.c
> > ++++ b/grub-core/video/radeon_fuloong2e.c
> > +@@ -75,7 +75,7 @@ find_card (grub_pci_device_t dev, grub_pci_id_t pciid,
> > void *data)
> > +   if (((class >> 16) & 0xffff) != GRUB_PCI_CLASS_SUBCLASS_VGA
> > +       || pciid != 0x515a1002)
> > +     return 0;
> > +-
> > ++
> > +   *found = 1;
> > +
> > +   addr = grub_pci_make_address (dev, GRUB_PCI_REG_ADDRESS_REG0);
> > +@@ -139,7 +139,7 @@ grub_video_radeon_fuloong2e_setup (unsigned int width,
> > unsigned int height,
> > +   framebuffer.mapped = 1;
> > +
> > +   /* Prevent garbage from appearing on the screen.  */
> > +-  grub_memset (framebuffer.ptr, 0x55,
> > ++  grub_memset (framebuffer.ptr, 0x55,
> > +            framebuffer.mode_info.height * framebuffer.mode_info.pitch);
> > +
> > + #ifndef TEST
> > +@@ -152,7 +152,7 @@ grub_video_radeon_fuloong2e_setup (unsigned int width,
> > unsigned int height,
> > +     return err;
> > +
> > +   err = grub_video_fb_set_active_render_target
> > (framebuffer.render_target);
> > +-
> > ++
> > +   if (err)
> > +     return err;
> > +
> > +diff --git a/grub-core/video/radeon_yeeloong3a.c b/grub-
> > core/video/radeon_yeeloong3a.c
> > +index 52614feb6..48631c181 100644
> > +--- a/grub-core/video/radeon_yeeloong3a.c
> > ++++ b/grub-core/video/radeon_yeeloong3a.c
> > +@@ -74,7 +74,7 @@ find_card (grub_pci_device_t dev, grub_pci_id_t pciid,
> > void *data)
> > +   if (((class >> 16) & 0xffff) != GRUB_PCI_CLASS_SUBCLASS_VGA
> > +       || pciid != 0x96151002)
> > +     return 0;
> > +-
> > ++
> > +   *found = 1;
> > +
> > +   addr = grub_pci_make_address (dev, GRUB_PCI_REG_ADDRESS_REG0);
> > +@@ -137,7 +137,7 @@ grub_video_radeon_yeeloong3a_setup (unsigned int
> > width, unsigned int height,
> > + #endif
> > +
> > +   /* Prevent garbage from appearing on the screen.  */
> > +-  grub_memset (framebuffer.ptr, 0,
> > ++  grub_memset (framebuffer.ptr, 0,
> > +            framebuffer.mode_info.height * framebuffer.mode_info.pitch);
> > +
> > + #ifndef TEST
> > +@@ -150,7 +150,7 @@ grub_video_radeon_yeeloong3a_setup (unsigned int
> > width, unsigned int height,
> > +     return err;
> > +
> > +   err = grub_video_fb_set_active_render_target
> > (framebuffer.render_target);
> > +-
> > ++
> > +   if (err)
> > +     return err;
> > +
> > +diff --git a/grub-core/video/readers/png.c b/grub-
> > core/video/readers/png.c
> > +index 0157ff742..54dfedf43 100644
> > +--- a/grub-core/video/readers/png.c
> > ++++ b/grub-core/video/readers/png.c
> > +@@ -916,7 +916,7 @@ grub_png_convert_image (struct grub_png_data *data)
> > +     }
> > +       return;
> > +     }
> > +-
> > ++
> > +   if (data->is_gray)
> > +     {
> > +       switch (data->bpp)
> > +diff --git a/grub-core/video/readers/tga.c b/grub-
> > core/video/readers/tga.c
> > +index 7cb9d1d2a..a9ec3a1b6 100644
> > +--- a/grub-core/video/readers/tga.c
> > ++++ b/grub-core/video/readers/tga.c
> > +@@ -127,7 +127,7 @@ tga_load_palette (struct tga_data *data)
> > +
> > +   if (len > sizeof (data->palette))
> > +     len = sizeof (data->palette);
> > +-
> > ++
> > +   if (grub_file_read (data->file, &data->palette, len)
> > +       != (grub_ssize_t) len)
> > +     return grub_errno;
> > +diff --git a/grub-core/video/sis315_init.c b/grub-
> > core/video/sis315_init.c
> > +index ae5c1419c..09c3c7bbe 100644
> > +--- a/grub-core/video/sis315_init.c
> > ++++ b/grub-core/video/sis315_init.c
> > +@@ -1,4 +1,4 @@
> > +-static const struct { grub_uint8_t reg; grub_uint8_t val; } sr_dump [] =
> > ++static const struct { grub_uint8_t reg; grub_uint8_t val; } sr_dump [] =
> > + {
> > +   { 0x28, 0x81 },
> > +   { 0x2a, 0x00 },
> > +diff --git a/grub-core/video/sis315pro.c b/grub-core/video/sis315pro.c
> > +index 22a0c85a6..4d2f9999a 100644
> > +--- a/grub-core/video/sis315pro.c
> > ++++ b/grub-core/video/sis315pro.c
> > +@@ -103,7 +103,7 @@ find_card (grub_pci_device_t dev, grub_pci_id_t pciid,
> > void *data)
> > +   if (((class >> 16) & 0xffff) != GRUB_PCI_CLASS_SUBCLASS_VGA
> > +       || pciid != GRUB_SIS315PRO_PCIID)
> > +     return 0;
> > +-
> > ++
> > +   *found = 1;
> > +
> > +   addr = grub_pci_make_address (dev, GRUB_PCI_REG_ADDRESS_REG0);
> > +@@ -218,7 +218,7 @@ grub_video_sis315pro_setup (unsigned int width,
> > unsigned int height,
> > +
> > + #ifndef TEST
> > +   /* Prevent garbage from appearing on the screen.  */
> > +-  grub_memset (framebuffer.ptr, 0,
> > ++  grub_memset (framebuffer.ptr, 0,
> > +            framebuffer.mode_info.height * framebuffer.mode_info.pitch);
> > +   grub_arch_sync_dma_caches (framebuffer.ptr,
> > +                          framebuffer.mode_info.height
> > +@@ -231,7 +231,7 @@ grub_video_sis315pro_setup (unsigned int width,
> > unsigned int height,
> > +          | GRUB_VGA_IO_MISC_EXTERNAL_CLOCK_0
> > +          | GRUB_VGA_IO_MISC_28MHZ
> > +          | GRUB_VGA_IO_MISC_ENABLE_VRAM_ACCESS
> > +-         | GRUB_VGA_IO_MISC_COLOR,
> > ++         | GRUB_VGA_IO_MISC_COLOR,
> > +          GRUB_VGA_IO_MISC_WRITE + GRUB_MACHINE_PCI_IO_BASE);
> > +
> > +   grub_vga_sr_write (0x86, 5);
> > +@@ -335,7 +335,7 @@ grub_video_sis315pro_setup (unsigned int width,
> > unsigned int height,
> > +   {
> > +     if (read_sis_cmd (0x5) != 0xa1)
> > +       write_sis_cmd (0x86, 0x5);
> > +-
> > ++
> > +     write_sis_cmd (read_sis_cmd (0x20) | 0xa1, 0x20);
> > +     write_sis_cmd (read_sis_cmd (0x1e) | 0xda, 0x1e);
> > +
> > +diff --git a/grub-core/video/sm712.c b/grub-core/video/sm712.c
> > +index 10c46eb65..65f59f84b 100644
> > +--- a/grub-core/video/sm712.c
> > ++++ b/grub-core/video/sm712.c
> > +@@ -167,7 +167,7 @@ enum
> > +     GRUB_SM712_CR_SHADOW_VGA_VBLANK_START = 0x46,
> > +     GRUB_SM712_CR_SHADOW_VGA_VBLANK_END = 0x47,
> > +     GRUB_SM712_CR_SHADOW_VGA_VRETRACE_START = 0x48,
> > +-    GRUB_SM712_CR_SHADOW_VGA_VRETRACE_END = 0x49,
> > ++    GRUB_SM712_CR_SHADOW_VGA_VRETRACE_END = 0x49,
> > +     GRUB_SM712_CR_SHADOW_VGA_OVERFLOW = 0x4a,
> > +     GRUB_SM712_CR_SHADOW_VGA_CELL_HEIGHT = 0x4b,
> > +     GRUB_SM712_CR_SHADOW_VGA_HDISPLAY_END = 0x4c,
> > +@@ -375,7 +375,7 @@ find_card (grub_pci_device_t dev, grub_pci_id_t pciid,
> > void *data)
> > +   if (((class >> 16) & 0xffff) != GRUB_PCI_CLASS_SUBCLASS_VGA
> > +       || pciid != GRUB_SM712_PCIID)
> > +     return 0;
> > +-
> > ++
> > +   *found = 1;
> > +
> > +   addr = grub_pci_make_address (dev, GRUB_PCI_REG_ADDRESS_REG0);
> > +@@ -471,7 +471,7 @@ grub_video_sm712_setup (unsigned int width, unsigned
> > int height,
> > +
> > + #if !defined (TEST) && !defined(GENINIT)
> > +   /* Prevent garbage from appearing on the screen.  */
> > +-  grub_memset ((void *) framebuffer.cached_ptr, 0,
> > ++  grub_memset ((void *) framebuffer.cached_ptr, 0,
> > +            framebuffer.mode_info.height * framebuffer.mode_info.pitch);
> > + #endif
> > +
> > +@@ -482,7 +482,7 @@ grub_video_sm712_setup (unsigned int width, unsigned
> > int height,
> > +   grub_sm712_sr_write (0x2, 0x6b);
> > +   grub_sm712_write_reg (0, GRUB_VGA_IO_PIXEL_MASK);
> > +   grub_sm712_sr_write (GRUB_VGA_SR_RESET_ASYNC, GRUB_VGA_SR_RESET);
> > +-  grub_sm712_write_reg (GRUB_VGA_IO_MISC_NEGATIVE_VERT_POLARITY
> > ++  grub_sm712_write_reg (GRUB_VGA_IO_MISC_NEGATIVE_VERT_POLARITY
> > +                     | GRUB_VGA_IO_MISC_NEGATIVE_HORIZ_POLARITY
> > +                     | GRUB_VGA_IO_MISC_UPPER_64K
> > +                     | GRUB_VGA_IO_MISC_EXTERNAL_CLOCK_0
> > +@@ -694,7 +694,7 @@ grub_video_sm712_setup (unsigned int width, unsigned
> > int height,
> > +   for (i = 0; i < ARRAY_SIZE (dda_lookups); i++)
> > +     grub_sm712_write_dda_lookup (i, dda_lookups[i].compare,
> > dda_lookups[i].dda,
> > +                              dda_lookups[i].vcentering);
> > +-
> > ++
> > +   /* Undocumented  */
> > +   grub_sm712_cr_write (0, 0x9c);
> > +   grub_sm712_cr_write (0, 0x9d);
> > +diff --git a/grub-core/video/video.c b/grub-core/video/video.c
> > +index 983424107..8937da745 100644
> > +--- a/grub-core/video/video.c
> > ++++ b/grub-core/video/video.c
> > +@@ -491,13 +491,13 @@ parse_modespec (const char *current_mode, int
> > *width, int *height, int *depth)
> > +                    current_mode);
> > +
> > +   param++;
> > +-
> > ++
> > +   *width = grub_strtoul (value, 0, 0);
> > +   if (grub_errno != GRUB_ERR_NONE)
> > +       return grub_error (GRUB_ERR_BAD_ARGUMENT,
> > +                      N_("invalid video mode specification `%s'"),
> > +                      current_mode);
> > +-
> > ++
> > +   /* Find height value.  */
> > +   value = param;
> > +   param = grub_strchr(param, 'x');
> > +@@ -513,13 +513,13 @@ parse_modespec (const char *current_mode, int
> > *width, int *height, int *depth)
> > +     {
> > +       /* We have optional color depth value.  */
> > +       param++;
> > +-
> > ++
> > +       *height = grub_strtoul (value, 0, 0);
> > +       if (grub_errno != GRUB_ERR_NONE)
> > +     return grub_error (GRUB_ERR_BAD_ARGUMENT,
> > +                        N_("invalid video mode specification `%s'"),
> > +                        current_mode);
> > +-
> > ++
> > +       /* Convert color depth value.  */
> > +       value = param;
> > +       *depth = grub_strtoul (value, 0, 0);
> > +--
> > +2.34.1
> > +
> > diff --git a/meta/recipes-bsp/grub/files/video-readers-jpeg-Abort-sooner-
> > if-a-read-operation-.patch b/meta/recipes-bsp/grub/files/video-readers-
> > jpeg-Abort-sooner-if-a-read-operation-.patch
> > new file mode 100644
> > index 0000000000..0c7deae858
> > --- /dev/null
> > +++ b/meta/recipes-bsp/grub/files/video-readers-jpeg-Abort-sooner-if-a-
> > read-operation-.patch
> > @@ -0,0 +1,264 @@
> > +From d5caac8ab79d068ad9a41030c772d03a4d4fbd7b Mon Sep 17 00:00:00 2001
> > +From: Daniel Axtens <d...@axtens.net>
> > +Date: Mon, 28 Jun 2021 14:16:14 +1000
> > +Subject: [PATCH] video/readers/jpeg: Abort sooner if a read operation
> > fails
> > +
> > +Fuzzing revealed some inputs that were taking a long time, potentially
> > +forever, because they did not bail quickly upon encountering an I/O error.
> > +
> > +Try to catch I/O errors sooner and bail out.
> > +
> > +Signed-off-by: Daniel Axtens <d...@axtens.net>
> > +Reviewed-by: Daniel Kiper <daniel.ki...@oracle.com>
> > +
> > +Upstream-Status: Backport
> > +
> > +Reference to upstream patch:
> > +https://git.savannah.gnu.org/cgit/grub.git/commit/?id=d5caac8ab79d068ad9a
> > 41030c772d03a4d4fbd7b
> > +
> > +Signed-off-by: Yongxin Liu <yongxin....@windriver.com>
> > +---
> > + grub-core/video/readers/jpeg.c | 86 +++++++++++++++++++++++++++-------
> > + 1 file changed, 70 insertions(+), 16 deletions(-)
> > +
> > +diff --git a/grub-core/video/readers/jpeg.c b/grub-
> > core/video/readers/jpeg.c
> > +index c47ffd651..806c56c78 100644
> > +--- a/grub-core/video/readers/jpeg.c
> > ++++ b/grub-core/video/readers/jpeg.c
> > +@@ -109,9 +109,17 @@ static grub_uint8_t
> > + grub_jpeg_get_byte (struct grub_jpeg_data *data)
> > + {
> > +   grub_uint8_t r;
> > ++  grub_ssize_t bytes_read;
> > +
> > +   r = 0;
> > +-  grub_file_read (data->file, &r, 1);
> > ++  bytes_read = grub_file_read (data->file, &r, 1);
> > ++
> > ++  if (bytes_read != 1)
> > ++    {
> > ++      grub_error (GRUB_ERR_BAD_FILE_TYPE,
> > ++              "jpeg: unexpected end of data");
> > ++      return 0;
> > ++    }
> > +
> > +   return r;
> > + }
> > +@@ -120,9 +128,17 @@ static grub_uint16_t
> > + grub_jpeg_get_word (struct grub_jpeg_data *data)
> > + {
> > +   grub_uint16_t r;
> > ++  grub_ssize_t bytes_read;
> > +
> > +   r = 0;
> > +-  grub_file_read (data->file, &r, sizeof (grub_uint16_t));
> > ++  bytes_read = grub_file_read (data->file, &r, sizeof (grub_uint16_t));
> > ++
> > ++  if (bytes_read != sizeof (grub_uint16_t))
> > ++    {
> > ++      grub_error (GRUB_ERR_BAD_FILE_TYPE,
> > ++              "jpeg: unexpected end of data");
> > ++      return 0;
> > ++    }
> > +
> > +   return grub_be_to_cpu16 (r);
> > + }
> > +@@ -135,6 +151,11 @@ grub_jpeg_get_bit (struct grub_jpeg_data *data)
> > +   if (data->bit_mask == 0)
> > +     {
> > +       data->bit_save = grub_jpeg_get_byte (data);
> > ++      if (grub_errno != GRUB_ERR_NONE) {
> > ++    grub_error (GRUB_ERR_BAD_FILE_TYPE,
> > ++                "jpeg: file read error");
> > ++    return 0;
> > ++      }
> > +       if (data->bit_save == JPEG_ESC_CHAR)
> > +     {
> > +       if (grub_jpeg_get_byte (data) != 0)
> > +@@ -143,6 +164,11 @@ grub_jpeg_get_bit (struct grub_jpeg_data *data)
> > +                       "jpeg: invalid 0xFF in data stream");
> > +           return 0;
> > +         }
> > ++      if (grub_errno != GRUB_ERR_NONE)
> > ++        {
> > ++          grub_error (GRUB_ERR_BAD_FILE_TYPE, "jpeg: file read error");
> > ++          return 0;
> > ++        }
> > +     }
> > +       data->bit_mask = 0x80;
> > +     }
> > +@@ -161,7 +187,7 @@ grub_jpeg_get_number (struct grub_jpeg_data *data,
> > int num)
> > +     return 0;
> > +
> > +   msb = value = grub_jpeg_get_bit (data);
> > +-  for (i = 1; i < num; i++)
> > ++  for (i = 1; i < num && grub_errno == GRUB_ERR_NONE; i++)
> > +     value = (value << 1) + (grub_jpeg_get_bit (data) != 0);
> > +   if (!msb)
> > +     value += 1 - (1 << num);
> > +@@ -208,6 +234,8 @@ grub_jpeg_decode_huff_table (struct grub_jpeg_data
> > *data)
> > +   while (data->file->offset + sizeof (count) + 1 <= next_marker)
> > +     {
> > +       id = grub_jpeg_get_byte (data);
> > ++      if (grub_errno != GRUB_ERR_NONE)
> > ++    return grub_errno;
> > +       ac = (id >> 4) & 1;
> > +       id &= 0xF;
> > +       if (id > 1)
> > +@@ -258,6 +286,8 @@ grub_jpeg_decode_quan_table (struct grub_jpeg_data
> > *data)
> > +
> > +   next_marker = data->file->offset;
> > +   next_marker += grub_jpeg_get_word (data);
> > ++  if (grub_errno != GRUB_ERR_NONE)
> > ++    return grub_errno;
> > +
> > +   if (next_marker > data->file->size)
> > +     {
> > +@@ -269,6 +299,8 @@ grub_jpeg_decode_quan_table (struct grub_jpeg_data
> > *data)
> > +      <= next_marker)
> > +     {
> > +       id = grub_jpeg_get_byte (data);
> > ++      if (grub_errno != GRUB_ERR_NONE)
> > ++        return grub_errno;
> > +       if (id >= 0x10)               /* Upper 4-bit is precision.  */
> > +     return grub_error (GRUB_ERR_BAD_FILE_TYPE,
> > +                        "jpeg: only 8-bit precision is supported");
> > +@@ -300,6 +332,9 @@ grub_jpeg_decode_sof (struct grub_jpeg_data *data)
> > +   next_marker = data->file->offset;
> > +   next_marker += grub_jpeg_get_word (data);
> > +
> > ++  if (grub_errno != GRUB_ERR_NONE)
> > ++    return grub_errno;
> > ++
> > +   if (grub_jpeg_get_byte (data) != 8)
> > +     return grub_error (GRUB_ERR_BAD_FILE_TYPE,
> > +                    "jpeg: only 8-bit precision is supported");
> > +@@ -325,6 +360,8 @@ grub_jpeg_decode_sof (struct grub_jpeg_data *data)
> > +     return grub_error (GRUB_ERR_BAD_FILE_TYPE, "jpeg: invalid index");
> > +
> > +       ss = grub_jpeg_get_byte (data);       /* Sampling factor.  */
> > ++      if (grub_errno != GRUB_ERR_NONE)
> > ++    return grub_errno;
> > +       if (!id)
> > +     {
> > +       grub_uint8_t vs, hs;
> > +@@ -504,7 +541,7 @@ grub_jpeg_idct_transform (jpeg_data_unit_t du)
> > +     }
> > + }
> > +
> > +-static void
> > ++static grub_err_t
> > + grub_jpeg_decode_du (struct grub_jpeg_data *data, int id,
> > jpeg_data_unit_t du)
> > + {
> > +   int h1, h2, qt;
> > +@@ -519,6 +556,9 @@ grub_jpeg_decode_du (struct grub_jpeg_data *data, int
> > id, jpeg_data_unit_t du)
> > +   data->dc_value[id] +=
> > +     grub_jpeg_get_number (data, grub_jpeg_get_huff_code (data, h1));
> > +
> > ++  if (grub_errno != GRUB_ERR_NONE)
> > ++    return grub_errno;
> > ++
> > +   du[0] = data->dc_value[id] * (int) data->quan_table[qt][0];
> > +   pos = 1;
> > +   while (pos < ARRAY_SIZE (data->quan_table[qt]))
> > +@@ -533,11 +573,13 @@ grub_jpeg_decode_du (struct grub_jpeg_data *data,
> > int id, jpeg_data_unit_t du)
> > +       num >>= 4;
> > +       pos += num;
> > +
> > ++      if (grub_errno != GRUB_ERR_NONE)
> > ++        return grub_errno;
> > ++
> > +       if (pos >= ARRAY_SIZE (jpeg_zigzag_order))
> > +     {
> > +-      grub_error (GRUB_ERR_BAD_FILE_TYPE,
> > +-                  "jpeg: invalid position in zigzag order!?");
> > +-      return;
> > ++      return grub_error (GRUB_ERR_BAD_FILE_TYPE,
> > ++                         "jpeg: invalid position in zigzag order!?");
> > +     }
> > +
> > +       du[jpeg_zigzag_order[pos]] = val * (int) data->quan_table[qt][pos];
> > +@@ -545,6 +587,7 @@ grub_jpeg_decode_du (struct grub_jpeg_data *data, int
> > id, jpeg_data_unit_t du)
> > +     }
> > +
> > +   grub_jpeg_idct_transform (du);
> > ++  return GRUB_ERR_NONE;
> > + }
> > +
> > + static void
> > +@@ -603,7 +646,8 @@ grub_jpeg_decode_sos (struct grub_jpeg_data *data)
> > +   data_offset += grub_jpeg_get_word (data);
> > +
> > +   cc = grub_jpeg_get_byte (data);
> > +-
> > ++  if (grub_errno != GRUB_ERR_NONE)
> > ++    return grub_errno;
> > +   if (cc != 3 && cc != 1)
> > +     return grub_error (GRUB_ERR_BAD_FILE_TYPE,
> > +                    "jpeg: component count must be 1 or 3");
> > +@@ -616,7 +660,8 @@ grub_jpeg_decode_sos (struct grub_jpeg_data *data)
> > +       id = grub_jpeg_get_byte (data) - 1;
> > +       if ((id < 0) || (id >= 3))
> > +     return grub_error (GRUB_ERR_BAD_FILE_TYPE, "jpeg: invalid index");
> > +-
> > ++      if (grub_errno != GRUB_ERR_NONE)
> > ++    return grub_errno;
> > +       ht = grub_jpeg_get_byte (data);
> > +       data->comp_index[id][1] = (ht >> 4);
> > +       data->comp_index[id][2] = (ht & 0xF) + 2;
> > +@@ -624,11 +669,14 @@ grub_jpeg_decode_sos (struct grub_jpeg_data *data)
> > +       if ((data->comp_index[id][1] < 0) || (data->comp_index[id][1] > 3)
> > ||
> > +       (data->comp_index[id][2] < 0) || (data->comp_index[id][2] > 3))
> > +     return grub_error (GRUB_ERR_BAD_FILE_TYPE, "jpeg: invalid hufftable
> > index");
> > ++      if (grub_errno != GRUB_ERR_NONE)
> > ++    return grub_errno;
> > +     }
> > +
> > +   grub_jpeg_get_byte (data);        /* Skip 3 unused bytes.  */
> > +   grub_jpeg_get_word (data);
> > +-
> > ++  if (grub_errno != GRUB_ERR_NONE)
> > ++    return grub_errno;
> > +   if (data->file->offset != data_offset)
> > +     return grub_error (GRUB_ERR_BAD_FILE_TYPE, "jpeg: extra byte in
> > sos");
> > +
> > +@@ -646,6 +694,7 @@ grub_jpeg_decode_data (struct grub_jpeg_data *data)
> > + {
> > +   unsigned c1, vb, hb, nr1, nc1;
> > +   int rst = data->dri;
> > ++  grub_err_t err = GRUB_ERR_NONE;
> > +
> > +   vb = 8 << data->log_vs;
> > +   hb = 8 << data->log_hs;
> > +@@ -666,17 +715,22 @@ grub_jpeg_decode_data (struct grub_jpeg_data *data)
> > +
> > +     for (r2 = 0; r2 < (1U << data->log_vs); r2++)
> > +       for (c2 = 0; c2 < (1U << data->log_hs); c2++)
> > +-        grub_jpeg_decode_du (data, 0, data->ydu[r2 * 2 + c2]);
> > ++            {
> > ++              err = grub_jpeg_decode_du (data, 0, data->ydu[r2 * 2 +
> > c2]);
> > ++              if (err != GRUB_ERR_NONE)
> > ++                return err;
> > ++            }
> > +
> > +     if (data->color_components >= 3)
> > +       {
> > +-        grub_jpeg_decode_du (data, 1, data->cbdu);
> > +-        grub_jpeg_decode_du (data, 2, data->crdu);
> > ++        err = grub_jpeg_decode_du (data, 1, data->cbdu);
> > ++        if (err != GRUB_ERR_NONE)
> > ++          return err;
> > ++        err = grub_jpeg_decode_du (data, 2, data->crdu);
> > ++        if (err != GRUB_ERR_NONE)
> > ++          return err;
> > +       }
> > +
> > +-    if (grub_errno)
> > +-      return grub_errno;
> > +-
> > +     nr2 = (data->r1 == nr1 - 1) ? (data->image_height - data->r1 * vb) :
> > vb;
> > +     nc2 = (c1 == nc1 - 1) ? (data->image_width - c1 * hb) : hb;
> > +
> > +--
> > +2.34.1
> > +
> > diff --git a/meta/recipes-bsp/grub/files/video-readers-jpeg-Refuse-to-
> > handle-multiple-start-o.patch b/meta/recipes-bsp/grub/files/video-readers-
> > jpeg-Refuse-to-handle-multiple-start-o.patch
> > new file mode 100644
> > index 0000000000..91ecaad98a
> > --- /dev/null
> > +++ b/meta/recipes-bsp/grub/files/video-readers-jpeg-Refuse-to-handle-
> > multiple-start-o.patch
> > @@ -0,0 +1,53 @@
> > +From 166a4d61448f74745afe1dac2f2cfb85d04909bf Mon Sep 17 00:00:00 2001
> > +From: Daniel Axtens <d...@axtens.net>
> > +Date: Mon, 28 Jun 2021 14:25:17 +1000
> > +Subject: [PATCH] video/readers/jpeg: Refuse to handle multiple start of
> > + streams
> > +
> > +An invalid file could contain multiple start of stream blocks, which
> > +would cause us to reallocate and leak our bitmap. Refuse to handle
> > +multiple start of streams.
> > +
> > +Additionally, fix a grub_error() call formatting.
> > +
> > +Signed-off-by: Daniel Axtens <d...@axtens.net>
> > +Reviewed-by: Daniel Kiper <daniel.ki...@oracle.com>
> > +
> > +Upstream-Status: Backport
> > +
> > +Reference to upstream patch:
> > +https://git.savannah.gnu.org/cgit/grub.git/commit/?id=166a4d61448f74745af
> > e1dac2f2cfb85d04909bf
> > +
> > +Signed-off-by: Yongxin Liu <yongxin....@windriver.com>
> > +---
> > + grub-core/video/readers/jpeg.c | 7 +++++--
> > + 1 file changed, 5 insertions(+), 2 deletions(-)
> > +
> > +diff --git a/grub-core/video/readers/jpeg.c b/grub-
> > core/video/readers/jpeg.c
> > +index 2284a6c06..579bbe8a4 100644
> > +--- a/grub-core/video/readers/jpeg.c
> > ++++ b/grub-core/video/readers/jpeg.c
> > +@@ -683,6 +683,9 @@ grub_jpeg_decode_sos (struct grub_jpeg_data *data)
> > +   if (data->file->offset != data_offset)
> > +     return grub_error (GRUB_ERR_BAD_FILE_TYPE, "jpeg: extra byte in
> > sos");
> > +
> > ++  if (*data->bitmap)
> > ++    return grub_error (GRUB_ERR_BAD_FILE_TYPE, "jpeg: too many start of
> > scan blocks");
> > ++
> > +   if (grub_video_bitmap_create (data->bitmap, data->image_width,
> > +                             data->image_height,
> > +                             GRUB_VIDEO_BLIT_FORMAT_RGB_888))
> > +@@ -705,8 +708,8 @@ grub_jpeg_decode_data (struct grub_jpeg_data *data)
> > +   nc1 = (data->image_width + hb - 1)  >> (3 + data->log_hs);
> > +
> > +   if (data->bitmap_ptr == NULL)
> > +-    return grub_error(GRUB_ERR_BAD_FILE_TYPE,
> > +-                  "jpeg: attempted to decode data before start of 
> > stream");
> > ++    return grub_error (GRUB_ERR_BAD_FILE_TYPE,
> > ++                   "jpeg: attempted to decode data before start of
> > stream");
> > +
> > +   for (; data->r1 < nr1 && (!data->dri || rst);
> > +        data->r1++, data->bitmap_ptr += (vb * data->image_width - hb *
> > nc1) * 3)
> > +--
> > +2.34.1
> > +
> > diff --git a/meta/recipes-bsp/grub/grub2.inc b/meta/recipes-
> > bsp/grub/grub2.inc
> > index 45852ab9b1..47ea561002 100644
> > --- a/meta/recipes-bsp/grub/grub2.inc
> > +++ b/meta/recipes-bsp/grub/grub2.inc
> > @@ -22,6 +22,16 @@ SRC_URI = "${GNU_MIRROR}/grub/grub-${PV}.tar.gz \
> >             file://0001-RISC-V-Restore-the-typcast-to-long.patch \
> >             file://CVE-2021-3981-grub-mkconfig-Restore-umask-for-the-
> > grub.cfg.patch \
> >             file://0001-configure.ac-Use-_zicsr_zifencei-extentions-on-
> > riscv.patch \
> > +           file://video-Remove-trailing-whitespaces.patch \
> > +           file://CVE-2021-3695-video-readers-png-Drop-greyscale-support-
> > to-fix-heap.patch \
> > +           file://CVE-2021-3696-video-readers-png-Avoid-heap-OOB-R-W-
> > inserting-huff.patch \
> > +           file://video-readers-jpeg-Abort-sooner-if-a-read-operation-
> > .patch \
> > +           file://video-readers-jpeg-Refuse-to-handle-multiple-start-
> > o.patch \
> > +           file://CVE-2021-3697-video-readers-jpeg-Block-int-underflow-
> > wild-pointer.patch \
> > +           file://CVE-2022-28733-net-ip-Do-IP-fragment-maths-safely.patch
> > \
> > +           file://CVE-2022-28734-net-http-Fix-OOB-write-for-split-http-
> > headers.patch \
> > +           file://CVE-2022-28734-net-http-Error-out-on-headers-with-LF-
> > without-CR.patch \
> > +           file://CVE-2022-28735-kern-efi-sb-Reject-non-kernel-files-in-
> > the-shim_lock.patch \
> >  "
> >
> >  SRC_URI[sha256sum] =
> > "23b64b4c741569f9426ed2e3d0e6780796fca081bee4c99f62aa3f53ae803f5f"
> > --
> > 2.34.1
>
>
> 
>
-=-=-=-=-=-=-=-=-=-=-=-
Links: You receive all messages sent to this group.
View/Reply Online (#169483): 
https://lists.openembedded.org/g/openembedded-core/message/169483
Mute This Topic: https://lists.openembedded.org/mt/92828276/21656
Group Owner: openembedded-core+ow...@lists.openembedded.org
Unsubscribe: https://lists.openembedded.org/g/openembedded-core/unsub 
[arch...@mail-archive.com]
-=-=-=-=-=-=-=-=-=-=-=-

Reply via email to