5d94219
# HG changeset patch
5d94219
# Parent b7eb1ce0237d6125b75bc8ff1cb3afc328d6e78c
5d94219
# User Steve Singer <steve@ssinger.info>
5d94219
Bug 1005535 - Get skia GPU building on big endian.
5d94219
5d94219
diff --git a/configure.in b/configure.in
5d94219
--- a/configure.in
5d94219
+++ b/configure.in
5d94219
@@ -8231,21 +8231,21 @@ dnl Skia
5d94219
 dnl ========================================================
5d94219
 if test "$MOZ_ENABLE_SKIA"; then
5d94219
   AC_DEFINE(MOZ_ENABLE_SKIA)
5d94219
   AC_DEFINE(USE_SKIA)
5d94219
   if test "${MOZ_WIDGET_TOOLKIT}" = "android" -o x"$MOZ_WIDGET_TOOLKIT" = x"gonk"; then
5d94219
     AC_DEFINE(SK_BUILD_FOR_ANDROID_NDK)
5d94219
   fi
5d94219
 
5d94219
-  if test "${CPU_ARCH}" != "ppc" -a "${CPU_ARCH}" != "ppc64" -a "${CPU_ARCH}" != "sparc" -a -z "$MOZ_DISABLE_SKIA_GPU" ; then
5d94219
+#  if test "${CPU_ARCH}" != "ppc" -a "${CPU_ARCH}" != "ppc64" -a "${CPU_ARCH}" != "sparc" -a -z "$MOZ_DISABLE_SKIA_GPU" ; then
5d94219
     MOZ_ENABLE_SKIA_GPU=1
5d94219
     AC_DEFINE(USE_SKIA_GPU)
5d94219
     AC_SUBST(MOZ_ENABLE_SKIA_GPU)
5d94219
-  fi
5d94219
+#  fi
5d94219
 fi
5d94219
 AC_SUBST(MOZ_ENABLE_SKIA)
5d94219
 
5d94219
 dnl ========================================================
5d94219
 dnl disable xul
5d94219
 dnl ========================================================
5d94219
 MOZ_ARG_DISABLE_BOOL(xul,
5d94219
 [  --disable-xul           Disable XUL],
5d94219
diff --git a/gfx/skia/generate_mozbuild.py b/gfx/skia/generate_mozbuild.py
5d94219
--- a/gfx/skia/generate_mozbuild.py
5d94219
+++ b/gfx/skia/generate_mozbuild.py
5d94219
@@ -236,17 +236,17 @@ def generate_separated_sources(platform_
5d94219
         return True
5d94219
 
5d94219
     return False
5d94219
 
5d94219
   separated = {
5d94219
     'common': {
5d94219
       #'trunk/src/effects/gradients/SkGradientTileProc.cpp',
5d94219
       'trunk/src/gpu/gl/GrGLCreateNativeInterface_none.cpp',
5d94219
-      'trunk/src/ports/SkDiscardableMemory_none.cpp',
5d94219
+      #'trunk/src/ports/SkDiscardableMemory_none.cpp',
5d94219
       'trunk/src/ports/SkImageDecoder_empty.cpp',
5d94219
       'trunk/src/ports/SkMemory_mozalloc.cpp',
5d94219
       # 'trunk/src/images/SkImages.cpp',
5d94219
       # 'trunk/src/images/SkImageRef.cpp',
5d94219
       # 'trunk/src/images/SkImageRef_GlobalPool.cpp',
5d94219
       # 'trunk/src/images/SkImageRefPool.cpp',
5d94219
       # 'trunk/src/images/SkImageDecoder.cpp',
5d94219
       # 'trunk/src/images/SkImageDecoder_Factory.cpp',
5d94219
diff --git a/gfx/skia/moz.build b/gfx/skia/moz.build
5d94219
--- a/gfx/skia/moz.build
5d94219
+++ b/gfx/skia/moz.build
5d94219
@@ -847,17 +847,16 @@ else:
5d94219
         'trunk/src/opts/SkBitmapProcState_opts_none.cpp',
5d94219
         'trunk/src/opts/SkBlitMask_opts_none.cpp',
5d94219
         'trunk/src/opts/SkBlitRow_opts_none.cpp',
5d94219
         'trunk/src/opts/SkBlurImage_opts_none.cpp',
5d94219
         'trunk/src/opts/SkMorphology_opts_none.cpp',
5d94219
         'trunk/src/opts/SkTextureCompression_opts_none.cpp',
5d94219
         'trunk/src/opts/SkUtils_opts_none.cpp',
5d94219
         'trunk/src/opts/SkXfermode_opts_none.cpp',
5d94219
-        'trunk/src/ports/SkDiscardableMemory_none.cpp',
5d94219
     ]
5d94219
 
5d94219
 
5d94219
 # can we find a better way of dealing with asm sources?
5d94219
 
5d94219
 # left out of UNIFIED_SOURCES for now; that's not C++ anyway, nothing else to unify it with
5d94219
 if not CONFIG['INTEL_ARCHITECTURE'] and CONFIG['CPU_ARCH'] == 'arm' and CONFIG['GNU_CC']:
5d94219
     SOURCES += [
5d94219
diff --git a/gfx/skia/trunk/include/config/SkUserConfig.h b/gfx/skia/trunk/include/config/SkUserConfig.h
5d94219
--- a/gfx/skia/trunk/include/config/SkUserConfig.h
5d94219
+++ b/gfx/skia/trunk/include/config/SkUserConfig.h
5d94219
@@ -192,16 +192,17 @@
5d94219
 
5d94219
 #if defined(SK_CPU_ARM32) || defined(SK_CPU_ARM64)
5d94219
 #  define SK_BARRIERS_PLATFORM_H "skia/SkBarriers_arm.h"
5d94219
 #else
5d94219
 #  define SK_BARRIERS_PLATFORM_H "skia/SkBarriers_x86.h"
5d94219
 #endif
5d94219
 
5d94219
 // On all platforms we have this byte order
5d94219
+
5d94219
 #define SK_A32_SHIFT 24
5d94219
 #define SK_R32_SHIFT 16
5d94219
 #define SK_G32_SHIFT 8
5d94219
 #define SK_B32_SHIFT 0
5d94219
 
5d94219
 #define SK_ALLOW_STATIC_GLOBAL_INITIALIZERS 0
5d94219
 
5d94219
 #define SK_SUPPORT_LEGACY_GETDEVICE
5d94219
diff --git a/gfx/skia/trunk/include/core/SkColorPriv.h b/gfx/skia/trunk/include/core/SkColorPriv.h
5d94219
--- a/gfx/skia/trunk/include/core/SkColorPriv.h
5d94219
+++ b/gfx/skia/trunk/include/core/SkColorPriv.h
5d94219
@@ -27,37 +27,27 @@
5d94219
  *  For easier compatibility with Skia's GPU backend, we further restrict these
5d94219
  *  to either (in memory-byte-order) RGBA or BGRA. Note that this "order" does
5d94219
  *  not directly correspond to the same shift-order, since we have to take endianess
5d94219
  *  into account.
5d94219
  *
5d94219
  *  Here we enforce this constraint.
5d94219
  */
5d94219
 
5d94219
-#ifdef SK_CPU_BENDIAN
5d94219
-    #define SK_RGBA_R32_SHIFT   24
5d94219
-    #define SK_RGBA_G32_SHIFT   16
5d94219
-    #define SK_RGBA_B32_SHIFT   8
5d94219
-    #define SK_RGBA_A32_SHIFT   0
5d94219
 
5d94219
-    #define SK_BGRA_B32_SHIFT   24
5d94219
-    #define SK_BGRA_G32_SHIFT   16
5d94219
-    #define SK_BGRA_R32_SHIFT   8
5d94219
-    #define SK_BGRA_A32_SHIFT   0
5d94219
-#else
5d94219
     #define SK_RGBA_R32_SHIFT   0
5d94219
     #define SK_RGBA_G32_SHIFT   8
5d94219
     #define SK_RGBA_B32_SHIFT   16
5d94219
     #define SK_RGBA_A32_SHIFT   24
5d94219
 
5d94219
     #define SK_BGRA_B32_SHIFT   0
5d94219
     #define SK_BGRA_G32_SHIFT   8
5d94219
     #define SK_BGRA_R32_SHIFT   16
5d94219
     #define SK_BGRA_A32_SHIFT   24
5d94219
-#endif
5d94219
+
5d94219
 
5d94219
 #if defined(SK_PMCOLOR_IS_RGBA) && defined(SK_PMCOLOR_IS_BGRA)
5d94219
     #error "can't define PMCOLOR to be RGBA and BGRA"
5d94219
 #endif
5d94219
 
5d94219
 #define LOCAL_PMCOLOR_SHIFTS_EQUIVALENT_TO_RGBA  \
5d94219
     (SK_A32_SHIFT == SK_RGBA_A32_SHIFT &&    \
5d94219
      SK_R32_SHIFT == SK_RGBA_R32_SHIFT &&    \
5d94219
diff --git a/gfx/skia/trunk/include/core/SkImageInfo.h b/gfx/skia/trunk/include/core/SkImageInfo.h
5d94219
--- a/gfx/skia/trunk/include/core/SkImageInfo.h
5d94219
+++ b/gfx/skia/trunk/include/core/SkImageInfo.h
5d94219
@@ -83,19 +83,20 @@ enum SkColorType {
5d94219
 
5d94219
     kLastEnum_SkColorType = kIndex_8_SkColorType,
5d94219
 
5d94219
 #if SK_PMCOLOR_BYTE_ORDER(B,G,R,A)
5d94219
     kN32_SkColorType = kBGRA_8888_SkColorType,
5d94219
 #elif SK_PMCOLOR_BYTE_ORDER(R,G,B,A)
5d94219
     kN32_SkColorType = kRGBA_8888_SkColorType,
5d94219
 #else
5d94219
-#error "SK_*32_SHFIT values must correspond to BGRA or RGBA byte order"
5d94219
+     kN32_SkColorType = kBGRA_8888_SkColorType
5d94219
 #endif
5d94219
 
5d94219
+
5d94219
 #ifdef SK_SUPPORT_LEGACY_N32_NAME
5d94219
     kPMColor_SkColorType = kN32_SkColorType
5d94219
 #endif
5d94219
 };
5d94219
 
5d94219
 static int SkColorTypeBytesPerPixel(SkColorType ct) {
5d94219
     static const uint8_t gSize[] = {
5d94219
         0,  // Unknown
5d94219
diff --git a/gfx/skia/trunk/include/gpu/GrTypes.h b/gfx/skia/trunk/include/gpu/GrTypes.h
5d94219
--- a/gfx/skia/trunk/include/gpu/GrTypes.h
5d94219
+++ b/gfx/skia/trunk/include/gpu/GrTypes.h
5d94219
@@ -304,25 +304,23 @@ enum GrPixelConfig {
5d94219
      * Byte order is r, g, b, a.  This color format is 32 bits per channel
5d94219
      */
5d94219
     kRGBA_float_GrPixelConfig,
5d94219
     kLast_GrPixelConfig = kRGBA_float_GrPixelConfig
5d94219
 };
5d94219
 static const int kGrPixelConfigCnt = kLast_GrPixelConfig + 1;
5d94219
 
5d94219
 // Aliases for pixel configs that match skia's byte order.
5d94219
-#ifndef SK_CPU_LENDIAN
5d94219
-    #error "Skia gpu currently assumes little endian"
5d94219
-#endif
5d94219
+
5d94219
 #if SK_PMCOLOR_BYTE_ORDER(B,G,R,A)
5d94219
     static const GrPixelConfig kSkia8888_GrPixelConfig = kBGRA_8888_GrPixelConfig;
5d94219
 #elif SK_PMCOLOR_BYTE_ORDER(R,G,B,A)
5d94219
     static const GrPixelConfig kSkia8888_GrPixelConfig = kRGBA_8888_GrPixelConfig;
5d94219
 #else
5d94219
-    #error "SK_*32_SHIFT values must correspond to GL_BGRA or GL_RGBA format."
5d94219
+    static const GrPixelConfig kSkia8888_GrPixelConfig = kBGRA_8888_GrPixelConfig;
5d94219
 #endif
5d94219
 
5d94219
 // Returns true if the pixel config is a GPU-specific compressed format
5d94219
 // representation.
5d94219
 static inline bool GrPixelConfigIsCompressed(GrPixelConfig config) {
5d94219
     switch (config) {
5d94219
         case kETC1_GrPixelConfig:
5d94219
         case kLATC_GrPixelConfig: