[lld] r308935 - Fix ObjCPass on big-endian host

Tom Stellard via llvm-commits llvm-commits at lists.llvm.org
Mon Jul 24 16:18:35 PDT 2017


Is this OK to merge to the 5.0 branch?

-Tom

On 07/24/2017 07:13 PM, Tom Stellard via llvm-commits wrote:
> Author: tstellar
> Date: Mon Jul 24 16:13:31 2017
> New Revision: 308935
> 
> URL: http://llvm.org/viewvc/llvm-project?rev=308935&view=rev
> Log:
> Fix ObjCPass on big-endian host
> 
> Summary:
> This fixes test/mach-o/objc-image-info-pass-output.yaml on
> big-endian hosts.
> 
> Reviewers: lhames, kledzik, ruiu
> 
> Reviewed By: ruiu
> 
> Subscribers: llvm-commits
> 
> Differential Revision: https://reviews.llvm.org/D35052
> 
> Modified:
>     lld/trunk/lib/ReaderWriter/MachO/ObjCPass.cpp
> 
> Modified: lld/trunk/lib/ReaderWriter/MachO/ObjCPass.cpp
> URL: http://llvm.org/viewvc/llvm-project/lld/trunk/lib/ReaderWriter/MachO/ObjCPass.cpp?rev=308935&r1=308934&r2=308935&view=diff
> ==============================================================================
> --- lld/trunk/lib/ReaderWriter/MachO/ObjCPass.cpp (original)
> +++ lld/trunk/lib/ReaderWriter/MachO/ObjCPass.cpp Mon Jul 24 16:13:31 2017
> @@ -11,6 +11,7 @@
>  
>  #include "ArchHandler.h"
>  #include "File.h"
> +#include "MachONormalizedFileBinaryUtils.h"
>  #include "MachOPasses.h"
>  #include "lld/Core/DefinedAtom.h"
>  #include "lld/Core/File.h"
> @@ -29,7 +30,7 @@ namespace mach_o {
>  ///
>  class ObjCImageInfoAtom : public SimpleDefinedAtom {
>  public:
> -  ObjCImageInfoAtom(const File &file,
> +  ObjCImageInfoAtom(const File &file, bool isBig,
>                      MachOLinkingContext::ObjCConstraint objCConstraint,
>                      uint32_t swiftVersion)
>        : SimpleDefinedAtom(file) {
> @@ -54,6 +55,8 @@ public:
>      }
>  
>      Data.info.flags |= (swiftVersion << 8);
> +
> +    normalized::write32(Data.bytes + 4, Data.info.flags, isBig);
>    }
>  
>    ~ObjCImageInfoAtom() override = default;
> @@ -109,7 +112,8 @@ public:
>  private:
>  
>    const DefinedAtom* getImageInfo() {
> -    return new (_file.allocator()) ObjCImageInfoAtom(_file,
> +    bool IsBig = MachOLinkingContext::isBigEndian(_ctx.arch());
> +    return new (_file.allocator()) ObjCImageInfoAtom(_file, IsBig,
>                                                       _ctx.objcConstraint(),
>                                                       _ctx.swiftVersion());
>    }
> 
> 
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at lists.llvm.org
> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits
> 



More information about the llvm-commits mailing list