Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
P
proview
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Esteban Blanc
proview
Commits
7785c4c6
Commit
7785c4c6
authored
Jan 21, 2019
by
Marcus Nordenberg
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
gsdml data: update how data is written according to chosen byte order
parent
8e744aa1
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
49 additions
and
16 deletions
+49
-16
profibus/lib/rt/src/os_linux/rt_io_m_pndevice.cpp
profibus/lib/rt/src/os_linux/rt_io_m_pndevice.cpp
+8
-5
profibus/lib/rt/src/rt_pn_gsdml_data.cpp
profibus/lib/rt/src/rt_pn_gsdml_data.cpp
+34
-6
profibus/lib/rt/src/rt_pn_gsdml_data.h
profibus/lib/rt/src/rt_pn_gsdml_data.h
+7
-5
No files found.
profibus/lib/rt/src/os_linux/rt_io_m_pndevice.cpp
View file @
7785c4c6
/*
/*
* Copyright (C) 2010 SSAB Oxelsund AB.
* Copyright (C) 2010 SSAB Oxel
�
sund AB.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* modify it under the terms of the GNU General Public License as
...
@@ -123,6 +123,11 @@ static pwr_tStatus IoRackInit(io_tCtx ctx, io_sAgent* ap, io_sRack* rp)
...
@@ -123,6 +123,11 @@ static pwr_tStatus IoRackInit(io_tCtx ctx, io_sAgent* ap, io_sRack* rp)
}
}
chanp
->
offset
=
input_counter
;
chanp
->
offset
=
input_counter
;
chanp
->
mask
=
1
<<
chan_di
->
Number
;
chanp
->
mask
=
1
<<
chan_di
->
Number
;
// TODO Check with the PROFINET specification what to do with boolean values greater than 8 bit integers.
// The data coming from an et200sp 16 DI module represented as unsigned16 and the channel value of a
// AI modules channel represented as integer16 are sent with different byte order. Maybe booleans can be
// considered Little Endian...
// More TODO: Check host endianess aswell and take action accordingly
if
(
chan_di
->
Representation
==
pwr_eDataRepEnum_Bit16
if
(
chan_di
->
Representation
==
pwr_eDataRepEnum_Bit16
&&
op
->
ByteOrdering
==
pwr_eByteOrderingEnum_BigEndian
)
&&
op
->
ByteOrdering
==
pwr_eByteOrderingEnum_BigEndian
)
chanp
->
mask
=
swap16
(
chanp
->
mask
);
chanp
->
mask
=
swap16
(
chanp
->
mask
);
...
@@ -132,8 +137,7 @@ static pwr_tStatus IoRackInit(io_tCtx ctx, io_sAgent* ap, io_sRack* rp)
...
@@ -132,8 +137,7 @@ static pwr_tStatus IoRackInit(io_tCtx ctx, io_sAgent* ap, io_sRack* rp)
if
(
chan_di
->
Number
==
0
)
if
(
chan_di
->
Number
==
0
)
latent_input_count
latent_input_count
=
GetChanSize
((
pwr_eDataRepEnum
)
chan_di
->
Representation
);
=
GetChanSize
((
pwr_eDataRepEnum
)
chan_di
->
Representation
);
// printf("Di channel found in %s, Number %d, Offset %d\n",
//printf("Di channel found in %s, Number %d, Offset %d\n", cardp->Name, chan_di->Number, chanp->offset);
// cardp->Name, chan_di->Number, chanp->offset);
break
;
break
;
case
pwr_cClass_ChanAi
:
case
pwr_cClass_ChanAi
:
...
@@ -187,8 +191,7 @@ static pwr_tStatus IoRackInit(io_tCtx ctx, io_sAgent* ap, io_sRack* rp)
...
@@ -187,8 +191,7 @@ static pwr_tStatus IoRackInit(io_tCtx ctx, io_sAgent* ap, io_sRack* rp)
if
(
chan_do
->
Number
==
0
)
if
(
chan_do
->
Number
==
0
)
latent_output_count
latent_output_count
=
GetChanSize
((
pwr_eDataRepEnum
)
chan_do
->
Representation
);
=
GetChanSize
((
pwr_eDataRepEnum
)
chan_do
->
Representation
);
// printf("Do channel found in %s, Number %d, Offset %d\n",
//printf("Do channel found in %s, Number %d, Offset %d\n", cardp->Name, chan_do->Number, chanp->offset);
// cardp->Name, chan_do->Number, chanp->offset);
break
;
break
;
case
pwr_cClass_ChanAo
:
case
pwr_cClass_ChanAo
:
...
...
profibus/lib/rt/src/rt_pn_gsdml_data.cpp
View file @
7785c4c6
...
@@ -44,6 +44,8 @@
...
@@ -44,6 +44,8 @@
#include "rt_pb_msg.h"
#include "rt_pb_msg.h"
#include "rt_pn_gsdml_data.h"
#include "rt_pn_gsdml_data.h"
#include "pwr_baseclasses.h"
typedef
enum
{
typedef
enum
{
gsdmldata_eTag_
,
gsdmldata_eTag_
,
gsdmldata_eTag_PnDevice
,
gsdmldata_eTag_PnDevice
,
...
@@ -83,12 +85,15 @@ GsdmlDataRecord::GsdmlDataRecord(const GsdmlDataRecord& x)
...
@@ -83,12 +85,15 @@ GsdmlDataRecord::GsdmlDataRecord(const GsdmlDataRecord& x)
}
}
}
}
int
GsdmlDataRecord
::
print
(
std
::
ofstream
&
fp
)
int
GsdmlDataRecord
::
print
(
std
::
ofstream
&
fp
,
bool
reverse_endianess
)
{
{
char
str
[
1024
];
char
str
[
1024
];
unsigned
char
*
data
=
(
reverse_endianess
?
this
->
data_reversed_endianess
:
this
->
data
);
co_xml_parser
::
data_to_ostring
(
data
,
data_length
,
str
,
sizeof
(
str
));
co_xml_parser
::
data_to_ostring
(
data
,
data_length
,
str
,
sizeof
(
str
));
fp
<<
" <DataRecord Index=
\"
"
<<
index
<<
"
\"\n
"
fp
<<
" <DataRecord Index=
\"
"
<<
index
<<
"
\"\n
"
<<
" TransferSequence=
\"
"
<<
transfer_sequence
<<
"
\"\n
"
<<
" TransferSequence=
\"
"
<<
transfer_sequence
<<
"
\"\n
"
<<
" DataLength=
\"
"
<<
data_length
<<
"
\"\n
"
<<
" DataLength=
\"
"
<<
data_length
<<
"
\"\n
"
...
@@ -97,7 +102,7 @@ int GsdmlDataRecord::print(std::ofstream& fp)
...
@@ -97,7 +102,7 @@ int GsdmlDataRecord::print(std::ofstream& fp)
return
1
;
return
1
;
}
}
int
GsdmlSubslotData
::
print
(
std
::
ofstream
&
fp
)
int
GsdmlSubslotData
::
print
(
std
::
ofstream
&
fp
,
bool
reverse_endianess
)
{
{
fp
<<
" <Subslot SubslotNumber=
\"
"
<<
subslot_number
<<
"
\"\n
"
fp
<<
" <Subslot SubslotNumber=
\"
"
<<
subslot_number
<<
"
\"\n
"
<<
" SubmoduleEnumNumber=
\"
"
<<
submodule_enum_number
<<
"
\"\n
"
<<
" SubmoduleEnumNumber=
\"
"
<<
submodule_enum_number
<<
"
\"\n
"
...
@@ -107,14 +112,14 @@ int GsdmlSubslotData::print(std::ofstream& fp)
...
@@ -107,14 +112,14 @@ int GsdmlSubslotData::print(std::ofstream& fp)
<<
" IOOutputLength=
\"
"
<<
io_output_length
<<
"
\"
>
\n
"
;
<<
" IOOutputLength=
\"
"
<<
io_output_length
<<
"
\"
>
\n
"
;
for
(
unsigned
int
i
=
0
;
i
<
data_record
.
size
();
i
++
)
{
for
(
unsigned
int
i
=
0
;
i
<
data_record
.
size
();
i
++
)
{
data_record
[
i
]
->
print
(
fp
);
data_record
[
i
]
->
print
(
fp
,
reverse_endianess
);
}
}
fp
<<
" </Subslot>
\n
"
;
fp
<<
" </Subslot>
\n
"
;
return
1
;
return
1
;
}
}
int
GsdmlSlotData
::
print
(
std
::
ofstream
&
fp
)
int
GsdmlSlotData
::
print
(
std
::
ofstream
&
fp
,
bool
reverse_endianess
)
{
{
fp
<<
" <Slot ModuleEnumNumber=
\"
"
<<
module_enum_number
<<
"
\"\n
"
fp
<<
" <Slot ModuleEnumNumber=
\"
"
<<
module_enum_number
<<
"
\"\n
"
<<
" ModuleIdentNumber=
\"
"
<<
module_ident_number
<<
"
\"\n
"
<<
" ModuleIdentNumber=
\"
"
<<
module_ident_number
<<
"
\"\n
"
...
@@ -123,7 +128,7 @@ int GsdmlSlotData::print(std::ofstream& fp)
...
@@ -123,7 +128,7 @@ int GsdmlSlotData::print(std::ofstream& fp)
<<
" SlotNumber=
\"
"
<<
slot_number
<<
"
\"
>
\n
"
;
<<
" SlotNumber=
\"
"
<<
slot_number
<<
"
\"
>
\n
"
;
for
(
unsigned
int
i
=
0
;
i
<
subslot_data
.
size
();
i
++
)
{
for
(
unsigned
int
i
=
0
;
i
<
subslot_data
.
size
();
i
++
)
{
subslot_data
[
i
]
->
print
(
fp
);
subslot_data
[
i
]
->
print
(
fp
,
reverse_endianess
);
}
}
fp
<<
" </Slot>
\n
"
;
fp
<<
" </Slot>
\n
"
;
...
@@ -147,6 +152,7 @@ int GsdmlDeviceData::print(const char* filename)
...
@@ -147,6 +152,7 @@ int GsdmlDeviceData::print(const char* filename)
pwr_tFileName
fname
;
pwr_tFileName
fname
;
std
::
ofstream
fp
;
std
::
ofstream
fp
;
char
*
gsdmlfile_p
;
char
*
gsdmlfile_p
;
bool
reverse_endianess
=
false
;
// Print name of gsdmlfile, not path
// Print name of gsdmlfile, not path
if
((
gsdmlfile_p
=
strrchr
(
gsdmlfile
,
'/'
)))
if
((
gsdmlfile_p
=
strrchr
(
gsdmlfile
,
'/'
)))
...
@@ -172,8 +178,30 @@ int GsdmlDeviceData::print(const char* filename)
...
@@ -172,8 +178,30 @@ int GsdmlDeviceData::print(const char* filename)
<<
" SubnetMask=
\"
"
<<
subnet_mask
<<
"
\"\n
"
<<
" SubnetMask=
\"
"
<<
subnet_mask
<<
"
\"\n
"
<<
" MAC_Address=
\"
"
<<
mac_address
<<
"
\"
/>
\n
"
;
<<
" MAC_Address=
\"
"
<<
mac_address
<<
"
\"
/>
\n
"
;
//Save in accordance to the chosen endianess
#if (pwr_dHost_byteOrder == pwr_dLittleEndian)
if
(
byte_order
==
pwr_eByteOrderingEnum_LittleEndian
)
{
reverse_endianess
=
false
;
}
else
{
// We use the data saved as the reversed endianess
reverse_endianess
=
true
;
}
#elif (pwr_dHost_byteOrder == pwr_dBigEndian)
if
(
byte_order
==
pwr_eByteOrderingEnum_LittleEndian
)
{
reverse_endianess
=
true
;
}
else
{
reverse_endianess
=
false
;
}
#endif
for
(
unsigned
int
i
=
0
;
i
<
slot_data
.
size
();
i
++
)
{
for
(
unsigned
int
i
=
0
;
i
<
slot_data
.
size
();
i
++
)
{
slot_data
[
i
]
->
print
(
fp
);
slot_data
[
i
]
->
print
(
fp
,
reverse_endianess
);
}
}
for
(
unsigned
int
i
=
0
;
i
<
iocr_data
.
size
();
i
++
)
{
for
(
unsigned
int
i
=
0
;
i
<
iocr_data
.
size
();
i
++
)
{
iocr_data
[
i
]
->
print
(
fp
);
iocr_data
[
i
]
->
print
(
fp
);
...
...
profibus/lib/rt/src/rt_pn_gsdml_data.h
View file @
7785c4c6
...
@@ -46,12 +46,13 @@
...
@@ -46,12 +46,13 @@
class
GsdmlDataRecord
{
class
GsdmlDataRecord
{
public:
public:
GsdmlDataRecord
()
GsdmlDataRecord
()
:
record_idx
(
0
),
data
(
0
),
data_length
(
0
),
index
(
0
),
transfer_sequence
(
0
)
:
record_idx
(
0
),
data
(
0
),
data_
reversed_endianess
(
0
),
data_
length
(
0
),
index
(
0
),
transfer_sequence
(
0
)
{
{
}
}
unsigned
int
record_idx
;
unsigned
int
record_idx
;
unsigned
char
*
data
;
unsigned
char
*
data
;
unsigned
char
*
data_reversed_endianess
;
unsigned
int
data_length
;
unsigned
int
data_length
;
unsigned
short
index
;
unsigned
short
index
;
unsigned
short
transfer_sequence
;
unsigned
short
transfer_sequence
;
...
@@ -63,7 +64,7 @@ public:
...
@@ -63,7 +64,7 @@ public:
}
}
GsdmlDataRecord
(
const
GsdmlDataRecord
&
x
);
GsdmlDataRecord
(
const
GsdmlDataRecord
&
x
);
int
print
(
std
::
ofstream
&
fp
);
int
print
(
std
::
ofstream
&
fp
,
bool
reverse_endianess
);
};
};
class
GsdmlIOCRData
{
class
GsdmlIOCRData
{
...
@@ -113,7 +114,7 @@ public:
...
@@ -113,7 +114,7 @@ public:
data_record
.
push_back
(
new
GsdmlDataRecord
(
*
x
.
data_record
[
i
]));
data_record
.
push_back
(
new
GsdmlDataRecord
(
*
x
.
data_record
[
i
]));
}
}
}
}
int
print
(
std
::
ofstream
&
fp
);
int
print
(
std
::
ofstream
&
fp
,
bool
reverse_endianess
);
};
};
class
GsdmlSlotData
{
class
GsdmlSlotData
{
...
@@ -153,7 +154,7 @@ public:
...
@@ -153,7 +154,7 @@ public:
subslot_data
.
push_back
(
new
GsdmlSubslotData
(
*
x
.
subslot_data
[
i
]));
subslot_data
.
push_back
(
new
GsdmlSubslotData
(
*
x
.
subslot_data
[
i
]));
}
}
}
}
int
print
(
std
::
ofstream
&
fp
);
int
print
(
std
::
ofstream
&
fp
,
bool
reverse_endianess
);
};
};
class
GsdmlChannelDiag
{
class
GsdmlChannelDiag
{
...
@@ -169,7 +170,7 @@ public:
...
@@ -169,7 +170,7 @@ public:
class
GsdmlDeviceData
{
class
GsdmlDeviceData
{
public:
public:
GsdmlDeviceData
()
GsdmlDeviceData
()
:
device_num
(
0
),
vendor_id
(
0
),
device_id
(
0
),
byte_order
(
0
),
instance
(
0
)
:
device_num
(
0
),
vendor_id
(
0
),
device_id
(
0
),
byte_order
(
0
),
read_data_is_native_ordered
(
1
),
instance
(
0
)
{
{
device_name
[
0
]
=
0
;
device_name
[
0
]
=
0
;
ip_address
[
0
]
=
0
;
ip_address
[
0
]
=
0
;
...
@@ -189,6 +190,7 @@ public:
...
@@ -189,6 +190,7 @@ public:
unsigned
short
device_id
;
unsigned
short
device_id
;
char
version
[
20
];
char
version
[
20
];
int
byte_order
;
int
byte_order
;
int
read_data_is_native_ordered
;
unsigned
short
instance
;
unsigned
short
instance
;
pwr_tFileName
gsdmlfile
;
pwr_tFileName
gsdmlfile
;
std
::
vector
<
GsdmlSlotData
*>
slot_data
;
std
::
vector
<
GsdmlSlotData
*>
slot_data
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment