Add file to ensure some C++ compatibility

This commit is contained in:
Sebastian Huber 2014-08-29 11:01:39 +02:00
parent 62bdb6ae50
commit 7e982cf603
3 changed files with 125 additions and 53 deletions

View File

@ -5,31 +5,33 @@ include $(RTEMS_MAKEFILE_PATH)/Makefile.inc
include $(RTEMS_CUSTOM) include $(RTEMS_CUSTOM)
include $(PROJECT_ROOT)/make/leaf.cfg include $(PROJECT_ROOT)/make/leaf.cfg
CFLAGS += -ffreestanding COMMON_FLAGS += -ffreestanding
CFLAGS += -fno-common COMMON_FLAGS += -fno-common
CFLAGS += -Irtemsbsd/include COMMON_FLAGS += -Irtemsbsd/include
CFLAGS += -Irtemsbsd/$(RTEMS_CPU)/include COMMON_FLAGS += -Irtemsbsd/$(RTEMS_CPU)/include
CFLAGS += -Ifreebsd/sys COMMON_FLAGS += -Ifreebsd/sys
CFLAGS += -Ifreebsd/sys/$(RTEMS_CPU)/include COMMON_FLAGS += -Ifreebsd/sys/$(RTEMS_CPU)/include
CFLAGS += -Ifreebsd/sys/contrib/altq COMMON_FLAGS += -Ifreebsd/sys/contrib/altq
CFLAGS += -Ifreebsd/sys/contrib/pf COMMON_FLAGS += -Ifreebsd/sys/contrib/pf
CFLAGS += -Icopied/rtemsbsd/$(RTEMS_CPU)/include COMMON_FLAGS += -Icopied/rtemsbsd/$(RTEMS_CPU)/include
CFLAGS += -Ifreebsd/include COMMON_FLAGS += -Ifreebsd/include
CFLAGS += -Ifreebsd/lib/libc/include COMMON_FLAGS += -Ifreebsd/lib/libc/include
CFLAGS += -Ifreebsd/lib/libc/isc/include COMMON_FLAGS += -Ifreebsd/lib/libc/isc/include
CFLAGS += -Ifreebsd/lib/libc/resolv COMMON_FLAGS += -Ifreebsd/lib/libc/resolv
CFLAGS += -Ifreebsd/lib/libutil COMMON_FLAGS += -Ifreebsd/lib/libutil
CFLAGS += -Ifreebsd/lib/libkvm COMMON_FLAGS += -Ifreebsd/lib/libkvm
CFLAGS += -Ifreebsd/lib/libmemstat COMMON_FLAGS += -Ifreebsd/lib/libmemstat
CFLAGS += -Ifreebsd/lib/libipsec COMMON_FLAGS += -Ifreebsd/lib/libipsec
CFLAGS += -ImDNSResponder/mDNSCore COMMON_FLAGS += -ImDNSResponder/mDNSCore
CFLAGS += -ImDNSResponder/mDNSShared COMMON_FLAGS += -ImDNSResponder/mDNSShared
CFLAGS += -ImDNSResponder/mDNSPosix COMMON_FLAGS += -ImDNSResponder/mDNSPosix
CFLAGS += -Itestsuite/include COMMON_FLAGS += -Itestsuite/include
CFLAGS += -Wall COMMON_FLAGS += -Wall
CFLAGS += -Wno-format COMMON_FLAGS += -Wno-format
COMMON_FLAGS += -MT $@ -MD -MP -MF $(basename $@).d
CFLAGS += $(COMMON_FLAGS)
CFLAGS += -std=gnu99 CFLAGS += -std=gnu99
CFLAGS += -MT $@ -MD -MP -MF $(basename $@).d CXXFLAGS += $(COMMON_FLAGS)
NEED_DUMMY_PIC_IRQ=yes NEED_DUMMY_PIC_IRQ=yes
TEST_NETWORK_CONFIG = testsuite/include/rtems/bsd/test/network-config.h TEST_NETWORK_CONFIG = testsuite/include/rtems/bsd/test/network-config.h
@ -46,6 +48,8 @@ D_FILES =
LIB = libbsd.a LIB = libbsd.a
LIB_GEN_FILES = LIB_GEN_FILES =
LIB_C_FILES = LIB_C_FILES =
LIB_CXX_FILES =
LIB_CXX_FILES += rtemsbsd/rtems/rtems-bsd-cxx.cc
LIB_C_FILES += rtemsbsd/local/bus_if.c LIB_C_FILES += rtemsbsd/local/bus_if.c
LIB_C_FILES += rtemsbsd/local/cryptodev_if.c LIB_C_FILES += rtemsbsd/local/cryptodev_if.c
LIB_C_FILES += rtemsbsd/local/device_if.c LIB_C_FILES += rtemsbsd/local/device_if.c
@ -1431,9 +1435,9 @@ LIB_C_FILES += mDNSResponder/mDNSPosix/mDNSUNP.c
ifeq ($(NEED_DUMMY_PIC_IRQ),yes) ifeq ($(NEED_DUMMY_PIC_IRQ),yes)
CFLAGS += -I rtems-dummy-pic-irq/include CFLAGS += -I rtems-dummy-pic-irq/include
endif endif
LIB_O_FILES = $(LIB_C_FILES:%.c=%.o) LIB_O_FILES = $(LIB_C_FILES:%.c=%.o) $(LIB_CXX_FILES:%.cc=%.o)
O_FILES += $(LIB_O_FILES) O_FILES += $(LIB_O_FILES)
D_FILES += $(LIB_C_FILES:%.c=%.d) D_FILES += $(LIB_C_FILES:%.c=%.d) $(LIB_CXX_FILES:%.cc=%.d)
all: $(LIB) $(TESTS) $(TEST_NETWORK_CONFIG) $(NET_TESTS) all: $(LIB) $(TESTS) $(TEST_NETWORK_CONFIG) $(NET_TESTS)

View File

@ -411,31 +411,33 @@ class ModuleManager:
'include $(RTEMS_CUSTOM)\n' \ 'include $(RTEMS_CUSTOM)\n' \
'include $(PROJECT_ROOT)/make/leaf.cfg\n' \ 'include $(PROJECT_ROOT)/make/leaf.cfg\n' \
'\n' \ '\n' \
'CFLAGS += -ffreestanding\n' \ 'COMMON_FLAGS += -ffreestanding\n' \
'CFLAGS += -fno-common\n' \ 'COMMON_FLAGS += -fno-common\n' \
'CFLAGS += -Irtemsbsd/include\n' \ 'COMMON_FLAGS += -Irtemsbsd/include\n' \
'CFLAGS += -Irtemsbsd/$(RTEMS_CPU)/include\n' \ 'COMMON_FLAGS += -Irtemsbsd/$(RTEMS_CPU)/include\n' \
'CFLAGS += -Ifreebsd/sys\n' \ 'COMMON_FLAGS += -Ifreebsd/sys\n' \
'CFLAGS += -Ifreebsd/sys/$(RTEMS_CPU)/include\n' \ 'COMMON_FLAGS += -Ifreebsd/sys/$(RTEMS_CPU)/include\n' \
'CFLAGS += -Ifreebsd/sys/contrib/altq\n' \ 'COMMON_FLAGS += -Ifreebsd/sys/contrib/altq\n' \
'CFLAGS += -Ifreebsd/sys/contrib/pf\n' \ 'COMMON_FLAGS += -Ifreebsd/sys/contrib/pf\n' \
'CFLAGS += -Icopied/rtemsbsd/$(RTEMS_CPU)/include\n' \ 'COMMON_FLAGS += -Icopied/rtemsbsd/$(RTEMS_CPU)/include\n' \
'CFLAGS += -Ifreebsd/include\n' \ 'COMMON_FLAGS += -Ifreebsd/include\n' \
'CFLAGS += -Ifreebsd/lib/libc/include\n' \ 'COMMON_FLAGS += -Ifreebsd/lib/libc/include\n' \
'CFLAGS += -Ifreebsd/lib/libc/isc/include\n' \ 'COMMON_FLAGS += -Ifreebsd/lib/libc/isc/include\n' \
'CFLAGS += -Ifreebsd/lib/libc/resolv\n' \ 'COMMON_FLAGS += -Ifreebsd/lib/libc/resolv\n' \
'CFLAGS += -Ifreebsd/lib/libutil\n' \ 'COMMON_FLAGS += -Ifreebsd/lib/libutil\n' \
'CFLAGS += -Ifreebsd/lib/libkvm\n' \ 'COMMON_FLAGS += -Ifreebsd/lib/libkvm\n' \
'CFLAGS += -Ifreebsd/lib/libmemstat\n' \ 'COMMON_FLAGS += -Ifreebsd/lib/libmemstat\n' \
'CFLAGS += -Ifreebsd/lib/libipsec\n' \ 'COMMON_FLAGS += -Ifreebsd/lib/libipsec\n' \
'CFLAGS += -ImDNSResponder/mDNSCore\n' \ 'COMMON_FLAGS += -ImDNSResponder/mDNSCore\n' \
'CFLAGS += -ImDNSResponder/mDNSShared\n' \ 'COMMON_FLAGS += -ImDNSResponder/mDNSShared\n' \
'CFLAGS += -ImDNSResponder/mDNSPosix\n' \ 'COMMON_FLAGS += -ImDNSResponder/mDNSPosix\n' \
'CFLAGS += -Itestsuite/include\n' \ 'COMMON_FLAGS += -Itestsuite/include\n' \
'CFLAGS += -Wall\n' \ 'COMMON_FLAGS += -Wall\n' \
'CFLAGS += -Wno-format\n' \ 'COMMON_FLAGS += -Wno-format\n' \
'COMMON_FLAGS += -MT $@ -MD -MP -MF $(basename $@).d\n' \
'CFLAGS += $(COMMON_FLAGS)\n' \
'CFLAGS += -std=gnu99\n' \ 'CFLAGS += -std=gnu99\n' \
'CFLAGS += -MT $@ -MD -MP -MF $(basename $@).d\n' \ 'CXXFLAGS += $(COMMON_FLAGS)\n' \
'NEED_DUMMY_PIC_IRQ=yes\n' \ 'NEED_DUMMY_PIC_IRQ=yes\n' \
'\n' \ '\n' \
'TEST_NETWORK_CONFIG = testsuite/include/rtems/bsd/test/network-config.h\n' \ 'TEST_NETWORK_CONFIG = testsuite/include/rtems/bsd/test/network-config.h\n' \
@ -451,7 +453,9 @@ class ModuleManager:
'\n' \ '\n' \
'LIB = libbsd.a\n' \ 'LIB = libbsd.a\n' \
'LIB_GEN_FILES =\n' \ 'LIB_GEN_FILES =\n' \
'LIB_C_FILES =\n' 'LIB_C_FILES =\n' \
'LIB_CXX_FILES =\n' \
'LIB_CXX_FILES += rtemsbsd/rtems/rtems-bsd-cxx.cc\n'
for m in self.modules: for m in self.modules:
if m.conditionalOn != "none": if m.conditionalOn != "none":
data += 'ifneq ($(' + m.conditionalOn + '),yes)\n' data += 'ifneq ($(' + m.conditionalOn + '),yes)\n'
@ -471,9 +475,9 @@ class ModuleManager:
'ifeq ($(NEED_DUMMY_PIC_IRQ),yes)\n' \ 'ifeq ($(NEED_DUMMY_PIC_IRQ),yes)\n' \
'CFLAGS += -I rtems-dummy-pic-irq/include\n' \ 'CFLAGS += -I rtems-dummy-pic-irq/include\n' \
'endif\n' \ 'endif\n' \
'LIB_O_FILES = $(LIB_C_FILES:%.c=%.o)\n' \ 'LIB_O_FILES = $(LIB_C_FILES:%.c=%.o) $(LIB_CXX_FILES:%.cc=%.o)\n' \
'O_FILES += $(LIB_O_FILES)\n' \ 'O_FILES += $(LIB_O_FILES)\n' \
'D_FILES += $(LIB_C_FILES:%.c=%.d)\n' \ 'D_FILES += $(LIB_C_FILES:%.c=%.d) $(LIB_CXX_FILES:%.cc=%.d)\n' \
'\n' \ '\n' \
'all: $(LIB) $(TESTS) $(TEST_NETWORK_CONFIG) $(NET_TESTS)\n' \ 'all: $(LIB) $(TESTS) $(TEST_NETWORK_CONFIG) $(NET_TESTS)\n' \
'\n' \ '\n' \

View File

@ -0,0 +1,64 @@
/*
* Copyright (c) 2014 embedded brains GmbH. All rights reserved.
*
* embedded brains GmbH
* Dornierstr. 4
* 82178 Puchheim
* Germany
* <rtems@embedded-brains.de>
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/
#define __STDC_LIMIT_MACROS
#define __STDC_CONSTANT_MACROS
extern "C" {
#include <machine/rtems-bsd-kernel-space.h>
#include <rtems/bsd/sys/param.h>
#include <rtems/bsd/sys/types.h>
#include <sys/mbuf.h>
#include <sys/malloc.h>
#include <sys/kernel.h>
#include <sys/module.h>
#include <sys/socket.h>
#include <sys/sockio.h>
#include <sys/bus.h>
#include <machine/bus.h>
#include <net/if.h>
#include <net/ethernet.h>
#include <net/if_arp.h>
#include <net/if_dl.h>
#include <net/if_media.h>
#include <net/if_types.h>
#include <net/if_var.h>
}
/*
* Just make sure that these header files are C++ compatible to enable network
* interface drivers in C++.
*/