From 83107b407ec20fc3ab3b0e8f56fda52795400d9e Mon Sep 17 00:00:00 2001 From: Sascha Ittner Date: Tue, 24 Feb 2015 18:59:54 +0100 Subject: [PATCH 1/3] - initial portable support, currently lcnc rtai+sim --- Makefile | 22 +++++++++++----- configure.mk | 27 ++++++++++++++++++++ examples/Makefile | 4 +-- src/Kbuild | 20 +++++++++++++++ src/Makefile | 59 ++++++++----------------------------------- src/lcec.h | 4 +-- src/lcec_conf.c | 3 ++- src/lcec_main.c | 52 ++++++++++++++++++++------------------ src/lcec_rtapi.h | 52 +++++++++++++++++++++----------------- src/lcec_rtapi_kmod.h | 38 ++++++++++++++++++++++++++++ src/lcec_rtapi_user.h | 47 ++++++++++++++++++++++++++++++++++ src/realtime.mk | 57 +++++++++++++++++++++++++++++++++++++++++ src/user.mk | 21 +++++++++++++++ 13 files changed, 295 insertions(+), 111 deletions(-) create mode 100644 configure.mk create mode 100644 src/Kbuild create mode 100644 src/lcec_rtapi_kmod.h create mode 100644 src/lcec_rtapi_user.h create mode 100644 src/realtime.mk create mode 100644 src/user.mk diff --git a/Makefile b/Makefile index 8dea524f..5a31d7cb 100644 --- a/Makefile +++ b/Makefile @@ -1,10 +1,18 @@ -all: - $(MAKE) -C src all +.PHONY: all configure install clean -clean: - $(MAKE) -C src realclean +all: configure + @$(MAKE) -C src all -install: all - $(MAKE) -C src install-rt install-user - $(MAKE) -C examples install-examples +clean: configure + @$(MAKE) -C src clean + rm -f config.mk + +install: configure + @$(MAKE) -C src install + @$(MAKE) -C examples install-examples + +configure: config.mk + +config.mk: configure.mk + @$(MAKE) -s -f configure.mk > config.mk diff --git a/configure.mk b/configure.mk new file mode 100644 index 00000000..1ddebcd0 --- /dev/null +++ b/configure.mk @@ -0,0 +1,27 @@ +.PHONY: configure +configure: + @echo "BUILDSYS = $(BUILDSYS)" + @echo "KERNELDIR = $(KERNELDIR)" + @echo "CC = $(CC)" + @echo "RTAI = $(RTAI)" + @echo "RTAIDIR = $(RTAIDIR)" + @echo "RTFLAGS = $(RTFLAGS)" + @echo "KERNELRELEASE = $(KERNELRELEASE)" + @echo "EXTRA_CFLAGS = $(EXTRA_CFLAGS)" + @echo "USE_RTLIBM = $(USE_RTLIBM)" + @echo "EMC2_HOME = $(EMC2_HOME)" + @echo "RUN_IN_PLACE = $(RUN_IN_PLACE)" + @echo "RTLIBDIR = $(RTLIBDIR)" + @echo "LIBDIR = $(LIBDIR)" + @echo "prefix = $(prefix)" + +# include modinc +MODINC=$(shell comp --print-modinc) +include $(MODINC) + +# dirty workaround to get the RTAI directory +RTAIINCDIR = $(subst /rtai.h,,$(firstword $(wildcard $(foreach i,$(subst -I,,$(filter -I%,$(RTFLAGS))), $(i)/rtai.h)))) +ifneq ($(RTAIINCDIR),) + RTAIDIR = $(realpath $(RTAIINCDIR)/..) +endif + diff --git a/examples/Makefile b/examples/Makefile index 86f4ca4b..d9010d19 100644 --- a/examples/Makefile +++ b/examples/Makefile @@ -1,9 +1,7 @@ -MODINC=$(shell comp --print-modinc) +include ../config.mk SUBDIRS = generic-complex swm-fm45a -include $(MODINC) - install-examples: mkdir -p $(DESTDIR)$(EMC2_HOME)/share/linuxcnc-ethercat/examples cp -R $(SUBDIRS) $(DESTDIR)$(EMC2_HOME)/share/linuxcnc-ethercat/examples diff --git a/src/Kbuild b/src/Kbuild new file mode 100644 index 00000000..b0fa0584 --- /dev/null +++ b/src/Kbuild @@ -0,0 +1,20 @@ +obj-m += lcec.o +lcec-objs := \ + lcec_main.o \ + lcec_generic.o \ + lcec_el1xxx.o \ + lcec_el2521.o \ + lcec_el2xxx.o \ + lcec_el31x2.o \ + lcec_el40x1.o \ + lcec_el40x2.o \ + lcec_el41x2.o \ + lcec_el5101.o \ + lcec_el5151.o \ + lcec_el5152.o \ + lcec_el7342.o \ + lcec_el95xx.o \ + lcec_em7004.o \ + lcec_stmds5k.o \ + lcec_deasda.o + diff --git a/src/Makefile b/src/Makefile index 4c6401f4..4c481ed2 100644 --- a/src/Makefile +++ b/src/Makefile @@ -1,53 +1,14 @@ -MODINC=$(shell comp --print-modinc) +.PHONY: all install clean -all: rt user +all: + @$(MAKE) -f user.mk all + @$(MAKE) -f realtime.mk all -realclean: - rm -f rm *.ko *.mod.c *.o .*.cmd - rm -f modules.order Module.symvers - rm -rf .tmp_versions - rm -f lcec_conf +install: + @$(MAKE) -f user.mk install + @$(MAKE) -f realtime.mk install -obj-m += lcec.o -lcec-objs := \ - lcec_main.o \ - lcec_generic.o \ - lcec_el1xxx.o \ - lcec_el2521.o \ - lcec_el2xxx.o \ - lcec_el31x2.o \ - lcec_el40x1.o \ - lcec_el40x2.o \ - lcec_el41x2.o \ - lcec_el5101.o \ - lcec_el5151.o \ - lcec_el5152.o \ - lcec_el7342.o \ - lcec_el95xx.o \ - lcec_em7004.o \ - lcec_stmds5k.o \ - lcec_deasda.o \ - $(MATHSTUB) - -include $(MODINC) - -# dirty workaround to get the RTAI directory -RTAI_INCLUDE_DIR = $(subst /rtai.h,,$(firstword $(wildcard $(foreach i,$(subst -I,,$(filter -I%,$(RTFLAGS))), $(i)/rtai.h)))) -RTAI_DIR = $(RTAI_INCLUDE_DIR)/.. - -user: lcec_conf - -lcec_conf: lcec_conf.c - gcc $(EXTRA_CFLAGS) -Wframe-larger-than=16384 -URTAPI -U__MODULE__ -DULAPI -Os -o $@ $< -Wl,-rpath,$(LIBDIR) -L$(LIBDIR) -llinuxcnchal -lexpat - -install-user: - mkdir -p $(DESTDIR)$(EMC2_HOME)/bin - cp lcec_conf $(DESTDIR)$(EMC2_HOME)/bin - -rt: - $(MAKE) KBUILD_EXTRA_SYMBOLS="$(RTLIBDIR)/Module.symvers $(RTAI_DIR)/modules/ethercat/Module.symvers" -C $(KERNELDIR) SUBDIRS=`pwd` CC=$(CC) V=0 modules - -install-rt: - mkdir -p $(DESTDIR)$(RTLIBDIR) - $(MAKE) install +clean: + @$(MAKE) -f user.mk $@ + @$(MAKE) -f realtime.mk $@ diff --git a/src/lcec.h b/src/lcec.h index 0895a6aa..00b597b0 100644 --- a/src/lcec.h +++ b/src/lcec.h @@ -22,9 +22,7 @@ #include "hal.h" -#include "rtapi.h" #include "rtapi_ctype.h" -#include "rtapi_app.h" #include "rtapi_string.h" #include "rtapi_math.h" @@ -64,7 +62,7 @@ do { \ #define LCEC_DELTA_VID 0x000001dd // SDO request timeout (ms) -#define LCEC_SDO_REQ_TIMEOUT 1000 +#define LCEC_SDO_REQ_TIMEOUT LCEC_MS_TO_TICKS(1000) struct lcec_master; struct lcec_slave; diff --git a/src/lcec_conf.c b/src/lcec_conf.c index 18bbc76c..63d9154c 100644 --- a/src/lcec_conf.c +++ b/src/lcec_conf.c @@ -26,6 +26,7 @@ #include "rtapi.h" #include "hal.h" +#include "lcec_rtapi.h" #include "lcec_conf.h" #define BUFFSIZE 8192 @@ -297,7 +298,7 @@ int main(int argc, char **argv) { fprintf(stderr, "%s: ERROR: couldn't allocate user/RT shared memory\n", modname); goto fail4; } - if (rtapi_shmem_getptr(shmem_id, &shmem_ptr) < 0) { + if (lcec_rtapi_shmem_getptr(shmem_id, &shmem_ptr) < 0) { fprintf(stderr, "%s: ERROR: couldn't map user/RT shared memory\n", modname); goto fail5; } diff --git a/src/lcec_main.c b/src/lcec_main.c index 8713b4c1..3dbeb25f 100644 --- a/src/lcec_main.c +++ b/src/lcec_main.c @@ -35,6 +35,8 @@ #include "lcec_stmds5k.h" #include "lcec_deasda.h" +#include "rtapi_app.h" + MODULE_LICENSE("GPL"); MODULE_AUTHOR("Sascha Ittner "); MODULE_DESCRIPTION("Driver for EtherCAT devices"); @@ -282,7 +284,7 @@ int rtapi_app_main(void) { } // initialize application time - RTAPI_GETTIMEOFDAY(&tv); + lcec_gettimeofday(&tv); master->app_time = EC_TIMEVAL2NANO(tv); // activating master @@ -391,7 +393,7 @@ int lcec_parse_config(void) { rtapi_print_msg (RTAPI_MSG_ERR, LCEC_MSG_PFX "couldn't allocate user/RT shared memory\n"); goto fail0; } - if (rtapi_shmem_getptr(shmem_id, &shmem_ptr) < 0 ) { + if (lcec_rtapi_shmem_getptr(shmem_id, &shmem_ptr) < 0 ) { rtapi_print_msg (RTAPI_MSG_ERR, LCEC_MSG_PFX "couldn't map user/RT shared memory\n"); goto fail1; } @@ -411,7 +413,7 @@ int lcec_parse_config(void) { rtapi_print_msg (RTAPI_MSG_ERR, LCEC_MSG_PFX "couldn't allocate user/RT shared memory\n"); goto fail0; } - if (rtapi_shmem_getptr(shmem_id, &shmem_ptr) < 0 ) { + if (lcec_rtapi_shmem_getptr(shmem_id, &shmem_ptr) < 0 ) { rtapi_print_msg (RTAPI_MSG_ERR, LCEC_MSG_PFX "couldn't map user/RT shared memory\n"); goto fail1; } @@ -438,7 +440,7 @@ int lcec_parse_config(void) { conf += sizeof(LCEC_CONF_MASTER_T); // alloc master memory - master = kzalloc(sizeof(lcec_master_t), GFP_KERNEL); + master = lcec_zalloc(sizeof(lcec_master_t)); if (master == NULL) { rtapi_print_msg(RTAPI_MSG_ERR, LCEC_MSG_PFX "Unable to allocate master %d structure memory\n", master_conf->index); goto fail2; @@ -481,7 +483,7 @@ int lcec_parse_config(void) { } // create new slave - slave = kzalloc(sizeof(lcec_slave_t), GFP_KERNEL); + slave = lcec_zalloc(sizeof(lcec_slave_t)); if (slave == NULL) { rtapi_print_msg(RTAPI_MSG_ERR, LCEC_MSG_PFX "Unable to allocate slave %s.%s structure memory\n", master->name, slave_conf->name); goto fail2; @@ -524,21 +526,21 @@ int lcec_parse_config(void) { memset(generic_hal_data, 0, sizeof(lcec_generic_pin_t) * slave_conf->pdoMappingCount); // alloc pdo entry memory - generic_pdo_entries = kzalloc(sizeof(ec_pdo_entry_info_t) * slave_conf->pdoEntryCount, GFP_KERNEL); + generic_pdo_entries = lcec_zalloc(sizeof(ec_pdo_entry_info_t) * slave_conf->pdoEntryCount); if (generic_pdo_entries == NULL) { rtapi_print_msg(RTAPI_MSG_ERR, LCEC_MSG_PFX "Unable to allocate slave %s.%s generic pdo entry memory\n", master->name, slave_conf->name); goto fail2; } // alloc pdo memory - generic_pdos = kzalloc(sizeof(ec_pdo_info_t) * slave_conf->pdoCount, GFP_KERNEL); + generic_pdos = lcec_zalloc(sizeof(ec_pdo_info_t) * slave_conf->pdoCount); if (generic_pdos == NULL) { rtapi_print_msg(RTAPI_MSG_ERR, LCEC_MSG_PFX "Unable to allocate slave %s.%s generic pdo memory\n", master->name, slave_conf->name); goto fail2; } // alloc sync manager memory - generic_sync_managers = kzalloc(sizeof(ec_sync_info_t) * (slave_conf->syncManagerCount + 1), GFP_KERNEL); + generic_sync_managers = lcec_zalloc(sizeof(ec_sync_info_t) * (slave_conf->syncManagerCount + 1)); if (generic_sync_managers == NULL) { rtapi_print_msg(RTAPI_MSG_ERR, LCEC_MSG_PFX "Unable to allocate slave %s.%s generic sync manager memory\n", master->name, slave_conf->name); goto fail2; @@ -548,7 +550,7 @@ int lcec_parse_config(void) { // alloc sdo config memory if (slave_conf->sdoConfigLength > 0) { - sdo_config = kzalloc(slave_conf->sdoConfigLength + sizeof(lcec_slave_sdoconf_t), GFP_KERNEL); + sdo_config = lcec_zalloc(slave_conf->sdoConfigLength + sizeof(lcec_slave_sdoconf_t)); if (sdo_config == NULL) { rtapi_print_msg(RTAPI_MSG_ERR, LCEC_MSG_PFX "Unable to allocate slave %s.%s generic pdo entry memory\n", master->name, slave_conf->name); goto fail2; @@ -591,7 +593,7 @@ int lcec_parse_config(void) { } // create new dc config - dc = kzalloc(sizeof(lcec_slave_dc_t), GFP_KERNEL); + dc = lcec_zalloc(sizeof(lcec_slave_dc_t)); if (dc == NULL) { rtapi_print_msg(RTAPI_MSG_ERR, LCEC_MSG_PFX "Unable to allocate slave %s.%s dc config memory\n", master->name, slave->name); goto fail2; @@ -626,7 +628,7 @@ int lcec_parse_config(void) { } // create new wd config - wd = kzalloc(sizeof(lcec_slave_watchdog_t), GFP_KERNEL); + wd = lcec_zalloc(sizeof(lcec_slave_watchdog_t)); if (wd == NULL) { rtapi_print_msg(RTAPI_MSG_ERR, LCEC_MSG_PFX "Unable to allocate slave %s.%s watchdog config memory\n", master->name, slave->name); goto fail2; @@ -781,7 +783,7 @@ int lcec_parse_config(void) { // allocate PDO entity memory for (master = first_master; master != NULL; master = master->next) { - pdo_entry_regs = kzalloc(sizeof(ec_pdo_entry_reg_t) * (master->pdo_entry_count + 1), GFP_KERNEL); + pdo_entry_regs = lcec_zalloc(sizeof(ec_pdo_entry_reg_t) * (master->pdo_entry_count + 1)); if (pdo_entry_regs == NULL) { rtapi_print_msg(RTAPI_MSG_ERR, LCEC_MSG_PFX "Unable to allocate master %s PDO entry memory\n", master->name); goto fail2; @@ -820,24 +822,24 @@ void lcec_clear_config(void) { // free slave if (slave->sdo_config != NULL) { - kfree(slave->sdo_config); + lcec_free(slave->sdo_config); } if (slave->generic_pdo_entries != NULL) { - kfree(slave->generic_pdo_entries); + lcec_free(slave->generic_pdo_entries); } if (slave->generic_pdos != NULL) { - kfree(slave->generic_pdos); + lcec_free(slave->generic_pdos); } if (slave->generic_sync_managers != NULL) { - kfree(slave->generic_sync_managers); + lcec_free(slave->generic_sync_managers); } if (slave->dc_conf != NULL) { - kfree(slave->dc_conf); + lcec_free(slave->dc_conf); } if (slave->wd_conf != NULL) { - kfree(slave->wd_conf); + lcec_free(slave->wd_conf); } - kfree(slave); + lcec_free(slave); slave = prev_slave; } @@ -848,11 +850,11 @@ void lcec_clear_config(void) { // free PDO entry memory if (master->pdo_entry_regs != NULL) { - kfree(master->pdo_entry_regs); + lcec_free(master->pdo_entry_regs); } // free master - kfree(master); + lcec_free(master); master = prev_master; } } @@ -1086,7 +1088,7 @@ ec_sdo_request_t *lcec_read_sdo(struct lcec_slave *slave, uint16_t index, uint8_ lcec_master_t *master = slave->master; ec_sdo_request_t *sdo; ec_request_state_t sdo_state; - unsigned long jiffies_start; + long ticks_start; // create request if (!(sdo = ecrt_slave_config_create_sdo_request(slave->config, index, subindex, size))) { @@ -1101,9 +1103,9 @@ ec_sdo_request_t *lcec_read_sdo(struct lcec_slave *slave, uint16_t index, uint8_ ecrt_sdo_request_read(sdo); // wait for completition (master's time out does not work here. why???) - jiffies_start = jiffies; - while ((sdo_state = ecrt_sdo_request_state(sdo)) == EC_REQUEST_BUSY && (jiffies - jiffies_start) < (HZ * LCEC_SDO_REQ_TIMEOUT / 1000)) { - schedule(); + ticks_start = lcec_get_ticks(); + while ((sdo_state = ecrt_sdo_request_state(sdo)) == EC_REQUEST_BUSY && (lcec_get_ticks() - ticks_start) < LCEC_SDO_REQ_TIMEOUT) { + lcec_schedule(); } // check state diff --git a/src/lcec_rtapi.h b/src/lcec_rtapi.h index 59d2f8b3..e6176c9f 100644 --- a/src/lcec_rtapi.h +++ b/src/lcec_rtapi.h @@ -1,31 +1,37 @@ -/******************************************************************** - * fake unified build config_module.h - *******************************************************************/ +// +// Copyright (C) 2015 Sascha Ittner +// +// This program is free software; you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation; either version 2 of the License, or +// (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program; if not, write to the Free Software +// Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA +// #ifndef _LCEC_RTAPI_H_ #define _LCEC_RTAPI_H_ -//#include "config_module.h" +#include -#define RTAPI_INC_CTYPE_H "linux/ctype.h" -#define RTAPI_INC_DEVICE_H "linux/device.h" -#define RTAPI_INC_FIRMWARE_H "linux/firmware.h" -#define RTAPI_INC_GFP_H "linux/gfp.h" -#define RTAPI_INC_LIST_H "linux/list.h" -#define RTAPI_INC_SLAB_H "linux/slab.h" -#define RTAPI_INC_STRING_H "linux/string.h" -#define RTAPI_INC_SCHED_H "linux/sched.h" -#define RTAPI_INC_JIFFIES_H "linux/jiffies.h" -#define RTAPI_INC_TIME_H "linux/time.h" +#ifdef __KERNEL__ + #include "lcec_rtapi_kmod.h" +#else + #include "lcec_rtapi_user.h" +#endif -#define RTAPI_GETTIMEOFDAY(x) do_gettimeofday(x) -//#define RTAPI_GETTIMEOFDAY(x) gettimeofday(x, NULL) +#if defined RTAPI_SERIAL && RTAPI_SERIAL >= 2 + #define lcec_rtapi_shmem_getptr(id, ptr) rtapi_shmem_getptr(id, ptr, NULL) +#else + #define lcec_rtapi_shmem_getptr(id, ptr) rtapi_shmem_getptr(id, ptr) +#endif -#include RTAPI_INC_SCHED_H -#include RTAPI_INC_JIFFIES_H -#include RTAPI_INC_CTYPE_H -#include RTAPI_INC_SLAB_H -#include RTAPI_INC_STRING_H -#include RTAPI_INC_TIME_H +#endif -#endif /* CONFIG_MODULE_H */ diff --git a/src/lcec_rtapi_kmod.h b/src/lcec_rtapi_kmod.h new file mode 100644 index 00000000..37fedca6 --- /dev/null +++ b/src/lcec_rtapi_kmod.h @@ -0,0 +1,38 @@ +// +// Copyright (C) 2015 Sascha Ittner +// +// This program is free software; you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation; either version 2 of the License, or +// (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program; if not, write to the Free Software +// Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA +// + +#ifndef _LCEC_RTAPI_KMOD_H_ +#define _LCEC_RTAPI_KMOD_H_ + +#include +#include +#include +#include + +#define lcec_zalloc(size) kzalloc(size, GFP_KERNEL) +#define lcec_free(ptr) kfree(ptr) + +#define lcec_gettimeofday(x) do_gettimeofday(x) + +#define LCEC_MS_TO_TICKS(x) (HZ * x / 1000) +#define lcec_get_ticks() ((long) jiffies) + +#define lcec_schedule() schedule() + +#endif + diff --git a/src/lcec_rtapi_user.h b/src/lcec_rtapi_user.h new file mode 100644 index 00000000..3e585f43 --- /dev/null +++ b/src/lcec_rtapi_user.h @@ -0,0 +1,47 @@ +// +// Copyright (C) 2015 Sascha Ittner +// +// This program is free software; you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation; either version 2 of the License, or +// (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program; if not, write to the Free Software +// Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA +// + +#ifndef _LCEC_RTAPI_USER_H_ +#define _LCEC_RTAPI_USER_H_ + +#include +#include +#include +#include +#include + +static inline void *lcec_zalloc(size_t size) { + void *p = malloc(size); + if (p) memset(p, 0, size); + return p; +} +#define lcec_free(ptr) free(ptr) + +#define lcec_gettimeofday(x) gettimeofday(x, NULL) + +#define LCEC_MS_TO_TICKS(x) (x / 10) +static inline long lcec_get_ticks(void) { + struct timespec tp; + clock_gettime(CLOCK_MONOTONIC, &tp); + return ((long)(tp.tv_sec * 100LL)) + (tp.tv_nsec / 10000000L); +} + +#define lcec_schedule() sched_yield() + +#endif + diff --git a/src/realtime.mk b/src/realtime.mk new file mode 100644 index 00000000..ab59d707 --- /dev/null +++ b/src/realtime.mk @@ -0,0 +1,57 @@ +include ../config.mk +include Kbuild + +cc-option = $(shell if $(CC) $(CFLAGS) $(1) -S -o /dev/null -xc /dev/null \ + > /dev/null 2>&1; then echo "$(1)"; else echo "$(2)"; fi ;) + +.PHONY: all clean install + +all: $(module) + +clean:: + rm -f $(module) + rm -f $(lcec-objs) + +install: $(module) + mkdir -p $(DESTDIR)$(RTLIBDIR) + cp $(module) $(DESTDIR)$(RTLIBDIR)/ + +ifeq ($(BUILDSYS),kbuild) + +module = $(patsubst %.o,%.ko,$(obj-m)) + +ifeq (,$(findstring -Wframe-larger-than=,$(EXTRA_CFLAGS))) + EXTRA_CFLAGS += $(call cc-option,-Wframe-larger-than=2560) +endif + +$(module): + $(MAKE) EXTRA_CFLAGS="$(EXTRA_CFLAGS)" KBUILD_EXTRA_SYMBOLS="$(RTLIBDIR)/Module.symvers $(RTAIDIR)/modules/ethercat/Module.symvers" -C $(KERNELDIR) SUBDIRS=`pwd` CC=$(CC) V=0 modules + +clean:: + rm -f $(obj-m) + rm -f *.mod.c .*.cmd + rm -f modules.order Module.symvers + rm -rf .tmp_versions + +install: $(module) + mkdir -p $(DESTDIR)$(RTLIBDIR) + cp $(module) $(DESTDIR)$(RTLIBDIR)/ + +else + +module = $(patsubst %.o,%.so,$(obj-m)) + +EXTRA_CFLAGS := $(filter-out -Wframe-larger-than=%,$(EXTRA_CFLAGS)) + +.PHONY: all clean install + +all: $(module) + +$(module): $(lcec-objs) + $(CC) -shared -o $@ $< -Wl,-rpath,$(LIBDIR) -L$(LIBDIR) -llinuxcnchal -lethercat + +%.o: %.c + $(CC) -o $@ $(EXTRA_CFLAGS) -Os -c $< + +endif + diff --git a/src/user.mk b/src/user.mk new file mode 100644 index 00000000..730fd8d5 --- /dev/null +++ b/src/user.mk @@ -0,0 +1,21 @@ +include ../config.mk + +EXTRA_CFLAGS := $(filter-out -Wframe-larger-than=%,$(EXTRA_CFLAGS)) + +.PHONY: all clean install + +all: lcec_conf + +clean: + rm -f lcec_conf.o lcec_conf + +install: lcec_conf + mkdir -p $(DESTDIR)$(EMC2_HOME)/bin + cp lcec_conf $(DESTDIR)$(EMC2_HOME)/bin/ + +lcec_conf: lcec_conf.o + $(CC) -o $@ $< -Wl,-rpath,$(LIBDIR) -L$(LIBDIR) -llinuxcnchal -lexpat + +%.o: %.c + $(CC) -o $@ $(EXTRA_CFLAGS) -URTAPI -U__MODULE__ -DULAPI -Os -c $< + From 05cc85f2dbb59eef9df237ec9f159944eb586bfc Mon Sep 17 00:00:00 2001 From: linuxcnc Date: Tue, 24 Feb 2015 19:24:11 +0100 Subject: [PATCH 2/3] - fixed rule order --- src/realtime.mk | 28 ++++++++++------------------ 1 file changed, 10 insertions(+), 18 deletions(-) diff --git a/src/realtime.mk b/src/realtime.mk index ab59d707..b40bccec 100644 --- a/src/realtime.mk +++ b/src/realtime.mk @@ -6,16 +6,6 @@ cc-option = $(shell if $(CC) $(CFLAGS) $(1) -S -o /dev/null -xc /dev/null \ .PHONY: all clean install -all: $(module) - -clean:: - rm -f $(module) - rm -f $(lcec-objs) - -install: $(module) - mkdir -p $(DESTDIR)$(RTLIBDIR) - cp $(module) $(DESTDIR)$(RTLIBDIR)/ - ifeq ($(BUILDSYS),kbuild) module = $(patsubst %.o,%.ko,$(obj-m)) @@ -33,20 +23,12 @@ clean:: rm -f modules.order Module.symvers rm -rf .tmp_versions -install: $(module) - mkdir -p $(DESTDIR)$(RTLIBDIR) - cp $(module) $(DESTDIR)$(RTLIBDIR)/ - else module = $(patsubst %.o,%.so,$(obj-m)) EXTRA_CFLAGS := $(filter-out -Wframe-larger-than=%,$(EXTRA_CFLAGS)) -.PHONY: all clean install - -all: $(module) - $(module): $(lcec-objs) $(CC) -shared -o $@ $< -Wl,-rpath,$(LIBDIR) -L$(LIBDIR) -llinuxcnchal -lethercat @@ -55,3 +37,13 @@ $(module): $(lcec-objs) endif +all: $(module) + +clean:: + rm -f $(module) + rm -f $(lcec-objs) + +install: $(module) + mkdir -p $(DESTDIR)$(RTLIBDIR) + cp $(module) $(DESTDIR)$(RTLIBDIR)/ + From 944fd867a16d52d184b54ba44a737c42f2f0709d Mon Sep 17 00:00:00 2001 From: Sascha Ittner Date: Tue, 24 Feb 2015 20:41:34 +0100 Subject: [PATCH 3/3] - added COMP variable to specify path to comp command --- configure.mk | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/configure.mk b/configure.mk index 1ddebcd0..369ec342 100644 --- a/configure.mk +++ b/configure.mk @@ -1,3 +1,5 @@ +COMP ?= comp + .PHONY: configure configure: @echo "BUILDSYS = $(BUILDSYS)" @@ -16,7 +18,11 @@ configure: @echo "prefix = $(prefix)" # include modinc -MODINC=$(shell comp --print-modinc) +MODINC=$(shell $(COMP) --print-modinc) +ifeq (, $(MODINC)) + $(error Unable to get modinc path) +endif + include $(MODINC) # dirty workaround to get the RTAI directory