Commit fc46b03c authored by claes's avatar claes

Default values for slave extuserprmdata was not set

parent b634e4ba
/* /*
* Proview $Id: rt_pb_gsd.cpp,v 1.10 2007-11-15 17:28:18 claes Exp $ * Proview $Id: rt_pb_gsd.cpp,v 1.11 2007-11-16 07:52:54 claes Exp $
* Copyright (C) 2005 SSAB Oxelsund AB. * Copyright (C) 2005 SSAB Oxelsund AB.
* *
* This program is free software; you can redistribute it and/or * This program is free software; you can redistribute it and/or
...@@ -874,11 +874,6 @@ int pb_gsd::read( char *filename) ...@@ -874,11 +874,6 @@ int pb_gsd::read( char *filename)
} }
else { else {
if ( (s = strchr( line, '='))) { if ( (s = strchr( line, '='))) {
// Pad with zero
for ( int i = e->Const_Offset + e->len; i < const_offset - e->Const_Offset; i++) {
if ( i < (int)sizeof( e->Const_Prm_Data))
e->Const_Prm_Data[i] = '0';
}
str_to_ostring( &t, s+1, sizeof(e->Const_Prm_Data), &data_len); str_to_ostring( &t, s+1, sizeof(e->Const_Prm_Data), &data_len);
memcpy( (char *)e->Const_Prm_Data + const_offset, (char *)t, data_len); memcpy( (char *)e->Const_Prm_Data + const_offset, (char *)t, data_len);
e->len = const_offset + data_len - e->Const_Offset; e->len = const_offset + data_len - e->Const_Offset;
...@@ -1106,6 +1101,10 @@ int pb_gsd::build() ...@@ -1106,6 +1101,10 @@ int pb_gsd::build()
if ( !extuserprmdataconst) if ( !extuserprmdataconst)
extuserprmdataconst = (gsd_sExtUserPrmDataConst *) calloc( 1, sizeof(gsd_sExtUserPrmDataConst)); extuserprmdataconst = (gsd_sExtUserPrmDataConst *) calloc( 1, sizeof(gsd_sExtUserPrmDataConst));
// Set default values to items
prm_items_set_default_data( prm_dataitems, prm_dataitems_cnt);
return 1; return 1;
} }
...@@ -1143,6 +1142,30 @@ int pb_gsd::prm_len( gsd_sPrmDataItem *item, int item_size) ...@@ -1143,6 +1142,30 @@ int pb_gsd::prm_len( gsd_sPrmDataItem *item, int item_size)
return len; return len;
} }
int pb_gsd::prm_items_set_default_data( gsd_sPrmDataItem *item, int item_size)
{
gsd_sExtUserPrmData *pd;
for ( int i = 0; i < item_size; i++) {
pd = item[i].ref->prm_data;
switch ( pd->data_type) {
case gsd_BitArea:
case gsd_Unsigned8:
case gsd_Signed8:
case gsd_Unsigned16:
case gsd_Signed16:
case gsd_Unsigned32:
case gsd_Signed32:
item[i].value = pd->Default_Value;
break;
default: ;
}
}
return 1;
}
int pb_gsd::prm_items_to_data( gsd_sPrmDataItem *item, int item_size, int pb_gsd::prm_items_to_data( gsd_sPrmDataItem *item, int item_size,
unsigned char *data, int data_size) unsigned char *data, int data_size)
{ {
......
/* /*
* Proview $Id: rt_pb_gsd.h,v 1.6 2007-08-21 15:12:40 claes Exp $ * Proview $Id: rt_pb_gsd.h,v 1.7 2007-11-16 07:52:54 claes Exp $
* Copyright (C) 2005 SSAB Oxelsund AB. * Copyright (C) 2005 SSAB Oxelsund AB.
* *
* This program is free software; you can redistribute it and/or * This program is free software; you can redistribute it and/or
...@@ -220,6 +220,7 @@ class pb_gsd { ...@@ -220,6 +220,7 @@ class pb_gsd {
int build(); int build();
int configure_module( gsd_sModuleConf *mclist); int configure_module( gsd_sModuleConf *mclist);
int prm_len( gsd_sPrmDataItem *item, int item_size); int prm_len( gsd_sPrmDataItem *item, int item_size);
int prm_items_set_default_data( gsd_sPrmDataItem *item, int item_size);
int prm_items_to_data( gsd_sPrmDataItem *item, int item_size, unsigned char *data, int prm_items_to_data( gsd_sPrmDataItem *item, int item_size, unsigned char *data,
int data_size); int data_size);
int prm_data_to_items( gsd_sPrmDataItem *item, int item_size, unsigned char *data, int prm_data_to_items( gsd_sPrmDataItem *item, int item_size, unsigned char *data,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment