# HG changeset patch # User Florian Pose # Date 1320405669 -3600 # Node ID 4751747d4e6dd0e47d2edf7c6fa8283b4d59b168 # Parent 5144a4bc6184167ff779306505b669e1d81262a7 Added --enable-wildcards to use 0xffffffff as wildcard for vendor ID and product code. diff -r 5144a4bc6184 -r 4751747d4e6d NEWS --- a/NEWS Mon Oct 24 10:49:27 2011 +0200 +++ b/NEWS Fri Nov 04 12:21:09 2011 +0100 @@ -76,6 +76,8 @@ * ethercat tool is now able to handle multiple masters. The --masters option supports ranges like '0,3,8-10'. * A sync manager is always enabled, if it contains registered process data. +* Added a configuration switch --enable-wildcards to use 0xffffffff as a +* wildcard for vendor ID and product code. Changes in 1.4.0: diff -r 5144a4bc6184 -r 4751747d4e6d configure.ac --- a/configure.ac Mon Oct 24 10:49:27 2011 +0200 +++ b/configure.ac Fri Nov 04 12:21:09 2011 +0100 @@ -1,6 +1,6 @@ #------------------------------------------------------------------------------ # -# $Id$ +# $Id: configure.ac,v 1baafcd263cc 2011/07/06 14:37:40 fp $ # # Copyright (C) 2006-2009 Florian Pose, Ingenieurgemeinschaft IgH # @@ -752,6 +752,31 @@ AC_SUBST(ENABLE_TTY,[$tty]) #------------------------------------------------------------------------------ +# Slave identification wildcards +#------------------------------------------------------------------------------ + +AC_ARG_ENABLE([wildcards], + AS_HELP_STRING([--enable-wildcards], + [Enable vendor ID / product code wildcards (default: no)]), + [ + case "${enableval}" in + yes) wildcards=1 + ;; + no) wildcards=0 + ;; + *) AC_MSG_ERROR([Invalid value for --enable-wildcards]) + ;; + esac + ], + [wildcards=0] +) + +if test "x${wildcards}" = "x1"; then + AC_DEFINE([EC_IDENT_WILDCARDS], [1], + [Use vendor id / product code wildcards]) +fi + +#------------------------------------------------------------------------------ AC_CONFIG_FILES([ Doxyfile diff -r 5144a4bc6184 -r 4751747d4e6d master/slave_config.c --- a/master/slave_config.c Mon Oct 24 10:49:27 2011 +0200 +++ b/master/slave_config.c Fri Nov 04 12:21:09 2011 +0100 @@ -1,6 +1,6 @@ /****************************************************************************** * - * $Id$ + * $Id: slave_config.c,v 8c63d804ead9 2011/08/11 18:44:18 fp $ * * Copyright (C) 2006-2008 Florian Pose, Ingenieurgemeinschaft IgH * @@ -234,12 +234,28 @@ return -EEXIST; } - if (slave->sii.vendor_id != sc->vendor_id - || slave->sii.product_code != sc->product_code) { - EC_CONFIG_DBG(sc, 1, "Slave %u has an invalid type (0x%08X/0x%08X)" - " for configuration (0x%08X/0x%08X).\n", - slave->ring_position, slave->sii.vendor_id, - slave->sii.product_code, sc->vendor_id, sc->product_code); + if ( +#ifdef EC_IDENT_WILDCARDS + sc->vendor_id != 0xffffffff && +#endif + slave->sii.vendor_id != sc->vendor_id + ) { + EC_CONFIG_DBG(sc, 1, "Slave %u has no matching vendor ID (0x%08X)" + " for configuration (0x%08X).\n", + slave->ring_position, slave->sii.vendor_id, sc->vendor_id); + return -EINVAL; + } + + if ( +#ifdef EC_IDENT_WILDCARDS + sc->product_code != 0xffffffff && +#endif + slave->sii.product_code != sc->product_code + ) { + EC_CONFIG_DBG(sc, 1, "Slave %u has no matching product code (0x%08X)" + " for configuration (0x%08X).\n", + slave->ring_position, slave->sii.product_code, + sc->product_code); return -EINVAL; }