Skip to content

Commit c9a19c2

Browse files
Fix UNIX CMake (and OS X autotools) builds for Heimdall CLI
1 parent b9e7227 commit c9a19c2

File tree

3 files changed

+36
-16
lines changed

3 files changed

+36
-16
lines changed

cmake/LargeFiles.cmake

Lines changed: 32 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -2,21 +2,31 @@ macro(test_large_files VARIABLE USE_64_SUFFIX)
22
if(NOT DEFINED ${VARIABLE})
33
message(STATUS "Checking if large (64-bit) file support is available...")
44

5-
if(${USE_64_SUFFIX})
5+
if(USE_64_SUFFIX)
66
set(SUFFIX_64 "64")
7-
else(${USE_64_SUFFIX})
7+
else(USE_64_SUFFIX)
88
set(SUFFIX_64 "")
9-
endif(${USE_64_SUFFIX})
9+
endif(USE_64_SUFFIX)
1010

1111
# First try without any macros defined
1212
try_compile(LARGE_FILES_SUPPORTED "${CMAKE_BINARY_DIR}"
13-
"${CMAKE_MODULE_PATH}/LargeFiles${SUFFIX_64}.c")
13+
"${CMAKE_MODULE_PATH}/LargeFiles${SUFFIX_64}.c"
14+
OUTPUT_VARIABLE TRY_LARGE_FILES_OUTPUT)
15+
16+
if(VERBOSE_LARGE_FILES)
17+
message(STATUS "Large file output (no special flags):\n${TRY_LARGE_FILES_OUTPUT}")
18+
endif(VERBOSE_LARGE_FILES)
1419

1520
if(NOT LARGE_FILES_SUPPORTED)
1621
# Try with C macro _FILE_OFFSET_BITS=64
1722
try_compile(LARGE_FILES_SUPPORTED "${CMAKE_BINARY_DIR}"
1823
"${CMAKE_MODULE_PATH}/LargeFiles${SUFFIX_64}.c"
19-
COMPILE_DEFINITIONS "-D_FILE_OFFSET_BITS=64")
24+
COMPILE_DEFINITIONS "-D_FILE_OFFSET_BITS=64"
25+
OUTPUT_VARIABLE TRY_LARGE_FILES_OUTPUT)
26+
27+
if(VERBOSE_LARGE_FILES)
28+
message(STATUS "Large file output (_FILE_OFFSET_BITS=64):\n${TRY_LARGE_FILES_OUTPUT}")
29+
endif(VERBOSE_LARGE_FILES)
2030

2131
if(LARGE_FILES_SUPPORTED)
2232
set(_FILE_OFFSET_BITS=64 CACHE INTERNAL "C macro _FILE_OFFSET_BITS=64 is required for 64-bit file support")
@@ -28,22 +38,32 @@ macro(test_large_files VARIABLE USE_64_SUFFIX)
2838

2939
try_compile(LARGE_FILES_SUPPORTED "${CMAKE_BINARY_DIR}"
3040
"${CMAKE_MODULE_PATH}/LargeFiles${SUFFIX_64}.c"
31-
COMPILE_DEFINITIONS "-D_LARGEFILE_SOURCE${SUFFIX_64}")
41+
COMPILE_DEFINITIONS "-D_LARGEFILE_SOURCE${SUFFIX_64}"
42+
OUTPUT_VARIABLE TRY_LARGE_FILES_OUTPUT)
43+
44+
if(VERBOSE_LARGE_FILES)
45+
message(STATUS "Large file output (_LARGEFILE_SOURCE${SUFFIX_64}):\n${TRY_LARGE_FILES_OUTPUT}")
46+
endif(VERBOSE_LARGE_FILES)
3247

3348
if(LARGE_FILES_SUPPORTED)
34-
set(_LARGEFILE_SOURCE${SUFFIX_64}=1 CACHE INTERNAL "C macro _LARGEFILE_SOURCE${SUFFIX_64} is required for 64-bit file support")
49+
set(_LARGEFILE${SUFFIX_64}_SOURCE=1 CACHE INTERNAL "C macro _LARGEFILE${SUFFIX_64}_SOURCE is required for 64-bit file support")
3550
endif(LARGE_FILES_SUPPORTED)
3651
endif(NOT LARGE_FILES_SUPPORTED)
3752

3853
if(NOT LARGE_FILES_SUPPORTED)
3954
# Try with both C macro _FILE_OFFSET_BITS=64 and _LARGEFILE_SOURCE
4055
try_compile(LARGE_FILES_SUPPORTED "${CMAKE_BINARY_DIR}"
4156
"${CMAKE_MODULE_PATH}/LargeFiles${SUFFIX_64}.c"
42-
COMPILE_DEFINITIONS "-D_FILE_OFFSET_BITS=64" "-D_LARGEFILE_SOURCE${SUFFIX_64}")
57+
COMPILE_DEFINITIONS "-D_FILE_OFFSET_BITS=64" "-D_LARGEFILE${SUFFIX_64}_SOURCE"
58+
OUTPUT_VARIABLE TRY_LARGE_FILES_OUTPUT)
59+
60+
if(VERBOSE_LARGE_FILES)
61+
message(STATUS "Large file output (_FILE_OFFSET_BITS=64 and _LARGEFILE_SOURCE${SUFFIX_64}):\n${TRY_LARGE_FILES_OUTPUT}")
62+
endif(VERBOSE_LARGE_FILES)
4363

4464
if(LARGE_FILES_SUPPORTED)
4565
set(_FILE_OFFSET_BITS=64 CACHE INTERNAL "C macro _FILE_OFFSET_BITS=64 is required for 64-bit file support")
46-
set(_LARGEFILE_SOURCE${SUFFIX_64}=1 CACHE INTERNAL "C macro _LARGEFILE_SOURCE${SUFFIX_64} is required for 64-bit file support")
66+
set(_LARGEFILE${SUFFIX_64}_SOURCE=1 CACHE INTERNAL "C macro _LARGEFILE${SUFFIX_64}_SOURCE is required for 64-bit file support")
4767
endif(LARGE_FILES_SUPPORTED)
4868
endif(NOT LARGE_FILES_SUPPORTED)
4969

@@ -77,10 +97,10 @@ macro(use_large_files TARGET USE_64_SUFFIX)
7797
APPEND PROPERTY COMPILE_DEFINITIONS "-D_LARGEFILE_SOURCE")
7898
endif(DEFINED _LARGEFILE_SOURCE)
7999

80-
if(DEFINED _LARGEFILE_SOURCE64)
100+
if(DEFINED _LARGEFILE64_SOURCE)
81101
set_property(TARGET ${TARGET}
82-
APPEND PROPERTY COMPILE_DEFINITIONS "-D_LARGEFILE_SOURCE64")
83-
endif(DEFINED _LARGEFILE_SOURCE64)
102+
APPEND PROPERTY COMPILE_DEFINITIONS "-D_LARGEFILE64_SOURCE")
103+
endif(DEFINED _LARGEFILE64_SOURCE)
84104
else(USING_LARGE_FILES)
85105
message(FATAL_ERROR "Large file support not available")
86106
endif(USING_LARGE_FILES)

heimdall/CMakeLists.txt

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -77,7 +77,7 @@ set(HEIMDALL_SOURCE_FILES
7777
source/VersionAction.h)
7878

7979
include(LargeFiles)
80-
use_large_files(heimdall YES)
80+
use_large_files(heimdall false)
8181
add_executable(heimdall ${HEIMDALL_SOURCE_FILES})
8282

8383
target_link_libraries(heimdall PRIVATE pit)
@@ -86,5 +86,5 @@ LINK_DIRECTORIES(../libusb-1.0/lib/mingw)
8686
if(WIN32)
8787
target_link_libraries(heimdall PRIVATE ${CMAKE_SOURCE_DIR}/libusb-1.0/lib/mingw/libusb-1.0.a)
8888
else(WIN32)
89-
target_link_libraries(heimdalll PRIVATE usb-1.0)
89+
target_link_libraries(heimdall PRIVATE usb-1.0)
9090
endif(WIN32)

heimdall/source/Heimdall.h

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -48,8 +48,8 @@
4848

4949
#define FileOpen(FILE, MODE) fopen(FILE, MODE)
5050
#define FileClose(FILE) fclose(FILE)
51-
#define FileSeek(FILE, OFFSET, ORIGIN) fseeko64(FILE, OFFSET, ORIGIN)
52-
#define FileTell(FILE) ftello64(FILE)
51+
#define FileSeek(FILE, OFFSET, ORIGIN) fseeko(FILE, OFFSET, ORIGIN)
52+
#define FileTell(FILE) ftello(FILE)
5353
#define FileRewind(FILE) rewind(FILE)
5454

5555
#endif

0 commit comments

Comments
 (0)