-
+spec2def(kernel32.dll kernel32.spec)
add_definitions(-D_KERNEL32_)
thread/fls.c
thread/thread.c
thread/tls.c
- thread/${ARCH}/fiber.S
- thread/${ARCH}/thread.S
kernel32.rc
- kernel32_stubs.c)
+ kernel32_stubs.c
+ ${CMAKE_CURRENT_BINARY_DIR}/kernel32.def)
+
+if(ARCH MATCHES i386)
+list(APPEND SOURCE
+ thread/i386/fiber.S
+ thread/i386/thread.S
+)
+elseif(ARCH MATCHES amd64)
+list(APPEND SOURCE
+ thread/amd64/fiber.S
+ thread/amd64/thread.S)
+endif(ARCH MATCHES i386)
add_library(kernel32 SHARED
- ${SOURCE}
- ${CMAKE_CURRENT_BINARY_DIR}/kernel32_k32.h.gch)
+ ${CMAKE_CURRENT_BINARY_DIR}/kernel32_k32.h.gch
+ ${SOURCE})
-set_target_properties(kernel32 PROPERTIES LINK_FLAGS "-Wl,-entry,_DllMain@12")
+set_module_type(kernel32 win32dll)
-target_link_libraries(kernel32 ${CMAKE_CURRENT_SOURCE_DIR}/kernel32.def
- pseh
- -lntdll)
+target_link_libraries(kernel32 ${PSEH_LIB})
+add_importlibs(kernel32 ntdll)
add_pch(kernel32 ${CMAKE_CURRENT_SOURCE_DIR}/k32.h ${SOURCE})
-add_dependencies(kernel32 errcodes version)
+add_dependencies(kernel32 errcodes asm)
+add_cab_target(kernel32 1)
+add_importlib_target(kernel32.spec)