提交 a006fef7 编写于 作者: A Andy Polyakov

Improve WINCE support.

Submitted by: Pierre Delaage
上级 0e5cf7bc
...@@ -118,7 +118,7 @@ ...@@ -118,7 +118,7 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#if !defined(OPENSSL_SYSNAME_WIN32) && !defined(NETWARE_CLIB) #if !defined(OPENSSL_SYSNAME_WIN32) && !defined(OPENSSL_SYSNAME_WINCE) && !defined(NETWARE_CLIB)
#include <strings.h> #include <strings.h>
#endif #endif
#include <sys/types.h> #include <sys/types.h>
......
...@@ -202,7 +202,7 @@ extern BIO *bio_err; ...@@ -202,7 +202,7 @@ extern BIO *bio_err;
# endif # endif
#endif #endif
#ifdef OPENSSL_SYSNAME_WIN32 #if defined(OPENSSL_SYSNAME_WIN32) || defined(OPENSSL_SYSNAME_WINCE)
# define openssl_fdset(a,b) FD_SET((unsigned int)a, b) # define openssl_fdset(a,b) FD_SET((unsigned int)a, b)
#else #else
# define openssl_fdset(a,b) FD_SET(a, b) # define openssl_fdset(a,b) FD_SET(a, b)
......
...@@ -66,7 +66,7 @@ ...@@ -66,7 +66,7 @@
#include <openssl/bio.h> #include <openssl/bio.h>
#ifndef OPENSSL_NO_DGRAM #ifndef OPENSSL_NO_DGRAM
#if defined(OPENSSL_SYS_WIN32) || defined(OPENSSL_SYS_VMS) #if defined(OPENSSL_SYS_VMS)
#include <sys/timeb.h> #include <sys/timeb.h>
#endif #endif
...@@ -1895,7 +1895,7 @@ int BIO_dgram_non_fatal_error(int err) ...@@ -1895,7 +1895,7 @@ int BIO_dgram_non_fatal_error(int err)
static void get_current_time(struct timeval *t) static void get_current_time(struct timeval *t)
{ {
#if defined(OPENSSL_SYS_WIN32) || defined(OPENSSL_SYS_WINCE) #if defined(_WIN32)
SYSTEMTIME st; SYSTEMTIME st;
union { unsigned __int64 ul; FILETIME ft; } now; union { unsigned __int64 ul; FILETIME ft; } now;
......
...@@ -63,9 +63,25 @@ ...@@ -63,9 +63,25 @@
#if defined(OPENSSL_NO_POSIX_IO) #if defined(OPENSSL_NO_POSIX_IO)
/* /*
* One can argue that one should implement dummy placeholder for * Dummy placeholder for BIO_s_fd...
* BIO_s_fd here...
*/ */
BIO *BIO_new_fd(int fd,int close_flag)
{
return NULL;
}
int BIO_fd_non_fatal_error(int err)
{
return 0;
}
int BIO_fd_should_retry(int i)
{
return 0;
}
BIO_METHOD *BIO_s_fd(void)
{
return NULL;
}
#else #else
/* /*
* As for unconditional usage of "UPLINK" interface in this module. * As for unconditional usage of "UPLINK" interface in this module.
......
...@@ -387,7 +387,9 @@ void OpenSSLDie(const char *file,int line,const char *assertion) ...@@ -387,7 +387,9 @@ void OpenSSLDie(const char *file,int line,const char *assertion)
abort(); abort();
#else #else
/* Win32 abort() customarily shows a dialog, but we just did that... */ /* Win32 abort() customarily shows a dialog, but we just did that... */
#if !defined(_WIN32_WCE)
raise(SIGABRT); raise(SIGABRT);
#endif
_exit(3); _exit(3);
#endif #endif
} }
......
...@@ -61,7 +61,7 @@ ...@@ -61,7 +61,7 @@
#include "o_str.h" #include "o_str.h"
#if !defined(OPENSSL_IMPLEMENTS_strncasecmp) && \ #if !defined(OPENSSL_IMPLEMENTS_strncasecmp) && \
!defined(OPENSSL_SYSNAME_WIN32) && \ !defined(OPENSSL_SYSNAME_WIN32) && !defined(OPENSSL_SYSNAME_WINCE) && \
!defined(NETWARE_CLIB) !defined(NETWARE_CLIB)
# include <strings.h> # include <strings.h>
#endif #endif
......
...@@ -270,7 +270,7 @@ extern "C" { ...@@ -270,7 +270,7 @@ extern "C" {
*/ */
# define _WIN32_WINNT 0x0400 # define _WIN32_WINNT 0x0400
# endif # endif
# if !defined(OPENSSL_NO_SOCK) && defined(_WIN32_WINNT) # if !defined(OPENSSL_NO_SOCK) && (defined(_WIN32_WINNT) || defined(_WIN32_WCE))
/* /*
* Just like defining _WIN32_WINNT including winsock2.h implies * Just like defining _WIN32_WINNT including winsock2.h implies
* certain "discipline" for maintaining [broad] binary compatibility. * certain "discipline" for maintaining [broad] binary compatibility.
...@@ -286,6 +286,9 @@ extern "C" { ...@@ -286,6 +286,9 @@ extern "C" {
# include <stdio.h> # include <stdio.h>
# include <stddef.h> # include <stddef.h>
# include <errno.h> # include <errno.h>
# if defined(_WIN32_WCE) && !defined(EACCES)
# define EACCES 13
# endif
# include <string.h> # include <string.h>
# ifdef _WIN64 # ifdef _WIN64
# define strlen(s) _strlen31(s) # define strlen(s) _strlen31(s)
......
...@@ -62,7 +62,7 @@ ...@@ -62,7 +62,7 @@
#include <openssl/objects.h> #include <openssl/objects.h>
#include "ssl_locl.h" #include "ssl_locl.h"
#if defined(OPENSSL_SYS_WIN32) || defined(OPENSSL_SYS_VMS) #if defined(OPENSSL_SYS_VMS)
#include <sys/timeb.h> #include <sys/timeb.h>
#endif #endif
...@@ -452,7 +452,7 @@ int dtls1_handle_timeout(SSL *s) ...@@ -452,7 +452,7 @@ int dtls1_handle_timeout(SSL *s)
static void get_current_time(struct timeval *t) static void get_current_time(struct timeval *t)
{ {
#if defined(OPENSSL_SYS_WIN32) || defined(OPENSSL_SYS_WINCE) #if defined(_WIN32)
SYSTEMTIME st; SYSTEMTIME st;
union { unsigned __int64 ul; FILETIME ft; } now; union { unsigned __int64 ul; FILETIME ft; } now;
......
...@@ -126,7 +126,7 @@ elsif ($FLAVOR =~ /CE/) ...@@ -126,7 +126,7 @@ elsif ($FLAVOR =~ /CE/)
$base_cflags.=" $wcecdefs"; $base_cflags.=" $wcecdefs";
$base_cflags.=' -I$(WCECOMPAT)/include' if (defined($ENV{'WCECOMPAT'})); $base_cflags.=' -I$(WCECOMPAT)/include' if (defined($ENV{'WCECOMPAT'}));
$base_cflags.=' -I$(PORTSDK_LIBPATH)/../../include' if (defined($ENV{'PORTSDK_LIBPATH'})); $base_cflags.=' -I$(PORTSDK_LIBPATH)/../../include' if (defined($ENV{'PORTSDK_LIBPATH'}));
if ($cc =~ /\bcl(\.exe)*$/) { if (`$cc 2>&1` =~ /Version ([0-9]+)\./ && $1>=14) {
$base_cflags.=($shlib and !$fipscanisterbuild)?' /MD':' /MT'; $base_cflags.=($shlib and !$fipscanisterbuild)?' /MD':' /MT';
} else { } else {
$base_cflags.=' /MC'; $base_cflags.=' /MC';
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册