src/pdo.c
author etisserant
Fri, 25 May 2007 23:57:17 +0200
changeset 204 44ce74232ccb
parent 201 2966cd34162a
child 208 05d95c45b388
permissions -rw-r--r--
Some fixes for visual studio C compiler compatiblity.
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
     1
/*
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
     2
This file is part of CanFestival, a library implementing CanOpen Stack. 
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
     3
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
     4
Copyright (C): Edouard TISSERANT and Francis DUPIN
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
     5
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
     6
See COPYING file for copyrights details.
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
     7
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
     8
This library is free software; you can redistribute it and/or
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
     9
modify it under the terms of the GNU Lesser General Public
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    10
License as published by the Free Software Foundation; either
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    11
version 2.1 of the License, or (at your option) any later version.
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    12
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    13
This library is distributed in the hope that it will be useful,
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    14
but WITHOUT ANY WARRANTY; without even the implied warranty of
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    15
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    16
Lesser General Public License for more details.
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    17
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    18
You should have received a copy of the GNU Lesser General Public
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    19
License along with this library; if not, write to the Free Software
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    20
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    21
*/
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    22
#include "pdo.h"
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    23
#include "objacces.h"
149
fe50ada8020b Changes in the API:
etisserant
parents: 90
diff changeset
    24
#include "canfestival.h"
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    25
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    26
/****************************************************************************/
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    27
UNS8 sendPDO(CO_Data* d, s_PDO pdo, UNS8 req)
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    28
{
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    29
  UNS8 i;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    30
  if( d->nodeState == Operational ) {
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    31
    Message m;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    32
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    33
    /* Message copy for sending */
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
    34
    m.cob_id.w = pdo.cobId & 0x7FF; /* Because the cobId is 11 bytes length */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    35
    if ( req == NOT_A_REQUEST ) {
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    36
      UNS8 i;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    37
      m.rtr = NOT_A_REQUEST;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    38
      m.len = pdo.len;
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
    39
      /* memcpy(&m.data, &pdo.data, m.len); */
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
    40
      /* This Memcpy depends on packing structure. Avoid */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    41
      for (i = 0 ; i < pdo.len ; i++)
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    42
	m.data[i] = pdo.data[i];
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    43
    }
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    44
    else {
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    45
      m.rtr = REQUEST;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    46
      m.len = 0;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    47
    }
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    48
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    49
    MSG_WAR(0x3901, "sendPDO cobId :", m.cob_id.w);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    50
    MSG_WAR(0x3902,  "     Nb octets  : ",  m.len);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    51
    for (i = 0 ; i < m.len ; i++) {
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    52
      MSG_WAR(0x3903,"           data : ", m.data[i]);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    53
    }
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    54
		  
149
fe50ada8020b Changes in the API:
etisserant
parents: 90
diff changeset
    55
    return canSend(d->canHandle,&m);
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
    56
  } /* end if */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    57
  return 0xFF;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    58
}
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    59
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    60
/***************************************************************************/
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
    61
UNS8 PDOmGR(CO_Data* d, UNS32 cobId) /* PDO Manager */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    62
{
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    63
  UNS8 res;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    64
  UNS8 i;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    65
  s_PDO pdo;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    66
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    67
  MSG_WAR(0x3905, "PDOmGR",0);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    68
	
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    69
  /* if PDO is waiting for transmission,
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    70
     preparation of the message to send */
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    71
    pdo.cobId = cobId;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    72
    pdo.len =  d->process_var.count;
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
    73
    /* memcpy(&(pdo.data), &(process_var.data), pdo.len); */
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
    74
    /* Ce memcpy devrait être portable */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    75
    for ( i = 0 ; i < pdo.len ; i++) 
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    76
      pdo.data[i] = d->process_var.data[i];
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    77
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    78
    res = sendPDO(d, pdo, NOT_A_REQUEST);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    79
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    80
    return res;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    81
}
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    82
201
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
    83
#if 0
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
    84
/*********************************************************************/
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
    85
/* TODO : implement bit mapping                          			 */
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
    86
/*********************************************************************/
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
    87
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    88
UNS8 buildPDO(CO_Data* d, UNS16 index)
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
    89
{ /* DO NOT USE MSG_ERR because the macro may send a PDO -> infinite loop if it fails. */	
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    90
  UNS16 ind;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    91
  UNS8      subInd;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    92
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
    93
  UNS8 *     pMappingCount = NULL;      /* count of mapped objects... */
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
    94
  /* pointer to the var which is mapped to a pdo */
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
    95
/*  void *     pMappedAppObject = NULL;  */
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
    96
  /* pointer fo the var which holds the mapping parameter of an mapping entry  */ 
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    97
  UNS32 *    pMappingParameter = NULL;  
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    98
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
    99
  UNS8      Size;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   100
  UNS8      dataType;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   101
  UNS8      offset;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   102
  UNS16     offsetObjdict;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   103
  UNS16     offsetObjdictPrm;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   104
  UNS32     objDict;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   105
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   106
  subInd=(UNS8)0x00;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   107
  offset = 0x00;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   108
  ind = index - 0x1800;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   109
  
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   110
  MSG_WAR(0x3910,"Prepare PDO to send index :", index);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   111
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   112
  /* only operational state allows PDO transmission */
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   113
  if( d->nodeState != Operational ) {
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   114
    MSG_WAR(0x2911, "Unable to send the PDO (node not in OPERATIONAL mode). Node : ", index);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   115
    return 0xFF;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   116
  }
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   117
  offsetObjdictPrm = d->firstIndex->PDO_TRS;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   118
  offsetObjdict = d->firstIndex->PDO_TRS_MAP;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   119
  
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   120
  if (offsetObjdictPrm && offsetObjdict)
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   121
  {
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   122
	  /* get mapped objects number to transmit with this PDO */
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   123
	  pMappingCount = (d->objdict + offsetObjdict + ind)->pSubindex[0].pObject;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   124
	  MSG_WAR(0x3912, "Nb maped objects : ",* pMappingCount);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   125
	  MSG_WAR(0x3913, "        at index : ", 0x1A00 + ind);
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   126
	  while (subInd < *pMappingCount) { /* Loop on mapped variables */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   127
	    /* get mapping parameters */
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   128
	    pMappingParameter = (d->objdict + offsetObjdict + ind)->pSubindex[subInd + 1].pObject;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   129
	    MSG_WAR(0x3914, "Get the mapping      at index : ", (UNS16)0x1A00 + ind);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   130
	    MSG_WAR(0x3915, "                     subIndex : ", subInd + 1);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   131
	    MSG_WAR(0x3916, "                     value    : ", *(UNS32 *)pMappingParameter);
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   132
	    /* Get the mapped variable */
201
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   133
	    Size = ((UNS8)(((*pMappingParameter) & 0xFF) >> 3));
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   134
	  	objDict = getODentry(d, (UNS16)((*pMappingParameter) >> 16),
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   135
				    (UNS8)(((*pMappingParameter) >> 8 ) & 0x000000FF),
201
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   136
				    (void *)&d->process_var.data[offset], &Size, &dataType, 0 );  
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   137
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   138
	     if (objDict != OD_SUCCESSFUL) {
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   139
	        MSG_WAR(0x2919, "error accessing to the mapped var : ", subInd + 1);  
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   140
		MSG_WAR(0x2920, "         Mapped at index : ", (*pMappingParameter) >> 16);
90
7df322d86ae1 copy/paste error
frdupin
parents: 71
diff changeset
   141
		MSG_WAR(0x2921, "                subindex : ", ((*pMappingParameter) >> 8 ) & 0xFF);
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   142
		return 0xFF;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   143
	     } 
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   144
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   145
	      offset += Size;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   146
	      d->process_var.count = offset;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   147
	      subInd++;					
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   148
	}/* end Loop on mapped variables  */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   149
  }
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   150
  return 0;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   151
}
201
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   152
#endif
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   153
/**************************************************************************/
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   154
UNS8 sendPDOrequest( CO_Data* d, UNS32 cobId )
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   155
{		
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   156
  UNS32 *	 pwCobId;	
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   157
  UNS16          offset;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   158
  UNS16          lastIndex;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   159
  UNS8           err;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   160
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   161
  MSG_WAR(0x3930, "sendPDOrequest ",0);  
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   162
  /* Sending the request only if the cobid have been found on the PDO receive */
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   163
  /* part dictionary */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   164
  offset = d->firstIndex->PDO_RCV;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   165
  lastIndex = d->lastIndex->PDO_RCV;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   166
  if (offset)
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   167
	  while (offset <= lastIndex) {
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   168
	    /*get the CobId*/
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   169
	    pwCobId = d->objdict[offset].pSubindex[1].pObject;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   170
	      
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   171
	    if ( *pwCobId  == cobId ) {
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   172
	      s_PDO pdo;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   173
	      pdo.cobId = *pwCobId;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   174
	      pdo.len = 0;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   175
	      err  = sendPDO(d, pdo, REQUEST);	
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   176
	      return err;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   177
	    }
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   178
	    offset++;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   179
	  }
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   180
  MSG_WAR(0x1931, "sendPDOrequest : COBID not found : ", cobId); 
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   181
  return 0xFF;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   182
}
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   183
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   184
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   185
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   186
/***********************************************************************/
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   187
UNS8 proceedPDO(CO_Data* d, Message *m)
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   188
{		
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   189
  UNS8   numPdo;
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   190
  UNS8   numMap;  /* Number of the mapped varable */                      
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   191
  UNS8 i;
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   192
  UNS8 *     pMappingCount = NULL;    /* count of mapped objects... */
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   193
  /* pointer to the var which is mapped to a pdo... */
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   194
/*  void *     pMappedAppObject = NULL;   */
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   195
  /* pointer fo the var which holds the mapping parameter of an mapping entry */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   196
  UNS32 *    pMappingParameter = NULL;  
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   197
  UNS8  *    pTransmissionType = NULL; /* pointer to the transmission type */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   198
  UNS32 *    pwCobId = NULL;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   199
  UNS8       Size;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   200
  UNS8       dataType;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   201
  UNS8       offset;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   202
  UNS8       status;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   203
  UNS32      objDict;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   204
  UNS16      offsetObjdict;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   205
  UNS16      lastIndex;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   206
  status = state1;
201
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   207
 
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   208
  MSG_WAR(0x3935, "proceedPDO, cobID : ", ((*m).cob_id.w & 0x7ff)); 
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   209
  offset = 0x00;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   210
  numPdo = 0;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   211
  numMap = 0;
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   212
  if((*m).rtr == NOT_A_REQUEST ) { /* The PDO received is not a request. */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   213
    offsetObjdict = d->firstIndex->PDO_RCV;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   214
    lastIndex = d->lastIndex->PDO_RCV;
201
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   215
    
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   216
    /* study of all the PDO stored in the dictionary */   
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   217
    if(offsetObjdict)
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   218
	    while (offsetObjdict <= lastIndex) {
201
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   219
			
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   220
	      switch( status ) {
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   221
						
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   222
	        case state1:	/* data are stored in process_var array */
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   223
		  /* memcpy(&(process_var.data), &m->data, (*m).len); */
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   224
		  /* Ce memcpy devrait être portable. */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   225
		  for ( i = 0 ; i < m->len ; i++) 
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   226
		    d->process_var.data[i] = m->data[i];
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   227
		  d->process_var.count = (*m).len;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   228
	
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   229
		  status = state2; 
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   230
		  break;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   231
	
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   232
		case state2:
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   233
		  /* get CobId of the dictionary correspondant to the received PDO */
201
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   234
	          pwCobId = d->objdict[offsetObjdict].pSubindex[1].pObject; 
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   235
		  /* check the CobId coherance */
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   236
		  /*pwCobId is the cobId read in the dictionary at the state 3 */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   237
		  if ( *pwCobId == (*m).cob_id.w ){
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   238
		    /* The cobId is recognized */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   239
		    status = state4;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   240
		    MSG_WAR(0x3936, "cobId found at index ", 0x1400 + numPdo);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   241
		    break;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   242
		  }
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   243
		  else {
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   244
		    /* cobId received does not match with those write in the dictionnary */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   245
		    numPdo++;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   246
		    offsetObjdict++;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   247
		    status = state2;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   248
		    break;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   249
		  }
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   250
	
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   251
		case state4:	/* get mapped objects number */
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   252
		  /* The cobId of the message received has been found in the dictionnary. */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   253
		  offsetObjdict = d->firstIndex->PDO_RCV_MAP;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   254
		  lastIndex = d->lastIndex->PDO_RCV_MAP;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   255
		  pMappingCount = (d->objdict + offsetObjdict + numPdo)->pSubindex[0].pObject;	  
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   256
		  numMap = 0;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   257
		  while (numMap < *pMappingCount) {
201
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   258
			UNS8 tmp[]= {0,0,0,0,0,0,0,0};
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   259
		  	UNS8 ByteSize;
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   260
		    pMappingParameter = (d->objdict + offsetObjdict + numPdo)->pSubindex[numMap + 1].pObject;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   261
		    if (pMappingParameter == NULL) {
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   262
		      MSG_ERR(0x1937, "Couldn't get mapping parameter : ", numMap + 1); 
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   263
		      return 0xFF;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   264
		    }
201
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   265
			/* Get the addresse of the mapped variable. */
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   266
		    /* detail of *pMappingParameter : */
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   267
	            /* The 16 hight bits contains the index, the medium 8 bits contains the subindex, */
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   268
		    /* and the lower 8 bits contains the size of the mapped variable. */
201
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   269
		    
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   270
		    Size = (UNS8)(*pMappingParameter);
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   271
			
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   272
			/* copy bit per bit in little endian */
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   273
			CopyBits(Size, (UNS8*)&d->process_var.data[offset>>3], offset%8, 0, ((UNS8*)tmp), 0, 0);
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   274
		  	
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   275
		  	ByteSize = 1 + ((Size - 1) >> 3); /*1->8 => 1 ; 9->16 => 2, ... */
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   276
		  	
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   277
		    objDict = setODentry(d, (UNS16)((*pMappingParameter) >> 16),
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   278
				            (UNS8)(((*pMappingParameter) >> 8 ) & 0xFF),
201
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   279
					    	tmp, &ByteSize, 0 );
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   280
					    	
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   281
		    if(objDict != OD_SUCCESSFUL) {
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   282
		      MSG_ERR(0x1938, "error accessing to the mapped var : ", numMap + 1);  
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   283
		      MSG_WAR(0x2939, "         Mapped at index : ", (*pMappingParameter) >> 16);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   284
		      MSG_WAR(0x2940, "                subindex : ", ((*pMappingParameter) >> 8 ) & 0xFF);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   285
		      return 0xFF;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   286
		    }
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   287
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   288
		    MSG_WAR(0x3942, "Variable updated with value received by PDO cobid : ", m->cob_id.w);  
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   289
		    MSG_WAR(0x3943, "         Mapped at index : ", (*pMappingParameter) >> 16);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   290
		    MSG_WAR(0x3944, "                subindex : ", ((*pMappingParameter) >> 8 ) & 0xFF);
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   291
		    /* MSG_WAR(0x3945, "                data : ",*((UNS32 *)pMappedAppObject)); */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   292
		    offset += Size;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   293
		    numMap++;
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   294
		  } /* end loop while on mapped variables */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   295
		  
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   296
		  offset=0x00;		
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   297
		  numMap = 0;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   298
		  return 0;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   299
		  
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   300
	      }/* end switch status	*/	 
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   301
	    }/* end while	*/
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   302
  }/* end if Donnees */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   303
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   304
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   305
  else if ((*m).rtr == REQUEST ){  
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   306
      MSG_WAR(0x3946, "Receive a PDO request cobId : ", m->cob_id.w);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   307
      status = state1;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   308
      offsetObjdict = d->firstIndex->PDO_TRS;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   309
      lastIndex = d->lastIndex->PDO_TRS;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   310
      if(offsetObjdict) while( offsetObjdict  <= lastIndex ){ 
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   311
	/* study of all PDO stored in the objects dictionary */
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   312
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   313
	switch( status ){
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   314
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   315
	case state1:	/* check the CobId */
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   316
			/* get CobId of the dictionary which match to the received PDO */
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   317
	  pwCobId = (d->objdict + offsetObjdict)->pSubindex[1].pObject;	  
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   318
	  if ( *pwCobId == (*m).cob_id.w ) {
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   319
	    status = state4;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   320
	    break;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   321
	  }
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   322
	  else {
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   323
	    numPdo++;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   324
	    offsetObjdict++;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   325
	  }
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   326
	  status = state1;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   327
	  break;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   328
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   329
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   330
	case state4:	/* check transmission type (after request?) */
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   331
	  pTransmissionType = d->objdict[offsetObjdict].pSubindex[2].pObject;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   332
	  if ( (*pTransmissionType == TRANS_RTR) || (*pTransmissionType == TRANS_RTR_SYNC ) || (*pTransmissionType == TRANS_EVENT) ) {
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   333
	    status = state5;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   334
	    break;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   335
	  }
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   336
	  else {
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   337
	    /* The requested PDO is not to send on request. So, does nothing. */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   338
	    MSG_WAR(0x2947, "PDO is not to send on request : ", m->cob_id.w);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   339
	    return 0xFF;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   340
	  }
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   341
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   342
	case state5:	/* get mapped objects number */
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   343
	  offsetObjdict = d->firstIndex->PDO_TRS_MAP;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   344
	  lastIndex = d->lastIndex->PDO_TRS_MAP;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   345
	  pMappingCount = (d->objdict + offsetObjdict + numPdo)->pSubindex[0].pObject;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   346
	  numMap = 0;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   347
	  while (numMap < *pMappingCount) {
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   348
	    pMappingParameter = (d->objdict + offsetObjdict + numPdo)->pSubindex[numMap + 1].pObject;
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   349
	    /* Get the mapped variable */
201
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   350
	    Size = ((UNS8)(((*pMappingParameter) & 0xFF) >> 3)); 
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   351
	    objDict = getODentry( d, (UNS16)((*pMappingParameter) >> (UNS8)16), 
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   352
				     (UNS8)(( (*pMappingParameter) >> (UNS8)8 ) & 0xFF),
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   353
				     (void *)&d->process_var.data[offset], &Size, &dataType, 0 );
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   354
	    if (objDict != OD_SUCCESSFUL) {
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   355
	      MSG_ERR(0x1948, "error accessing to the mapped var : ", numMap + 1);  
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   356
	      MSG_WAR(0x2949, "         Mapped at index : ", (*pMappingParameter) >> 16);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   357
	      MSG_WAR(0x2950, "                subindex : ", ((*pMappingParameter) >> 8 ) & 0xFF);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   358
	      return 0xFF;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   359
	    }
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   360
	    offset += (UNS8) (((*pMappingParameter) & 0xFF) >> 3);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   361
	    d->process_var.count = offset;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   362
	    numMap++;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   363
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   364
	  } /* end while */
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   365
	  PDOmGR( d, *pwCobId ); /* Transmit the PDO */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   366
	  return 0;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   367
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   368
	}/* end switch status */
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   369
      }/* end while	 */			
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   370
    }/* end if Requete */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   371
		
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   372
  return 0;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   373
}
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   374
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   375
201
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   376
void CopyBits(UNS8 NbBits, UNS8* SrcByteIndex, UNS8 SrcBitIndex, UNS8 SrcBigEndian, UNS8* DestByteIndex, UNS8 DestBitIndex, UNS8 DestBigEndian)
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   377
{
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   378
	//This loop copy as many bits that it can each time, crossing successively bytes
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   379
	// boundaries from LSB to MSB.
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   380
	while(NbBits > 0)
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   381
	{
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   382
		// Bit missalignement between src and dest
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   383
		INTEGER8 Vect = DestBitIndex - SrcBitIndex;
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   384
		
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   385
		// We can now get src and align it to dest
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   386
		UNS8 Aligned = Vect>0 ? *SrcByteIndex << Vect : *SrcByteIndex >> -Vect;
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   387
		
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   388
		// Compute the nb of bit we will be able to copy
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   389
		UNS8 BoudaryLimit = (Vect>0 ? 8 - DestBitIndex :  8 - SrcBitIndex );
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   390
		UNS8 BitsToCopy = BoudaryLimit > NbBits ? NbBits : BoudaryLimit;
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   391
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   392
		// Create a mask that will serve in:
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   393
		UNS8 Mask = ((0xff << (DestBitIndex + BitsToCopy)) | (0xff >> (8 - DestBitIndex)));
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   394
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   395
		// - Filtering src
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   396
		UNS8 Filtered = Aligned & ~Mask;
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   397
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   398
		// - and erase bits where we write, preserve where we don't
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   399
		*DestByteIndex &= Mask;
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   400
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   401
		// Then write.
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   402
		*DestByteIndex |= Filtered ;
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   403
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   404
		//Compute next time cursors for src
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   405
		if((SrcBitIndex += BitsToCopy)>7)	// cross boundary ?
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   406
		{
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   407
			SrcBitIndex = 0;							// First bit
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   408
			SrcByteIndex += (SrcBigEndian ? -1 : 1);	// Next byte
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   409
		}
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   410
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   411
		//Compute next time cursors for dest
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   412
		if((DestBitIndex += BitsToCopy)>7)
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   413
		{
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   414
			DestBitIndex = 0;							// First bit
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   415
			DestByteIndex += (DestBigEndian ? -1 : 1);// Next byte
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   416
		}
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   417
		
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   418
		//And decrement counter.
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   419
		NbBits -= BitsToCopy;
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   420
	}
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   421
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   422
}
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   423
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   424
#if 0
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   425
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   426
/*********************************************************************/
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   427
/* TODO : reimplement this using CallBacks                           */
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   428
/*********************************************************************/
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   429
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   430
UNS8 sendPDOevent( CO_Data* d, void * variable )
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   431
{ /* DO NOT USE MSG_ERR because the macro may send a PDO -> infinite loop if it fails.	*/
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   432
  UNS32           objDict = 0;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   433
  UNS8            ind, sub_ind;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   434
  UNS8            status; 
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   435
  UNS8            offset;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   436
  UNS8 *     pMappingCount = NULL;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   437
  UNS32 *    pMappingParameter = NULL;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   438
  void *     pMappedAppObject = NULL;
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   439
  UNS8 *     pTransmissionType = NULL; /* pointer to the transmission type */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   440
  UNS32 *    pwCobId = NULL;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   441
  UNS8 *     pSize;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   442
  UNS8       size;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   443
  UNS8       dataType;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   444
  UNS16      offsetObjdict;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   445
  UNS16      offsetObjdictPrm;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   446
  UNS16      lastIndex;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   447
  UNS8       numMap;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   448
  ind     = 0x00;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   449
  sub_ind = 1; 
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   450
  offset  = 0x00;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   451
  pSize   = &size;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   452
  status  = state1;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   453
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   454
  /* look for the index and subindex where the variable is mapped */
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   455
  /* Then, send the pdo which contains the variable. */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   456
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   457
  MSG_WAR (0x3960, "sendPDOevent", 0);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   458
  offsetObjdictPrm = d->firstIndex->PDO_TRS;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   459
  
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   460
  offsetObjdict = d->firstIndex->PDO_TRS_MAP;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   461
  lastIndex = d->lastIndex->PDO_TRS_MAP;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   462
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   463
  if (offsetObjdictPrm && offsetObjdict) 
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   464
	  /* Loop on PDO Transmit */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   465
	  while(offsetObjdict <= lastIndex){
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   466
	    /* Check the transmission mode */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   467
	    pTransmissionType = d->objdict[offsetObjdictPrm].pSubindex[2].pObject;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   468
	    if (*pTransmissionType != TRANS_EVENT) {
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   469
	      ind++;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   470
	      offsetObjdict++;  
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   471
	      offsetObjdictPrm++;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   472
	      continue;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   473
	    }
201
2966cd34162a Boolean variable mapped in PDO
greg
parents: 149
diff changeset
   474
	    pMappingCount = d->objdict[offsetObjdict].pSubindex[0].pObject; 
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   475
	    numMap = 1; /* mapped variable */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   476
	    while (numMap <= *pMappingCount) {
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   477
	      pMappingParameter = d->objdict[offsetObjdict].pSubindex[numMap].pObject;
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   478
	      /* Get the variable */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   479
	      objDict = getODentry( d,
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   480
	                            (UNS16)((*pMappingParameter) >> 16), 
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   481
				    (UNS8)(( (*pMappingParameter) >> (UNS8)8 ) & (UNS32)0x000000FF),
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   482
				    (void * *)&pMappedAppObject, pSize, &dataType, 0 );
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   483
	      if( objDict != OD_SUCCESSFUL ) {  
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   484
		MSG_WAR(0x2961, "Error in dict. at index : ", 
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   485
			(*pMappingParameter) >> (UNS8)16);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   486
	      
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   487
		MSG_WAR(0x2962, "               subindex : ", 
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   488
			((*pMappingParameter) >> (UNS8)8 ) & (UNS32)0x000000FF);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   489
		return 0xFF;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   490
	      }
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   491
	      if (pMappedAppObject == variable) { // Variable found !
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   492
		MSG_WAR(0x3963, "Variable to send found at index : ", 
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   493
			(*pMappingParameter) >> 16);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   494
		MSG_WAR(0x3964, "                       subIndex : ", 
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   495
			((*pMappingParameter) >> 8 ) & 0x000000FF);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   496
		buildPDO(d, 0x1800 + ind);
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   497
		/* Get the cobId */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   498
		pwCobId = d->objdict[offsetObjdictPrm].pSubindex[1].pObject;
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   499
		PDOmGR( d, *pwCobId ); /* Send the PDO */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   500
		return 0;	    
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   501
	      }
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   502
	      numMap++;
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   503
	    } /* End loop on mapped variable */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   504
	    ind++;	
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   505
	    offsetObjdict++;  
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   506
	    offsetObjdictPrm++;
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   507
	  } /* End loop while on PDO */
0
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   508
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   509
  MSG_WAR(0x2965, "Variable not found in a PDO to send on event", 0);
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   510
  return 0xFF;
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   511
4472ee7c6c3e Commit a new cvs repo.
etisserant
parents:
diff changeset
   512
}
71
95cd3376cc9f compilator compatitibility
frdupin
parents: 0
diff changeset
   513
#endif