-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathRELEASE_NOTES
365 lines (266 loc) · 13.3 KB
/
RELEASE_NOTES
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
Ensure protocol module's modStartup()/modShutdown() are executed
only once (the same module can be used by multiple communication
ports).
R4.1.2:
Removed R4.1.1 tag which had been forced.
build with boost 1.64.0 and yaml-cpp-0.5.3_boost-1.64.0
SequenceCommandImpl: a lot of existing YAML write '1' to a command
in order to execute. Should really be '0' but was never checked by
previous releases. With support for multiple sub-sequences the
argument now has a meaning. For sake of backwards compatibility we
accept any argument in case a sequence is 'one-dimensional'.
SequenceCommandImpl: permit creation of a ScalVal_Base interface
yaml_cpsw_merge (program): fixed -Y option
R4.1.0:
Use python 3.6.1 by default.
SequenceCommand now supports two-dimensional sequences, i.e.,
a sequence of command sequences. This can be used to let the
user pick a sequence at run-time. Handy in combination with
an attached 'enum' menu. Note, this is accessible via the
ScalVal_WO user API, not Command.
Implemented new, more efficient handling of merge keys.
R4.0.0:
Feature: added cpsw_fs_address which implements access to the underlying
file-system. (E.g., char-devices).
Feature: may now create ScalVal_WO interfaces - but writes are marked
as non-cacheable.
Feature: cpsw_entry/cpsw_entry_adapt: promoted 'singleInterfaceOnly'
feature from static- to virtual method. Individual entries can now
reject creation of multiple interfaces. This feature is now settable
from YAML.
pycpsw BUGFIX: RuntimeError when IYamlFixup::findByName() didn't find a node
SequenceCommand: now also recognizes 'system(<args>)' for executing
native scripts, code etc.
Internal read/write API rework.
Merged 'swig/cython' branch. Major changes involve c++11 support
and migration from boost::python to cython. All python wrappers
have been migrated.
This means that boost is no longer necessary (if c++11 is available).
A few headers (lockfree) are still used but can be disabled in
the configuration file (switch to a native but simple implementation
which may or may not be less performant).
API enhancement: added asynchronous 'getVal' + notification via callback.
R3.branch:
BUGFIX: cpsw_path findByName() crashed when ".." crossed root
Created a R3.branch tag prior to merging major updates
The python wrapper is generated with CYTHON by default. Boost is
still supported (in case the new cython wrapper makes problems).
Experimental support for SWIG is also available. Eventually, however,
BOOST and SWIG will be deprecated and phased out.
Internal Modification: call open/close only on the adapters that
perform I/O. This makes the python wrapper simpler.
BUGFIX: stack overrun in udpsrv
Feature: cpsw_mem_dev: support 'offset' property when mapping a
file descriptor.
Bugfix: Ipath::parent() implementation was wrong; caused segfault.
(merged from R3.5.branch)
Bugfix: cpsw_bufq.cc: If multiple threads sleep in
CEventBufSync::getSlot() some may never wake up!
FIX: There was a subtle change in the implementation of YAML
maps in yaml-cpp v0.6.2: When a non-existing key is looked
up with
YAML::Node operator[](const Key &k);
then an 'invisible' new entry is added to the map.
We can iterate through the new map and won't see this new
entry (unless it was explicitly created e.g., by an
assignment: 'map[key] = value;'.
This behaviour was already the same in 0.5.3. What has
**changed** however, is that under 0.6.3 this lookup
operation **breaks** existing iterators, i.e,
YAML::const_iterator my_itr( map.begin() );
YAML::const_iterator my_end( map.begin() );
if ( ! map[nonexisting_key] ) {
// lookup of non-existing key broke iterators
// under 0.6.2 -- it used to work fine under
// 0.5.3...
while ( my_itr != my_end ) {
// !!!MAY SEGFAULT HERE!!!
}
}
In order to perform a lookup which does not modify the
map we must use ('const' attribute overload of operator)
const YAML::Node operator[](const Key *k) const;
which is IMHO very confusing and error-prone. Unfortunately
the API lacks a 'find' member analogous to std::map's...
Feature: Provide file/line info when loading YAML fails due
to parser errors.
Feature: When performing an RMW operation over SRP that spans
multiple words then read back (up to a max.) multiple
words in a single read operation.
Feature: Support C++11; reduce dependency on boost if C++11
is used. Boost is still used internally but not visible
from the API.
Feature: Support SRP 'posted' writes. This is now the default.
However, the write mode can be set from YAML. Future API
additions could override the default for each individual
SRP operations. Posted writes should be just fine, however.
Interspersed reads always serve as synchronization points,
i.e., all writes and reads over a single SRP VC are issued
(and executed on target) strictly in order.
Feature: NetIODev supports 'rssiBridge' property. When set then
CPSW contacts the bridge's RPC service to learn the TCP port
serving <ipAddress>:<port> on the target.
I.e., if the 'normal' YAML says
ipAddr: 192.168.2.10
...
UDP:
port: 8198
RSSI:
and is changed into
ipAddr: 192.168.2.10
rssiBridge: cpu-b084-hp01
...
UDP:
port: 8198
RSSI:
then the code uses a RSSI bridge at cpu-b084-hp01 to
proxy traffic to 192.168.2.10:8198 off that bridge.
The RPC service takes care of remapping UDP to TCP
ports in case multiple bridges are running (connecting
to different targets).
Feature: NetIODev supports 'socksProxy' property (SOCKS_PROXY env-
var is also supported) for selecting a proxy.
Feature: Added SOCKS support for TCP connection (code stolen from
my implementation for EPICS.
Feature: rssi_bridge enhancements:
- added '-u' option to control for individual ports whether RSSI
is to be used or not (for bare UDP ports).
-> -p <port> tunnels an UDP/RSSI connection via TCP
-> -u <port> tunnels a bare UDP connection via TCP
- added connection handler. UDP side is only connected once
a TCP connection is accepted. The old behavior (UDP side is
connected to FPGA immediately) is available via '-C' option.
This feature (*without* -C) is useful as it allows the bridge
to be started with a standard set of ports. It is then up to
the remote peer (which has the YAML) to decide which ports
to actually use.
Merge: FIX for depacketizer V2 (SOF bit sometimes not cleared
in non-first fragments).
Merge: depacketizer V2 support (from master)
Merge: Set default for SRP retryCount to 0 if transport is RSSI
or TCP
Merge:
CFreeList now supports allocate_shared() (single allocation
from free-list)
Convert IntFields with bitSize > 64 to be converted to
(hex) strings without truncating them (when read as CString).
Fixed MTU calculation for RSSI and DEPACK
Support for native endianness (ScalVal)
Bugfix: TDESTMux2: missing inintialization of class member causing segfault.
Bugfix: IYamlFixup::findByName() corrupted YAML hierarchy.
Bugfix: (in udpsrv, i.e., test code): incorrect use of lock guard
lead to no mutex protection (in simulator only)!
Bugfix: RSSI protocol module 'push' with absolute timeout would
pop from underlying queue instead of pushing.
Fix: test driver for streams over unreliable transport should use
some margin of acceptable errors. This was set to 22% (builder
API) but when the same test was run with a YAML hierarchy the
corresponding option was not set to relax the acceptable error
margin. (Merged from R3.5.branch.)
R3.7.branch
Feature: added 'getPath()', 'getConstPath()' to ICommand
R3.6.6
Bugfix: cpsw_bufq.cc: If multiple threads sleep in
CEventBufSync::getSlot() some may never wake up!
R3.6.5 (merged)
Guard: Reject newer YAML properties which require a more recent
version of CPSW:
depack/protocolVersion:
rssiBridge
socksProxy
R3.6.4
Added i686 and zynq (arm) targets
R3.6.3
Removed buildroot-2015 target
R3.7.branch
Bugfix: path was clobbered (incorrect NELMS) during 'explore' if tail
was an array.
Bugfix: protocol stack builder always used depacketizer if no SRP
Pycpsw: release GIL while blocking to read/write a stream.
(hopefull it is OK and python doesn't alter the
buffer state; the code we're executing with the GIL
unlocked is strictly non-python, of course)
Feature: block all signals in newly created threads.
Bugfix: (jira ESLCOMMON-178) when loading an IntField config from
YAML and the IntField has an enum menu then providing numerical
values in the config file didn't work.
Changed IYamlFixup; the callback now gets two nodes
passed in. The root node of the CPSW hierarchy and
the top node (which might be outside of the root)
Also: the python method name was changed from 'fixup'
to '__call__' (to match c== operator()).
R3.7.branch
Feature: Added support for fragmentation (packetizer) of outgoing
traffic.
Protocol Stack: changed semantics of 'processOutput/processInput'.
these can now 'edit' buffer chains in a more flexible
manner.
Feature: added 'emitNode' to yaml_cpp wrapper. Convert
node hierarchy to string (which can be written to a file).
Bugfix: proto_stack_builder::useDepack() should not set
other params
Moved 'getEncoding()' from IScalVal_Base to IVal_Base.
Python: Stream.read() has an optional 'offset' argument
(same as underlying IStream::read())
MemDev: FIX - read(NULL) means that the user wants to
know if data are available; must return nonzero.
Added support for thread priorities. All internal threads
in the protocol stack can be configured (from YAML) with
a priority (see doc/README.yamlDefinition).
New features: a 'NullDev' which is not backed by anything.
Useful for testing/debugging because any YAML hierarchy
can be loaded w/o need for hardware (or a lot or memory
as with MemDev that covers a large address space).
Python: a minimal wrapper for yaml-cpp was added; enough
to support basic fixups.
Python: Added YamlFixup so that a fixup (LoadYamlFile etc.)
can be written in python. NOTE: this requires yaml-cpp
python bindings which must be implemented/obtained elsewhere,
i.e., they are NOT part of cpsw.
R3.6.1
Makefile fixes
Added more targets to .PHONY:
Recurse 'test' into SUBDIRS, POSTBUILD_SUBDIRS
Moved 'test' target to rules.mak
Let top-level 'makefile' use 'rules.mak' & friends
R3.6.0
Feature/Fix: PYTHON: instantiate Streams via a context manager;
i.e., streams can only be used inside a 'with' block!
*** NOTE *** this is a python interface change; it is
no longer possible to read from a newly created stream
(Stream.create() now returns a context manager)!
Instead, you must read from the block of a 'with'
statement:
with Stream.create() as s:
s.read( buf )
Feature: derive IStream from IVal_Base; allows to obtain
basic properties from the stream interface.
R3.5.4 4-May-2017 Till Straumann (strauman)
Bugfix: Path->toString() segfault
UDP/TCP: ignore empty buffer chains (but don't deref!)
Bugfix: when releasing a buffer our allocator never called the destructor
Changed exceptions in cpsw_buf.cc from InternalError -> InvalidArgError
R3.5.3 14-Mar-2017 Till Straumann (strauman)
Improved error message when reading config fails
Use buffers getAvail() instead of getCapacity when reading RSSI header
add getAvail to udpsrv_util's buffer implementation
Bugfix: udpsrv's TCP handler
cpsw_stream_tst should always use a TDEST muxer
Bugfix: cannot collapse writes when the caller supplies bitmasks
Bugfix: must not use header after buffer ownership is relinquished
Bugfix: cpsw_event.cc - shared_pointer released prematurely
R3.5.2 08-Mar-2017 Till Straumann (strauman)
TCP must not discard messages but wait for queue to drain
Cleanup in config.mak
Added ioQueSend() (blocking send with timeout)
Use blocking send when a reliable channel is involved (TCP/RSSI)
R3.5.1 5-Mar-2017 H. Slepicka (slepicka)
Changes on the package structure
Move source code to src folder
Changes on products name
linux-x86_64 -> rhel6-x86_64
linuxRT-xxxx -> buildroot-<version>-xxxx
Changes on rules.mak file
Add uninstall rule
Include .html and other docs at the install rule
Add top-level Makefile