mozilla-bmo1626236.patch
author Wolfgang Rosenauer <wr@rosenauer.org>
Thu, 23 Jul 2020 16:00:58 +0200
branchfirefox78
changeset 1138 4ac678bd2a26
parent 1136 d068eb84b4d3
permissions -rw-r--r--
78.0.2
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1136
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     1
# HG changeset patch
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     2
# User msirringhaus@suse.de
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     3
# Date 1582805876 -3600
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     4
#      Thu Feb 27 13:17:56 2020 +0100
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     5
# Node ID cc3d09abea31068e57f1ab918782f9f86fc6a158
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     6
# Parent  9cd90914846f667f18babc491a74c164ae5d6e9f
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     7
imported patch decoder_workaround.patch
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     8
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     9
diff -r 9cd90914846f image/decoders/nsGIFDecoder2.cpp
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    10
--- a/image/decoders/nsGIFDecoder2.cpp	Thu Feb 27 12:57:14 2020 +0100
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    11
+++ b/image/decoders/nsGIFDecoder2.cpp	Fri Mar 27 13:06:18 2020 +0100
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    12
@@ -422,6 +422,9 @@
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    13
   MOZ_ASSERT(mSwizzleFn);
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    14
   uint8_t* data = reinterpret_cast<uint8_t*>(aColormap);
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    15
   mSwizzleFn(data, data, aColors);
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    16
+#if MOZ_BIG_ENDIAN()
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    17
+  SwizzleRow(SurfaceFormat::A8R8G8B8, SurfaceFormat::B8G8R8A8)(data, data, aColors);
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    18
+#endif
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    19
 }
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    20
 
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    21
 LexerResult nsGIFDecoder2::DoDecode(SourceBufferIterator& aIterator,
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    22
diff -r 9cd90914846f image/decoders/nsJPEGDecoder.cpp
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    23
--- a/image/decoders/nsJPEGDecoder.cpp	Thu Feb 27 12:57:14 2020 +0100
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    24
+++ b/image/decoders/nsJPEGDecoder.cpp	Fri Mar 27 13:06:18 2020 +0100
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    25
@@ -263,6 +263,9 @@
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    26
         case JCS_YCbCr:
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    27
           // By default, we will output directly to BGRA. If we need to apply
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    28
           // special color transforms, this may change.
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    29
+#if MOZ_BIG_ENDIAN()
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    30
+          mInfo.out_color_space = MOZ_JCS_EXT_NATIVE_ENDIAN_XRGB;
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    31
+#else
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    32
           switch (SurfaceFormat::OS_RGBX) {
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    33
             case SurfaceFormat::B8G8R8X8:
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    34
               mInfo.out_color_space = JCS_EXT_BGRX;
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    35
@@ -277,6 +280,7 @@
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    36
               mState = JPEG_ERROR;
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    37
               return Transition::TerminateFailure();
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    38
           }
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    39
+#endif
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    40
           break;
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    41
         case JCS_CMYK:
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    42
         case JCS_YCCK:
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    43
diff -r 9cd90914846f image/decoders/nsPNGDecoder.cpp
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    44
--- a/image/decoders/nsPNGDecoder.cpp	Thu Feb 27 12:57:14 2020 +0100
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    45
+++ b/image/decoders/nsPNGDecoder.cpp	Fri Mar 27 13:06:18 2020 +0100
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    46
@@ -361,7 +361,7 @@
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    47
                                    IResumable* aOnResume) {
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    48
   MOZ_ASSERT(!HasError(), "Shouldn't call DoDecode after error!");
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    49
 
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    50
-  return mLexer.Lex(aIterator, aOnResume,
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    51
+  LexerResult res = mLexer.Lex(aIterator, aOnResume,
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    52
                     [=](State aState, const char* aData, size_t aLength) {
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    53
                       switch (aState) {
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    54
                         case State::PNG_DATA:
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    55
@@ -371,6 +371,14 @@
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    56
                       }
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    57
                       MOZ_CRASH("Unknown State");
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    58
                     });
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    59
+
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    60
+#if MOZ_BIG_ENDIAN()
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    61
+  if(res.is<TerminalState>() && res.as<TerminalState>() == TerminalState::SUCCESS) {
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    62
+      NativeEndian::swapToLittleEndianInPlace<uint32_t>((uint32_t*)(mImageData), mImageDataLength / 4);
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    63
+  }
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    64
+#endif
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    65
+
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    66
+  return res;
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    67
 }
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    68
 
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    69
 LexerTransition<nsPNGDecoder::State> nsPNGDecoder::ReadPNGData(
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    70
diff -r 9cd90914846f image/decoders/nsWebPDecoder.cpp
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    71
--- a/image/decoders/nsWebPDecoder.cpp	Thu Feb 27 12:57:14 2020 +0100
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    72
+++ b/image/decoders/nsWebPDecoder.cpp	Fri Mar 27 13:06:18 2020 +0100
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    73
@@ -237,7 +237,12 @@
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    74
   // WebP doesn't guarantee that the alpha generated matches the hint in the
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    75
   // header, so we always need to claim the input is BGRA. If the output is
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    76
   // BGRX, swizzling will mask off the alpha channel.
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    77
+#if MOZ_BIG_ENDIAN()
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    78
+  mBuffer.colorspace = MODE_ARGB;
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    79
+  SurfaceFormat inFormat = mFormat;
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    80
+#else
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    81
   SurfaceFormat inFormat = SurfaceFormat::OS_RGBA;
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    82
+#endif
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    83
 
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    84
   SurfacePipeFlags pipeFlags = SurfacePipeFlags();
d068eb84b4d3 sync SLE specifics
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    85
   if (mFormat == SurfaceFormat::OS_RGBA &&