docs: tweak formatting in pmrep(1) archive folio example
[pcp.git] / CHANGELOG
blobffa32db0617951aee8614639afdcd3423a83e9c7
1 pcp-3.10.9 (16 December 2015)
2     - Work in progress [see http://pcp.io/roadmap]
4 pcp-3.10.8 (30 October 2015)
5     - pmdaslurm: new PMDA exporting HPC scheduler metrics
6     - pmdalinux: correctly report high speed network link speeds
7     - pmdalinux: support for wireless network interfaces
8     - pmdalinux: add support for NVME devices
9     - pmie: fqdn functionality, added %c for action strings
10     - pmlogextract: runtime reducing instance optimizations
11     - pmlogrewrite: metric name lex pattern change
12     - pmlogger: change semantics for first logging operation
13     - rc_pmlogger: shell escape for control file "directory" field
14     - pcp-atop: update with latest atop features (esp. NFS)
15     - pcp-atop: fix initial fetch time offset for the globals
16     - pcp-atop: fix -b/-e options to match man page description
17     - docs: update Quick Ref Guide with pcp-atop/pcp-atopsar
18     - docs: remove outdated pmatop man page, see pcp-atop(1)
19     - python api: fix local-context mode type error
20     - python api: improve handling of non-ascii instance names
21     - python api: simple debugging interface to access pmDebug
22     - python api: ensure an interruptible sleep is used
23     - python api: add single host/archive pmOption setter methods
24     - libpcp: add $PCP_DEBUG to initialize pmDebug
25     - libpcp: extend __pmAF* family with __pmAFsetup
26     - libpcp: resolve false-context-sharing corner cases
27     - pcp2graphite: provide a local-context mode option
28     - pmmgr: add the subtarget-containers option
29     - pmmgr: add pmlogreduce support
30     - rc_pmcd: be more careful with auto-install/-remove
31     - pmcd: allow dynamic switching of monitored containers
32     - pmdapmcd: add pmcd.client.container diagnostic metric
33     - pmdaroot: new metric mapping containers to their cgroups
34     - pmdaroot: add cgroup heuristics for non-systemd setups
35     - pmdaroot: fix timeliness of creation of socket connection
36     - pmdads389: add normalized dn cache metrics
37     - pmdads389: instantaneous vs discrete metric corrections
38     - pmdads389: send correct error codes when not connected
39     - pmdamounts: correct a number of 32-bit unsafe calculations
40     - pmdanfsclient: improve PMDA error handling
41     - pmdaperfevent: fix invalid metric names
42     - pmdaperfevent: add reference clock cycles for NHM and WSM
43     - docs: added upgrade instructions to pmdaperfevent man page
44     - containers: bindmount /dev/log for syslog messages
45     - build: fix FreeBSD 10.2 with dtrace probes auto-enabled
47 pcp-3.10.7 (16 September 2015)
48     - containers: added the pcp-pmie container
49     - containers: remove /proc bind mount, conflicts with --pid=host
50     - pcp-atopsar: new PMAPI sar command based on http://atoptool.nl
51     - pcp-uptime: fix sigsegv from missing metrics on first fetch
52     - pmchart: fix memory corruption when restoring Saved Hosts list
53     - pmchart: fix sigsegv opening a view when no archive available
54     - rc_scripts: pmie/pmlogger - logged, no longer send cron email
55     - rc_scripts: pmie/pmlogger - support for control.d directories;
56       backward-compatible /etc/pcp/{pmie,pmlogger}/control extension
57     - rc_scripts: pmcd/pmlogger - provide a localhost-only setting
58     - pmdamic: new PMDA for Intel MIC card metrics
59     - pmdaproc: export CPU scheduler cgroup metrics from cpu.stat
60     - pmdalinux: export IPv6 kernel metrics from /proc/net/snmp6
61     - pmdalinux: fix variable types for several disk metrics
62     - pmdalinux: printf int64_t and/or uint64_t support (for softnet)
63     - pmdajson: updates to allow use with python 2.6 installations
64     - pmcpp: support inline shell command execution
65     - pmwebd: multiple metrics/instances per log graphite mode speedup
66     - libpcp: use public domain getdate instead of gnulib version
67     - libpcp: optimise archive decompression for common operations
68     - libpcp: revert pdubuf tsearch-based optimisation, fails on OSX
69     - pmieconf: add dmthin pool utilization monitoring scripts
70     - python: more care taken in pmOptions destructor (could sigsegv)
71     - windows port: 64-bit format specifiers throughout code base
72     - windows port: fix a libpcp dlsym bug and IPC on Windows
73     - windows port: fix a python crash when free'ing resources
74     - pmdawindows: fix mem.cache.bytes metric kernel extraction
75     - perl pmda module: fix double free error in local_sock() routine
76       (observed to cause pmdamemcache crash during error path exit)
77     - pmdanginx: correct errors returned for not-running nginx daemon
78     - pmdamounts: add mount fs usage metrics via statvfs(3)
79     - pmdapostfix: improve error handling for files vs directories
80     - pmdanfsclient: fix typos in metric value parsing routines
81     - pmlogconf: remove tool-specific intervals from tool templates
82     - pmlogconf: add nginx, elasticsearch and memcache configs
83     - docs: update quickref guide for easier command pasting
84     - docs: update references to init scripts, pmlogger control files
85     - docs: update pmdanginx(1) describing nginx configuration needs
86     - build: configure.ac preserves optional gcc flags in the build
87     - build: cater for builds using the latest Vector (now 1.0.2)
88     - build: fix LGPL license annotations in headers+libraries
89     - build: current FreeBSD toolchain updates
91 pcp-3.10.6 (4 August 2015)
92     - rc_scripts: use syslog over email for error notification
93     - libpcp: catch bad valfmt encoding in interp.c (SGI BZ 1100)
94     - libpcp: $PATH-alike lists for derived metrics configurations
95     - libpcp: add instant() method for derived metrics
96     - libpcp: fix locking problem in pmGetConfig(3) routine
97     - python: fix bug in pmsubsys causing timestamp to reset.
98     - misc: several Coverity scan bug fixes, across the board
99     - containers: add version and arch to container image filenames
100     - containers: add crontab entries for containers
101     - containers: don't fix pcp user since pcp-base already does
102     - pmlogcheck: teach it about valfmt badness
103     - pmcpp: major revamp for pmlogger use (include files & macros)
104     - pmcpp: speed and robustness enhancements
105     - pmdadm: fix 2 dmcache metrics encoding on big-endian machines
106     - pmdalinux: fix the mnt/net namespace setns call ordering
107     - pmdalinux: corrections to the linux disk statistics metadata
108     - pmdalinux: ipc shared memory metrics for total, rss, and swap
109     - pmdalinux: new network.softnet metrics (/proc/net/softnet_stat)
110     - pmdaproc: reduce log spam in pmdaproc unknown state case
111     - pmdapostgresql: separate DB username from O/S username
112     - pmdapostgresql: major overhaul for different versions schemas
113     - pmdapostfix: general log parsing improvements
114     - pmdajson: handle instances better in the JSON PMDA.
115     - pmdajson: default to instantaneous metrics and do not attempt
116       to guess at semantics from type.
117     - pmdaperfevent: fix typo causing memleak/worse on an error path
118     - pmdadtsrun: fix parenthesis botch in Perl code
119     - pmdate: correct year and month offset problems at end of month
120     - pmlogconf: stop enabling percpu interrupt metrics by default
121     - pmlogger: improve handling of stale primary socket links
122     - pmlogger: integration with pmcpp
123     - pmwebd: elide repeated indom searching in graphite mode
124     - pcp2graphite: archive mode, reused connections, and python3
125     - pcp-atop: correct the reporting of some system memory metrics
126     - pcp-python: allow preferred-python switching at runtime
127     - pcp-collectl: fix an interrupt subsystem crash
128     - pcp-collectl: break out append statements for valid syntax
129     - pcp-collectl: fix recording of data to archive folios
130     - iostat2pcp: fix off-by-one error in disk rawactive metrics
131     - docs: corrections to pmdaperfevent man page
132     - docs: add some missing text to pmGetConfig man page
133     - docs: correct references to pre-v3 CC-BY-SA license
134     - docs: update book builds for current Publican variants
135     - docs: add derived metrics section to guide.html
136     - rpms: pcp-collector meta-package default-enables pmcd+pmlogger
137     - build: fix dependency problems causing parallel make races
138     - build: pcp containers build support via Makepkgs
139     - build: ensure pmcollectl is installed, man page updates
140     - build: correct rpm package dependency on pcp-libs version
141     - build: disable autofsd-probe on (most) platforms, unneeded
142     - build: allow pmdajson configure on/off build overrides
143     - build: rework configure test for ps(1) output formats
144     - build: install python-pcp in pcp-monitor container
145     - build: get native Solaris builds going again
146     - build: get native Illumos builds going again
147     - build: get native Windows builds going again
149 pcp-3.10.5 (15 June 2015)
150     - packaging: rebuild pmns in %post in fedora.spec
151     - build: changes for SUSE SLES 12
152     - ds389log: fixes to match updated logconv.pl
153     - build: realpath not needed, and not there on older platforms
154     - build: fix configure typo causing accidental books build
155     - packaging: fedora spec updates to be more consistent with Makepkgs
156     - build: add ppc64le to rpm 64bit lib macro list
157     - libpcp: pmdaCache: hash determinism across compilers/platforms
158     - pmda proc: Proc metrics depend on page size
159     - pcp-atop: fix folio recording replay with DM indom
160     - pcp-atop: fix bounds checking on disk names (valgrind)
161     - pmdaproc.sh: ensure pmloggers not started if disabled
162     - json pmda: tolerate json array instances that are missing
163     - pmnewlog: usage tweaks
164     - packaging, build: json pmda: make build and packaging conditional
165     - configure: add /bin/sh as possible pid==1 candidate
166     - pmlogger: initialize linger
167     - pmdalinux: Deprecate hinv.nlv and hinv.map.lvname, add hinv.map.dmname
168     - python: fix bug found by qa/739, unguarded destructor call
169     - pmlogger: add comment explaining -o => opts.Lflag usage
170     - pmnewlog: clean up usage message
171     - pcp-atop: implement record mode functionality (-w option)
172     - pcp-atop: resolve a print-buffer overflow on large I/O values
173     - build: src/include/builddefs.in: promote QA SUBDIRS
174     - pmie: prevent premature rule evaluation in pmie live mode
175     - pmlogger: add initial support for running in local context mode
176     - rc scripts: Use full path to pmlogger in pmlogger_check
177     - containers: Use pcp-base as the base image for all other PCP containers
178     - containers: introduce pcp-base container, for layering
179     - pcp-atop: reading from PCP archives now operational
180     - rc scripts: Don't fork pmcheck co-processes in a container environment
181     - pmlogconf: use the correct dm metrics in the atop set
182     - pmtime: further workarounds for App Nap on Mac OS X
183     - pcp-atop: archive mode and md/lvm device support
184     - pmie: fix for ruleset UNKNOWN case
185     - pmie: add new 'instant' operator, with doc updates
186     - pmda json: Skip sources with the same name in the JSON PMDA
187     - pmlogger_check: re-process every logconf group on config updates
188     - pmlogconf: qa and other updates following recent additions
189     - pmfind, pmsleep: Use sig_atomic_t within signal handlers
190     - pmda json: Add python 2/3 compatibility fixes
191     - packaging: ensure pmiostat and pmatop symlinks end up in system-tools
192     - pcp-atop: feature-filled PMAPI version of atop
193     - containers: configuration of optional PMDAs in pcp-collector container
194     - containers: prototype Dockerfiles and build infrastructure (not integrated)
195     - build: retire old pmtop sources and man page
196     - build: allow for multiple man pages below one src subdir
197     - pmdaproc: add two /proc/pid/status metrics, used by atop
198     - pmdaproc.sh: fix temp file handling
199     - packaging: Mirror pcp.spec.in package into fedora.spec
200     - pmdalinux: restore pmlogrewrite config file name
201     - build: add struct declarations for application headers
202     - build: add ncurses configure checking via pkg-config for console tools
203     - packaging: debian: add missing pmGetOptionalConfig.3.gz entry
204     - pmda linux_proc: cleanup up the jiffies -> msec calculations
205     - linux pmda: fix up types for some disk i/o metrics
206     - jbd2 pmda: add pmlogrewrite support for KERNEL_ULONG metrics
207     - pmlogextract: fix additional corner case for -d
208     - pmdalinux: code refactoring, common source files for ipc metrics
209     - pmdaroot: Fix NULL pointer deref for initial root_container_search(NULL)
210     - pmdaproc: ensure environ_buf buffer correctly setup on refresh
211     - docs: correct the pmmktime(3) return code - not a pointer
212     - pmie: add quiet mode to suppress default diagnostics
213     - python pmda api: Fix problems when returning fetch errors
214     - pcp.sh: ensure usage always generated via --help option
215     - pmdas: handle multiple pmchart config files for pmda installs
216     - pcp-shping: report shell-ping availability/response times
217     - pmda linux proc: Fixup some of the time types in linux_proc descriptors
218     - pmda json: Ignore cache load erros, fix refresh metric bug
219     - pmda json: Improve the JSON PMDA by use of indom caches
220     - libpcp python: Improve indom cache handling, add Add pmdaCacheResize()
221     - libpcp: add a pmGetOptionalConfig(3) for safe use in DSOs
222     - pmdaroot: fix order of pmdaConnect/Init for slow start case
223     - build: improve parallel builds, use make %{?_smp_mflags}
224     - pmdaroot: Add some additional DBG_TRACE_ATTR debug printfs
225     - build: update mac plist properties, attempt an appnap workaround
226     - pmdaroot: fix race and segv with short-lived containers
227     - docs: man/pmda.3: document the hidden variables in pmdaproc.sh
228     - pmdaproc.sh: rework, retire perl_args and python_args
229     - pmdalinux: fix container issues, especially with networking metrics
230     - libpcp: allow duplicates pmns names
231     - build: work-around bugs in RPM filter-requires
232     - build, packaging: lots of conditional Requires clauses
233     - packaging: Wrap pcp-pmda-rpm and pcp-gui with proper %if checks
234     - docs: Fix location of pcp-webjs gitweb in the pcp guide
235     - build: spin-rawhide: Extract version info from VERSION.pcp
236     - build: add rpm conflict handling for pcp command in librapi
237     - packaging: Add pcp-doc to pcp-compat deps to avoid losing man pages on upgrade
238     - packaging: Rename pcp-pmda-nvidia rpm to pcp-pmda-nvidia-gpu
239     - perl binding: refine perl PMDA interface error codes
240     - build: pmda.h: refine PMDA_PMID macro
241     - packaging, build: rpm packaging split - split out most PMDAs
242     - build: Add configure psproc check for /bin/bash for open build systems
243     - pmdaproc: consistent error code for missing proc.psinfo metrics
244     - pmda systemd: re-enable with reworked regex in file selection
245     - packaging: add pcp-compat package for back-compat upgrades
246     - pmdapostfix: logfiles are root-readable only, drop setuser (RHBZ #1213724)
247     - pcp-lvmcache: added link, an exact synonym for pcp-dmcache
248     - docs: add a configure switch for publican brand support
249     - libpcp: add pmGetVersion
250     - rc scripts: more cautious approach to using systemctl for Debian
251     - docs: describe hotproc in the quick reference guide
252     - pmda json: add an empty "trusted_directory_list" to default config file
253     - libpcp: new error code PM_ERR_BADSTORE for malformed pmstore input
254     - hotproc: update the pmdaproc manpage with hotproc info
255     - hotproc: Allow config file reload
256     - hotproc: disallow hotproc.conf with global write mode
257     - pmda postfix: bugfix to report mails submitted using mail program
258     - hotproc: support disabling via pmstore
259     - pmdaproc: add help text for new cgroup mem metrics
260     - pmiostat: Add pmiostat to the list of tools known to pmafm
261     - pmda root: fix for root_root installer problem on Mac OS X
262     - pcp-monitor and pcp-collector 'meta' packages to pcp.spec.in
263     - libpcp: libpcp/check-statics: more Mac OS X changes
264     - pmda postfix: Force restart for postfix pmda installation to change gid
265     - libpcp: p_profile.c: add fault injection points in libpcp_fault
266     - pmnscomp: remove code ... no longer used - deprecated
267     - libpcp: avoid pmcpp when loading PMNS for the most common usage
268     - pmda rpm: check return status from pthread_create
269     - hotproc: add guards for missing ioentry
270     - pmdumplog: fix cmdline filename handling
271     - pmdaproc: additional proc memory, namespace and memory cgroup metrics
272     - python: exception handling improvements
273     - pmdamounts: fix stack corruption for large mount options
274     - libpcp: pmns.c pmNameID and pmNameAll error handling fix
275     - pmwebd: add -I option for opening directories-as-archives for graphite
276     - pmwebd: graphite-png rendering: tweak graphics
277     - pmwebd: compressed archive mitigation, skip them in graphite mode
278     - pmwebd: crash fix: png-rendered multiple graphs with corrupt archives
279     - pmwebd: handle exit_p requested during graphite data-mass gathering
280     - pmwebd: fix little memory leak for fts() during interrupted rendering
281     - pmwebd: add a "-i MIN-INTERVAL" option for graphite time-precision control
282     - hotproc: cleanups, gracefully handle no schedstat, config cleanup
283     - pmiostat: accumulate -x arguments, remove duplicate error handling
284     - ds389log: init metrics with PM_ERR_AGAIN not zero
285     - pmdads389[log]: make configuration variables actually configurable
286     - pmdads389: make more resilient to server failures
287     - libpcp: interp.c: massive performance improvement in archive replay
288     - build: scripts to set up a buildbot 
289     - libpcp: pmLookupName() error handling, especially for dynamic metrics
290     - hotproc: hotproc : fix an off by one error for fname configs
291     - rc scripts: Allow more than one .NeedInstall to occur at a time
292     - pmie: remove unnecessary 2 second delay at live startup
293     - pmiostat: usage message cleanup
294     - build: pmchart: porting work to current macosx compiler
295     - packaging: Build pmns in RPM spec for faster startup
297 pcp-3.10.4 (15 April 2015)
298     - pmdalinux: fixed kernel.pernode.cpu.* for systems with only one CPU.
299     - pmdadm: merged in pmdadmcache, added thin provisioning metrics
300     - pmcd: fix failure to recover from errors sending client attrs
301     - pmcd: don't advertise presence if -A specified.
302     - pmchart: fix metric/host selection for containers
303     - python build: support for epel5 builds using python26 packages
304     - python api: do not assume unicode is only for python3
305     - stdpmid: updated the reserved domain number ranges
306     - libpcp: fix instance request memory corruption for large requests
307     - libpcp: multi-threading fixes and pdubuf optimisations
308     - libpcp: fix Avahi-related memory corruption
309     - libpcp: fix an interpolation performance issue
310     - libpcp: fix getopt --hostsfile parsing
311     - libpcp: tighten error handling in __pmGetArchiveEnd()
312     - pmwebd: enable multi-threading by default
313     - pmwebd: correct _indom array-allocation logic
314     - pmwebd: additional ACAO headers to resource responses
315     - pcp2graphite: python version neutral handling of stdout flush
316     - pcp-verify: a new utility for verifying collector setups, especially
317       for use with containers
318     - pcp sh: fix tempfile leak with sub-commands, refactor pcp-summary
319     - rc scripts: ensure rundir directories created when needed
320     - rc scripts: ensure tmpfiles not leftover from helper scripts
321     - rc_pmcd: add .NeedRemove option for pmcd start script also
322     - pmpause: lightweight pmsleep extension for a pmcd container
323     - pmlogcheck: merge previous versions, added documentation and tests
324     - pmdumplog: new options and new log reading logic
325     - build: add missing configure check for pkg-config requirement
326     - build: Dockerfile for a pcp-pmcd container image based on Fedora
327     - build: get Mac builds going on current Mac OS X (10.9/10.10)
328     - configure: fix AC_MSG_ERROR parameter passing
329     - packaging: fix default pmlogger/pmie configs directory location
330     - packaging: simplify rpm dependencies on pcp-webjs package via %dir
331     - packaging: relax the allowed-libpfm-version checks a little
333 pcp-3.10.3 (2 March 2015)
334     - enhancement: ongoing improvements to the native containers support
335         http://pcp.io/docs/lab.containers.html
336     - enhancement: pmlogger on-the-fly one-shot recording
337         http://oss.sgi.com/bugzilla/show_bug.cgi?id=1073
338     - doc: containers tutorial.
339     - build: new scripts directory. Contains useful scripts for project
340       management tasks.
341     - build: python-pcp no longer required.
342     - build: python3 now used where available.
343         https://bugzilla.redhat.com/show_bug.cgi?id=1194324
344     - build: new --with-papi configure option.
345     - qa: lots of improvements for robustness, portablity and determinism.
346     - qa: duplicate PMNS names allowed by default.
347     - pmdapapi: add papi refresh/read batching: papi.control.batch.
348     - pmdalinux: improve /proc/cpuinfo parser for irregular formats.
349     - services: ensure that they start after pmcd.
350     - libpcp: allow duplicate names to map to the same PMID by default.
351     - libpcp: duplicate PMNS names allowed by default.
352     - pminfo: duplicate PMNS names allowed by default. Reverse the semantics of
353       the -n and -N options.
354     - pmlogger: duplicate PMNS names allowed by default
355     - dbpmda: duplicate PMNS names allowed by default
356     - pmcd: duplicate PMNS names allowed by default. Reverse the semantics of
357       the -n and -N options.
358     - pmdumplog: duplicate PMNS names allowed by default.
359     - pmlogreduce: duplicate PMNS names allowed by default.
360     - pmlogsummary: duplicate PMNS names allowed by default.
361     - pmlogcheck: duplicate PMNS names allowed by default.
362     - pmevent: duplicate PMNS names allowed by default.
363     - pmchart: add an extra optional chart colour scheme.
364     - solaris PMDA: duplicate PMNS names allowed by default.
365     - ganglia2pcp: new utility.
366     - bug fix: pmlogger: signal delivery may lead to deadlock
367         http://oss.sgi.com/bugzilla/show_bug.cgi?id=1104
368     - bug fix: libpcp: AF functionality has posix-signal-unsafe elements
369         http://oss.sgi.com/bugzilla/show_bug.cgi?id=1069
371 pcp-3.10.2 (23 January 2015)
372     - PMAPI extension: pmParseUnitsStr. Includes python binding
373     - libpcp/pmcd: protocol-level support for containers
374     - libpcp_pmda - add pmdaInterfaceMoved() function
375     - pmdalinux: improve help text for network metrics
376     - pmdalinux: remove support for devfs device names - replaced by udev
377     - pmdalinux: rework hinv.map.scsi for longer scsi device names and indom
378     - pmdalinux: switch to running as a daemon, as root
379       persistence
380     - activeMQ: new pmda
381     - CIFS: new pmda (Common Internet File System)
382     - pmda unbound: a new PMDA for the Unbound DNS resolver
383     - pmdapapi: add configure conditional to test for
384       PAPI_component_info_t->disabled
385     - pmdapapi: add papi.available.version to output current PAPI version being
386       used
387     - pmdapapi: other new metrics
388     - pmdapapi: drop root requirement for less sensitive papi.available metrics
389     - pmdapapi: use dynamic metric description
390     - dbpmda: extend string syntax to include both " and ' delimiters
391     - rc_pmcd: execute _pmda_setup in the background
392     - Solaris build improvements:
393       - Support for Solaris symbol versioning
394       - use a libcpp exports comment style that works for both Linux and Solaris
395     - pmwebd: buildability fixes for illumos-based distros
396     - pmda root: a privileged pmcd co-process
397       Initial implementation of "pmdaroot", a helper co-process
398       for pmcd that runs with elevated privileges and is able to
399       (well, will be able to soon) offer services to pmcd and to
400       other PMDAs where root access is required
401     - pmdaroot/libpcp_pmda: interfaces for changing namespaces
402     - pmlogextract robustness improvements
403     - add pcp2graphite
404     - fix security PR1101: unprivileged access to linux proc.* metrics on modern
405       kernel
406     - Fedora 1180109: pmda cleanup was killing unrelated python and perl
407       processes
409 pcp-3.10.1 (1 December 2014)
410     - pmda proc: rework existing per-cgroup metrics - no
411       longer use dynamic metrics, allowing arbitray names
412     - pmda proc: add many new per-cgroup metrics, audited
413       definitions (units, etc) for existing metrics.
414     - perfevent pmda: new libpfm hardware counters agent
415     - papi pmda: switch to using dynamic metrics
416     - papi pmda: multiplexing, auto-enabling options
417     - papi pmda: added a new papi.control.reset metric
418     - pmwebd: improve /metrics/find for graphite dashboard
419     - pmwebd: $PCP_SHARE_DIR/webapps - default web content
420     - docs: clarify web services section in quick guide
421     - docs: fix books build for current publican versions
422     - docs: enable building of html book content as well
423     - linux pmda: improve aarch64 /proc/cpuinfo parsing
424     - libpcp: fix 64bit endian bug in highres event timers
426 pcp-3.10.0 (31 October 2014)
427     - pmlogextract: improve handling of corrupt archives
428     - linux pmda: add hinv.{cpu,node}.online metrics
429     - gluster pmda: thread-based timeout for long queries
430     - linux pmda: fix hinv.cpu.clock refresh logic
431     - dmcache pmda: add missing instance request handler
432     - iostat2pcp: cater for iostat output format changes
433     - packaging: fix debian suggests vs recommends usage
434     - sample pmda: add pmStore support for some metrics
435     - python: pmda module object refcounts improvements
436     - pmiostat: support archives converted from collectl
437     - FreeBSD pmda: changes for 32-bit platforms
438     - docs: html validation fixes for the tutorial
439     - pmie: rework control and config files
440     - pmlogger: rework control and config files
441     - pmstat: add pmlogger config as per man page
442     - proc pmda: parser rework to improve robustness
443     - proc pmda: per-proc context switch & other metrics
444     - man pages: pmdiscoverservices(3) and pmfind(1)
445     - ds389 pmda: 389 Directory Server PMDA
446     - ds389log pmda: 389 Directory Server log processing PMDA
447     - linux pmda: add rpc.server and nfs v4.1 ops metrics
448     - telnet-probe: fix byte-by-byte copying
449     - papi pmda: default enable when possible
450     - docs: improve quick reference guide, use man7.org
451     - pmproxy: fix new client init for secure connections
452     - pmdiff: minor output formatting improvements
453     - linux pmda: fix initialization for netstat metrics
454     - pmlogger: fix small race on exit condition
455     - timeval refactoring for improved double arithmetic
456     - python: drop support for versions older than 2.6
457     - python3: add pcp module support for 3.3 and newer
458     - build: workaround qmake handling of library paths
459     - Mac OSX build/install improvements
460     - pmwebd: support for more javascript demos (including
461       graphite/grafana - via separate pcp-webjs package)
462     - pmwebd: extend precision for floating point outputs
463     - pmwebd: Access-Control-Allow-Origin header additions
464     - pmwebd: experimental pthread support
465     - pmwebd: new options file configuration format
466     - pmmgr: avoid some granularity-edge races
468 pcp-3.9.10 (5 September 2014)
469     - Support for native systemd service files for daemons
470     - Support for nanosecond resolution event timestamps
471     - Changes to the FreeBSD build to bring it up to date
472     - libpcp: reduce daemon memory usage with secure sockets
473     - libpcp: add auto-deflate support for xz compression
474     - pmie/pmlogger scripts: xz compression support enabled
475     - pmie/pmlogger scripts: lzo compression support added
476     - pmlogconf: fix slow pmlogger_daily remote host startup
477     - pmcd_wait: fixed to handle af_unix sockets correctly
478     - pmatop: fix help keys
479     - pmatop: parse standard pcp options (including archives)
480     - pmstore: support for local-context mode of operation
481     - pmdiff: additional reporting options, added to /usr/bin
482     - pmdiff: fix column layout with custom precision setting
483     - pmlogsummary: fix time window reporting with -S and -T
484     - pmdapapi: new agent for PAPI hardware event counters
485     - pmdagfs2: latency metrics for glock grant/demote/queue
486     - pmdamysql: change metric semantics for "uptime"
487     - pmdaxfs: fix DSO mode and allow test data injection
488     - pmdammv: long option support
489     - docs: numerous updates to the online documentation
490     - docs: added a quick reference guide for Red Hat users
492 pcp-3.9.9 (13 August 2014)
493     - sar2pcp: support for systat version 10.2.0
494     - pmiostat(1): new monitor tool with iostat-alike output
495     - pcp-dmcache(1): new monitor tool for dm-cache devices
496     - pmdalinux: disk.dm.* metric hierarchiy (device mapper)
497     - pmdalinux: refine device mapper naming for old platforms
498     - pmdalinux: allow controlled data injection for QA tests
499     - pmdadmcache: new agent for device mapper cache targets
500     - pmdainfiniband: correctly initialise switch metrics
501     - libpcp: global timeout option for service discovery
502     - libpcp: __pmDiscoverServicesWithOptions() improvements
503     - libpcp: grok '%<interface' for link-local ipv6 addresses
504     - libpcp: derived metrics support for new rate() keyword
505     - python api: many convenience class module extensions
506     - python api: timeval accessor helper interfaces
507     - python api: pmUnitStr now uses thread-safe version
508     - python api: pmNumberStr_r now available from python
509     - python api: fix derived metrics interface exceptions
510     - pmlogconf: mark some log-default metrics as log-once
511     - dbpmda: use the correct (blocking) socket API variants
512     - pmlogger_daily: fix $PCP_RUN_DIR creation checks
514 pcp-3.9.8 (16 July 2014)
515     - Add overlooked Debian packaging metadata updates.
517 pcp-3.9.7 (16 July 2014)
518     - pmie: "ruleset" extensions to the pmie(1) language
519     - pmdaproc: additional memory and new blkio cgroup metrics
520     - pmdanvidia: new Nvidia GPU PMDA using NVML interfaces
521     - pmdainfiniband: add switch counter metrics
522     - pmdalustrecomm: bug fixes in the lnet memory metrics
523     - pmdamemcache: fixed underlying socket code
524     - pmdalinux: mem.util.available for down-rev kernels
525     - pmdagfs2: several fixes and improvements in behaviour
526     - pmdas: support for long form command line options
527       (aix, jbd2, linux, lustre, mounts, processes, sample,
528       sendmail, txmon, xfs)
529     - libpcp: 'timeout' option for 'probe' service discovery
530     - libpcp: secure sockets timeout handling improvements
531     - pmie examples: updates to the pmie tutorial docs
532     - pmchart: new MemAvailable view for mem.util.available
533     - porting: additional GNU/Hurd port updates
534     - packaging: fix Makepkgs script for old tar versions
535     - packaging: fix rpm builds for rpm versions prior to 4.6
536     - libpcp: use minimum required stack for discovery threads
537     - libpcp: archive folio parsing in option handling code
538     - python APIs: archive folio parsing for recording tools
539     - man pages: updates to service discovery APIs and tools
540     - libpcp: archive interpolation thread safety improvements
541     - libpcp: fixed memory leak from pmDestroyContext(3)
543 pcp-3.9.6 (19 June 2014)
544     - Fix pthreads build fallout for Solaris platforms
545     - Remove accidental /var/run/pcp install on Debian
546     - Rename configure.in to configure.ac as autoconf prefers
548 pcp-3.9.5 (18 June 2014)
549     - porting work on the GNU/Hurd platform
550     - porting work on Windows (early MinGW-64 work)
551     - pmdalinux: add in the new mem.util.available metric
552     - pmchart: new vCPU view, resolve guest time reporting
553     - pmwebd: add CORS "Access-Control-Allow-Origin: *" to
554       JSON response headers
555     - pmatop: improvements to value fitting
556     - packaging: gui debuginfo/testsuite correctly replaced
557     - pmconfig: moved install location for Solaris conflict
558     - pmstat: fix hostname reporting when in cluster mode
559     - Coverity scan fixes in libpcp, python, and elsewhere
560     - packaging: pcp-doc now contains all of the tutorial bits
561     - python: timeval/metricspec error handling improvements
562     - pmatop: handle curses problems more gracefully
563     - pmdapostfix: run as postfix user, not the pcp user
564     - python: fix pmParseInterval failure segfault
565     - python: fix segfault when printing empty units
566     - libpcp: functions for collecting server port numbers
567     - pmcd.services metric reflecting PCP daemon usage
568     - libpcp, pmfind: active service probing
569     - pmproxy, pmwebd: support for service discovery
570     - pmcollectl, pmatop: improved log writing support
571     - pmie: long option support
572     - pmquery: neater output formatting
573     - pmchart, pmtime: long option support
574     - pmdasystemd: install the built binary
575     - python: significant work on the pcp.pmcc module, adding
576       long option support, scale conversion, an initial fetch
577       loop method, and entirely new convenience classes
578     - pmlogcheck: fix bad memory access sigsegv on some logs
579     - Fix infinite loop in build scripts without Qt enabled
580     - pmdalinux: add metrics from /proc/net/netstat
581     - pmdumptext: long option support
582     - pmcollectl: support for sub-second sampling intervals
583     - Revive support for RHEL5-era builds, post pcp-gui merge
585 pcp-3.9.4 (15 May 2014)
586     - pmlogger: improved archive I/O features, esp for access to
587       archives while they are actively being written
588     - pmlogger/pmlc: all flushing operations are now no-ops, but
589       they remain available for backward compatibility
590     - pcp-free: use pmConvScale in case metric units ever change
591     - pmlogmv: fix a couple of argument handling corner cases
592     - another round of IPv6 updates throughout PCP, making use
593       of __pm* networking APIs instead of e.g. gethostbyname.
594     - archive utilities updated for long option support:
595       pmdumplog, pmlogcheck, pmlogextract, pmlogger, pmloglabel,
596       pmlogreduce, pmlogrewrite and pmlogsummary
597     - PMDAs with long option support:
598       pmdaapache, pmdabash, pmdagfs2, pmdasample, pmdasimple,
599       pmdatrivial
600     - libpcp: allow addition of free-form text to usage messages
601     - pmgetopt: new cross-platform long option handling utility,
602       allowing pcp shell scripts to acquire long option support
603     - shell scripts updated to support long options:
604       pcp, pmie2col, pmie_check, pmie_daily, pmlogger_check,
605       pmlogger_daily, pmlogger_merge, pmlogmv, pmnewlog, pmwtf,
606       pmsignal, pmlogconf
607     - pmlogger: improve pmlc access controls
608     - man pages: more detailed pmlc/pmlogger access control docs
609     - pmda systemd: adopt slow-start capability
610     - pcp command: improved error handling
611     - pmcollectl: correct reporting of disk and network details
612     - merged pcp-gui source tree (back) into pcp
614 pcp-3.9.2 (15 April 2014)
615     - python api: direct support for creating derived metrics
616     - python api: fix C strings memory leak in pmExtractValue
617     - python api: fix pmConvScale parameterization
618     - python api: pmLookupName API mode allowing partial failure
619     - python api: improvements to the pmErr exceptions class
620     - python api: support auto-command-line-parsing in scripts
621     - python api: switch to thread-safe pmGetContextHostname
622     - pcp: support for scripted pcp(1) child commands, adding in
623       pcp-free(1), pcp-uptime(1) and pcp-numastat(1) to get the
624       ball rolling (python scripts)
625     - pmlogmv: new utility to atomically move/rename archives
626     - pmconfig: improvements to quoting for unusual versions
627     - pmdaproc.sh: allow Install/Remove from any directory
628     - libpcp: pmgetopt_r interface for use by collector tools
629     - libpcp_pmda: slow-start PMDA changes
630     - libpcp_pmda: fix a memory leak dealing in dynamic metrics,
631       with PMDAs using the optional hashed metric table method.
632     - libpcp_pmda: long option command line processing interface
633     - libpcp_pmda: handle POSIXLY_CORRECT arguments internally
634     - pmcd: remove POSIXLY_CORRECT env modifications
635     - dbpmda: remove POSIXLY_CORRECT env modifications
636     - pmlogger_check: add a no-merging-renaming-rewriting option
637     - pmlogger_daily: don't merge archives if it is not needed
638       (optimization)
639     - perl pmda api: add documentation for PCP::PMDA interfaces
640     - pmdalinux: fix a memory leak in cpu:node name resolution
641     - pmmgr: fix daemon invocation quirk for some sh variants
642     - pmdarpm: improvements to concurrent rpmdb access
643     - pmdarpm: rpm.size metric now 64bit, matching rpmdb changes
644     - pmdaproc.sh: add $perl_args and $python_args
645     - long command line options support:
646       pmdamailq, pmns utilities, newhelp, pmcd, pmcd_wait, pmcpp,
647       pmdate, pmdbg, pmerr, pmhostname, pmieconf, collectl2pcp,
648       pmlc, pmmgr, pmproxy, pmwebd.
649     - Makepkgs changes to support source tarball builds via git
650     - HACKING file added, describing PCP development methodology
652 pcp-3.9.1 (19 March 2014)
653     - libpcp: extended date parsing with GNU getdate(3) strings
654     - libpcp: APIs for tools to share command-line options code
655     - libpcp: thread-safe API variant for pmGetContexHostName()
656     - libpcp: fix local:/unix: bug in __pmUnparseHostSpec
657     - Begin adding long option support to tools (pminfo, pmval,
658       pmprobe, pmstore, pmstat, pmclient so far)
659     - Fix python module bug for PMDAs without instance domains
660     - pmmgr: -march=i386 build fix
661     - pmlogger_daily: fix problem with pmproxy connections
662     - pmdagfs2: miscellaneous updates
663     - pmdanfsclient: new PMDA exporting NFS client metrics
664     - pmdazswap: new PMDA exporting compressed swap metrics
665     - testsuite: porting, several new tests, updates to existing
666       tests, resolved a couple of SELinux related problems
667     - Series of portability changes for *BSD platforms
669 pcp-3.9.0 (19 February 2014)
670     - Packaging changes for multilib pcp-libs{-devel},pcp-conf
671     - Packaging changes for pcp-manager and pcp-webapi split
672     - pmmgr: signal-response improvements
673     - pmmgr: add pmlogmerge-granular mode
674     - pmmgr: pmlogrewrite support
675     - pmmgr: latency-based tie-break for multi-URL target pmcds
676     - pmmgr.1 man page: outline archiving strategy tradeoffs
677     - pmdalinux: s390x platform issues in /proc/cpuinfo parser
678     - pmdalinux: valgrind fix for /proc/stat parser
679     - pmdagluster: improvements to multiple volume handling
680     - pmdagluster: support for additional file operations
681     - pmlogextract: <mark> record handling fix
682     - pmdas: further robustness improvements to dynamic names
683     - pmdas: Install scripts can run even when pmcd is stopped
684     - pmdanfsclient: add source code (not yet enabled in build),
685       thanks to Ben Myers
686     - pcp-archive.5 man page: new, documents on-disk log format
687     - pmdammv: fix sigsegv when no MMV tempdir is present
688     - pmclient: updated to match the Programmers Guide examples
689     - pmapi.py: fix python interface to pmLocaltime and pmCtime
690     - debian: use autotools-dev to update config.{sub,guess},
691       thanks to Logan Rosen
692     - pmdumplog: add a -x option for extended timestamp reports
693     - pmie: fix count_* operators with dynamic instance domains
694     - pmie: fix fetch logic with dynamic instance domains
695     - testsuite: ensure pcpqa account creation does not warn
696     - testsuite: numerous new tests, updates to existing tests
698 pcp-3.8.12 (29 January 2014)
699     - Fix recent (3.8.10) regression for certain platforms where
700       important PMNS files ended up not being installed.  Impact
701       is on new installs only, not upgrades (so my QA missed it).
702     - pmmgr: add -l (logfile) option to fix a permissions issue.
703     - pmdalinux: fix sigsegv on certain ICMP procfs file lines.
704     - Further improvements to pmlogger internal data structures
705       dealing with configuration files with duplicate metrics
706       and/or instances - improved in terms of network fetching,
707       as well as on-disk data layout (all backwards compatible).
708     - pmdarpm: added cumulative rpm.total.{count,bytes} metrics.
709     - Add man pages for all of the PMDAs currently missing one.
711 pcp-3.8.10 (15 January 2014)
712     - Adds pmmgr(1) PCP daemon manager - a cunning new (opt-in)
713       approach to managing farms of pmlogger and pmie processes.
714     - Adds pmfind(1) utility for discovering advertised pmcd
715       services (initially) on the network.
716     - Adds a new pmDiscoverServices(3) PMAPI routine.
717     - Linux pmda: plug memory leak in /proc/interrupts parsing.
718     - systemd pmda: add sd_journal_process() to avoid inotify()
719       driven spinning
720     - Man page rework for some NAME entries, addressing SGI oss
721       bugzilla #972)
722     - Add notes for creating user pcp before make from source,
723       addressing SGI oss bugzilla #1040)
724     - Improve behavior related to Avahi service name collisions.
725     - Dodge another hostname-does-not-resolve bullet in pmlogger.
726     - Fix the configure check for RHEL5 rpmlib for pmdarpm.
727     - An extensive series of spelling fixes to man pages, thanks
728       to Michele Baldessari
729     - Small fixes here and there from Coverity static analysis.
730     - GFS2 pmda: add the complete set of GFS2 tracepoint metrics.
731     - RPM pmda: make instance names unique, add rpm.name metric.
732     - RPM pmda: reduce number of inotify events and rpmdb scans.
733     - Add some heuristics to reduce metric duplication from tasks
734       formed via pmlogger configuration file blocks.
736 pcp-3.8.9 (12 December 2013)
737     - Fix pmdalinux stack blowout during ioctl() for network
738       interfaces.
739     - Add a generic string cache concept for PMDAs to use when
740       needing to perform string value de-duplication.
741     - Add a PMDA for the RPM Package Manager exporting package
742       metadata and state.
743     - Fix bug in pmlogextract handling time windows and metrics
744       with dynamic indoms.
745     - Allow the host part of the host spec to be enclosed with
746       square brackets - needed for IPv6 addresses in order to
747       separate the address from the port.
748     - Fix an Avahi and pmcd conflict when using multiple ports.
749     - Introduce shared library symbol versioning and hidden
750       attributes for all PCP libraries.
751     - Reduce internal API/ABI leakage in libpcp with respect to
752       endian code, locking code, and derived metrics.
753     - Bring the Solaris port back up to date with latest source.
754     - Tag temporary files created by qa tests with test prefix.
755     - Split PCP_TMP_DIR setting into its two distinct use-cases
756       removing the need to install world-writable-sticky-bit-set
757       directories.
758     - Add /proc/cpuinfo flags and cache_alignement fields (x86).
759     - Improvements to the hinv.cpu.model metric value we export.
760     - Ensure pmcpp does not accidentally #include directories.
761     - Better cleanup of uncompressed temporary files in libpcp.
762     - Correct pmdasystemd fd_set usage.
763     - Gracefully handle missing python curses module scenario.
764     - Improvements to pmstat error handling.
765     - Update pmcds config file parser - cleaner quotes handling.
766     - pcp.sh - change formatting for pmie and pmlogger details.
767     - Unknown Host fixups in libpcp __pmHostEnt code.
768     - Add a security philosophy section to PCPIntro(1) man page.
769     - Dodge wchan in Linux proc PMDA if procfs file not found.
770     - Add network.interface.hw_addr metric (exported from sysfs)
771     - Remove a nowadays-empty config directory from installation
772     - Resolve rpm upgrade warning from missing .NeedRebuild file
773     - Add pmdaproc option to skip access checking, for secure /
774       isolated environments.
775     - Make NSS use a stronger default cipher suite.
777 pcp-3.8.8 (3 November 2013)
778     - Dodge Debian build issues related to kfreebsd sys/sdt.h.
780 pcp-3.8.7 (3 November 2013)
781     - Resolve Debian build issues related to pkg-config/Avahi.
783 pcp-3.8.6 (1 November 2013)
784     - Added a new Linux JDB2 PMDA (ext3, ext4, ocfs journals).
785     - Added Linux kernel PMDA mem.util.directMap1G metric.
786     - Rework previous fix for Debian kfreebsd port wrt probes.
787     - Further work on Coverity scan issues, again nothing big.
788     - Further work on removing the hostname-as-DNS-entity, add
789       more use of pmGetContextHostName, more default-to-local:
790       tools.
791     - Initial support for DNS-SD via Avahi in pmcd for service
792       discovery.
793     - Change pcpqa to default to $PCP_VAR_DIR/testsuite as its
794       home directory.
796 pcp-3.8.5 (18 October 2013)
797     - Add jsdemos for the web API into the source tarball.
798     - Resolve Fedora/EPEL build issue for Infiniband PMDA.
799     - Resolve Debian build issue for kfreebsd probes.h
800     - Remove hostname checks in pmie/pmlogger script PID search.
801     - Much work on QA.  Zero test failures on release for RHEL6,
802       and there was much rejoicing.
803     - Many Coverity scan issues resolved, nothing major though.
804     - Ensure MMV PMDA entry exists in default pmcd.conf once more.
805     - Add Linux disk.partitions metrics to the default logged set.
806     - New hinv.nlv (logical volume count) metric into Linux PMDA.
807     - Update pmevent to use local: as the default mechanism.
808     - Numerous updates to the GFS2 PMDA.
809     - Reinstate a pmcd sigsegv fix, lost in an earlier merge.
810     - Fix handling multiple concurrent clients in pmdasystemd.
811     - Fix memory leak in pmNewContext failure path seen via pmie.
812     - Make default crontab install cooperate with runlevel settings.
813     - Add a privacy-protecting pmdasystemd uid/gid-filtering mode.
814     - Functional network.interface speed/duplex metrics on older
815       kernels (2.6.32 vintage and earlier, for example).
816     - Support for IPv6 address and scope metrics (ifconfig-style)
817     - Numerous updates to the pmatop utility.
818     - Updates to the PCPIntro(1) manual page.
819     - Improvements to the Linux per-process metrics values for any
820       threads being reported.
821     - Options for restricting Linux pmdaproc to a named cgroup.
822     - Update pmlogger to default to local: connection mode.
823     - Allow opt-out with the default-enabled xfs and proc PMDAs.
824     - Resolve a pmcollectl divide-by-zero (python stack trace).
825     - Fix recursive expansion of child cgroups in Linux pmdaproc.
826     - Fix a pmie core dump with archives, interp and mark records.
827     - Reduce memory footprint of Linux per-process metrics.
828     - Add proc.psinfo metrics for cgroups and security labels.
829     - Use local: connection by default in pmatop and pmcollectl.
830     - Update the python API wrapper to default to local: connection.
831     - Improvements to pmcollectl host name handling.
832     - pmGetContextHostName return to static char[] return value.
834 pcp-3.8.4 (15 September 2013)
835     - Allow numerous of the pmlogconf/tools templates to be probed
836       and enabled.  These are Linux tools, so we probe for (remote
837       possibly) Linux hosts only for these.
838     - Numerous QA test updates, resolving small amounts of fallout
839       from the previous release reported by Red Hat QE folks.
840     - Updates to the Samba PMDA.
841     - Improvements to the Debian build - remove Infiniband deps as
842       we're not attempting to build that anymore there (evidently,
843       poor cross platform support?  Can revisit if anyone needs it).
844     - Remove Debian dependence on deprecated sysv rc package.
845     - Resolve Debian packaging override disparities.
847 pcp-3.8.3 (9 September 2013)
848     - Split the XFS and XFS quota metrics into a separate PMDA
849     - Optional hash-based metric table lookups for PMDAs
850     - pmdagfs2: updates
851     - pmlogrewrite: add support for indom replication
852     - pmatop: Decrease screen real estate used for display.
853     - Fix the pmdabash shell version support validation code
854     - Add gluster PMDA into the build, really this time
855     - Add hinv.nnode metric to pmdalinux, mirroring the IRIX metric
856     - Add an option allowing custom pmcd.hostname settings
857     - Implement host access checking for unix domain sockets.
858     - Man page updates, esp. to pmcd.1 re access controls.
859     - Add static probe support for pmcd probes (systemtap/dtrace)
860     - Change pmGetContextHostName to be pmcd.hostname aware and thus
861       able to report the correct remote hostname through a tunnel.
862     - Update numerous tools to use pmGetContextHostName now.
863     - Demonstration programs for the MMV API
864     - Add pmdasystemd journal event count and total bytes metrics
865     - Use -fPIC over -fpic, resolving build issues on some platforms.
866     - Ensure Perl refcount bumped on PMDA.pm pmdacache stored variables
867     - Fix pmie/pmlogger control scripts - bad pmproxy handling
868     - Add a mechanism for packaging to avoid chown use, for Debian.
870 pcp-3.8.2 (31 July 2013)
871     - Support for the Unix domain socket transport between pmcd
872       and client tools, using the "unix:" host specifier (and the
873       more forgiving "local:" which falls back to localhost if no
874       platform support exists).
875     - Note: PCP_RUN_DIR is as a result now installed owned by the
876       "pcp" user and group (rather than as "root").  Several other
877       directories are also now installed "pcp"-owned too, after
878       (unrelated) pmie and changes described below.
879     - Support for automatic extraction of client tool credentials
880       with Unix domain sockets, and transfer to interested PMDAs,
881       on Linux, Mac OS X and Solaris.  IOWs, PMDAs now know which
882       user they are acting on behalf of for each connection, when
883       this class of socket is used.  In a future release, it hoped
884       to make this the default local connection style.
885     - Extensions to pmdaproc to allow it to perform access-control
886       checking and metric value fetches as the user requesting the
887       data, instead of as root, such that kernel-based permission
888       checking is now performed.
889     - Re-enabled pmdaproc by default on Linux.
890     - pmdagfs2: updates to metrics, tests and a new manual page.
891     - pmdagfs2: fixes for distributions without gfs2 trace-points.
892     - pmdalinux: fix hinv.map.lvname realink memory corruption bug.
893     - pmdalinux: fix issue where EPERM passed out as a fetch result
894       with inaccessible filesystem paths.
895     - pmdalinux: rework /proc/net/snmp metric extraction, added new
896       metrics from recent kernels (checksum error counters, icmpmsg).
897     - Linux PMDA SNMP metric type migration support (log rewriter).
898     - pmdasystemd: correct .maxmem metric to PM_SPACE_BYTE
899     - pmdasystemd: limit number of journald entries consumed per poll
900     - pmdamysql: additional status metrics suitable for pmie rules.
901     - pmdamysql: correct units and type for active connection count
902     - MySQL PMDA metric migration support (log rewriting rules).
903     - pmdagluster: new PMDA exporting gluster filesystem metrics,
904       in particular fs operation latency and brick throughput data.
905     - Fixes to the python pmda interface code to allow old python
906       versions as well.
907     - Extensions to python pmda interface to allow pmdaCache(3) use.
908     - pmwebapi: support more general pcp hostname specs, and
909       HTTP Basic authentication.
910     - Throttle the size of the pmatop hardware component display.
911     - Fix pmgui.py on big endian platforms (affects pmcollectl).
912     - Further progress on the log checking tool, pmlogcheck.
913     - Generate default pmlogger and pmie daemon configuration files.
914     - Migrated all static pmlogger configs over to pmlogconf format.
915     - Added pmlogconf config files for metrics used by iostat, ip,
916       mpstat, sar, vmstat.
917     - Install cisco PMDA pmieconf rules into the correct location.
918     - Install default crontab entries for pmlogger and pmie checking
919       and daily archive maintenance, on Linux, running as user "pcp"
920       now (previously, "root").
921     - pmlogconf scripts: added in automatic NFSv4 logging.
922     - pmlogger scripts: better locking between check and daily
923     - pmlogger control: add -r, -T and increase timeouts by default.
924     - Start a working primary pmlogger with a useful and extensible
925       set of metrics after enabling the service.
926     - Start a working pmie with a useful and extensible set of rules
927       after enabling the service.
928     - Assigned new PANASAS and NVML PMDA domain numbers.
929     - pmlogextract: fix minor bug for empty instance domains
930     - Resolve issue where clients get sigsegv from bad -h options.
931     - Updated pmwtf man page - better explanation for -q option
932     - Massive, massive QA efforts, much better support for non-x86.
933     - iostat2pcp - timestamp rework for European datetime formats.
934     - Fixed debian bugs related to broken library symlink.
935     - Ensure permissions on the NOTICES file allow pcp uid/gid access.
936     - Major updates to the SASL code allowing remote authentication
937       and improvements to username/password interaction process.
938     - Fix SASL related memory leaks, sort out authname mapping.
939     - Ensure SASL errors are easily identifiable as such (pmErrStr_r)
940     - User and groups access control list support in pmcd, augmenting
941       the existing host-based access control list support.
942     - Fix tempfile leak in pmdaproc.sh from accidental $tmp override.
943     - Improve the PCP experience with older versions of NSS (<=RHEL5)
944     - Introduce pmcd self-callstack-tracing capability for the Linux,
945       FreeBSD, and MacOSX platforms (maybe others, via backtrace(3)).
947 pcp-3.8.1 (19 June 2013)
948     - Add support for PMDAs written in python via pcp.pmda package.
949     - Example implementation of pmdasimple using python.
950     - Added new proc.{memory.vmswap,psinfo.threads} metrics.
951     - New collectl2pcp utility and sub-package (deb/rpm) for
952       converting historical data collected with collectl into the
953       PCP archive format for replay and analysis with PCP tools.
954     - Add missing help text for some Linux kernel hinv.map metrics
955     - Added new hinv.map.lvname metric for reverse mapping logical
956       device mapper names to physical device names.
957     - Added new hinv.ninterface metric (pmdalinux and collectl2pcp)
958     - Fixes to pmcollectl handling of PCP logs in archive mode.
959     - Allow pmcollectl metrics to be sourced from a remote host.
960     - Additional gfs2 metrics and tests, thanks to Paul Evans from
961       the gfs2 development team at Red Hat.  This makes use of the
962       gfs2 kernel glock event tracing to track hot locks, and also
963       provides a storable mechanism for enabling/disabling tracing
964       on-the-fly.
965     - Updated access control section of pmcd.1 with IPv6 details.
966     - Improve archive integrity checking from libpcp_import, ensure
967       monotonic increasing timestamps presented for single archive.
968     - Improvements to the log import perl API allowing for batched
969       updates (out-of-order), thanks to Marko Myllynen.
970     - Removed a low limit in the libpcp_import auto-PMID generation
971       scheme, now allowing millions of metrics instead of hundreds.
972     - Promote pmlogger and pmlogextract into the default PATH, with
973       backward-compatibility preserving symlinks in PCP_BINADM_DIR.
974     - Support for IPv6 socket communication in libpcp_pmda for pmcd
975       PMDA communication.
976     - Support for IPv6 socket communication testing via dbpmda.
977     - Update man pages to reflect IPv6 support in libpcp_pmda.
978     - Other improvements to the socket-based PMDA mechanisms.
979     - Fix a 64bit big-endian host issue in systemd.maxmem metric
980     - Mac OS X packaging tweaks.
982 pcp-3.8.0 (14 May 2013)
983     - Added the nginx PMDA, thanks to Ryan Doyle.
984     - Fixed memory leak on an error path in profile PDU decoder.
985     - Added pmwebd(1) - a JSON-based bridge providing web tools
986       with access to the PMAPI (both pmcd and archives) via HTTP.
987     - Initial support for client authentication via opt-in protocol
988       extensions, host specification extension, communication to
989       PMDAs via version 6 of the agent interface, dbpmda support.
990       Uses SASL2 as the underlying technology (which provides for
991       plugin-based extension to many authentication mechanisms).
992     - Reworked many aspects of the python APIs - now a pcp package
993       with sub-modules, improved error handling, and much more.
994     - Work toward pylint(1)-clean python code throughout PCP.
995     - Added a new python module for MMV instrumentation.
996     - Initial work on a python module for writing PMDAs.
997     - Added a new python module abstracting commonly needed metric
998       Subsystems, shared by pmatop(1) and pmcollectl(1).
999     - Added new python client tool - pmatop(1) - implementing much
1000       of the reporting functionality of atop (www.atoptool.nl).
1001     - Additional checks added to metric names allowed into the PCP
1002       Log Import library to match the PMNS man page requirements.
1003     - Support for parallel make invocations.
1004     - Improvements to the secure server code to make it work better
1005       and on more platforms.
1006     - Improvements to the IPv6 and IPv4 access control wildcards.
1007     - Migrate man pages from man4 to man5.
1008     - Resolve Fedora bug where the log import API was found to be
1009       allowing invalid metric names to be created.
1011 pcp-3.7.2 (19 April 2013)
1012     - Improved pmie propagation of metadata units.
1013     - Extra pmlogger diagnostic when log cannot be created.
1014     - Fix Debian python build dependencies.
1015     - Avoid mis-sharing outbound pmcd connections if ports do not
1016       match (libpcp).
1017     - IPv6 presence now checked at run-time as well (pmconfig).
1018     - Packaging updates - tarball, slackware, gentoo.
1019     - Add several missing man page options, typos and such, found
1020       by Red Hat (internal?) checker tools.
1021     - Added pmwtf.1 man page.
1022     - Make pmdaapache observe a connect timeout as well as its
1023       existing request timeout.
1024     - Extend pmcd access control with a global wildcard for IPv6.
1025     - Make __pmSockAddrIsLoopBack handle IPv6 loopback address.
1026     - Resolve bug in too-small pduread recv causing communication
1027       failures with secure sockets, but in theory affecting other
1028       socket transports as well.
1029     - Resolve Debian packaging and build dependency issue.
1030     - Resolve Fedora bug where pmstat fails to start when pmcd has
1031       never been started (so namespace rebuild script not yet run).
1033 pcp-3.7.1 (20 March 2013)
1034     - IPv6 addresses and wild cards for host access control.
1035     - Add packaging scripts to correctly transition active temp
1036       file directories from their old locations.
1037     - Resolve a warning from rpm %pre script on new installs.
1038     - Convert pmhostname(1) to use the newer networking APIs.
1039     - Convert pmproxy(1) to use the newer networking APIs.
1040     - Correct the pmlogger heuristics for determining whether it
1041       is running as a daemon for *both* pmlogger_{daily,check}.
1042     - Add script to handle the tmpdir transition such that folks
1043       with running parfait/mmv-instrumented applications continue
1044       to see data exported, and for correct pmlogger/pmie daemon
1045       tracking across releases.
1046     - Fix "Warning: __pmConnectRestoreFlags: cannot restore flags"
1047       messages when built with secure-sockets option disabled.
1049 pcp-3.7.0 (11 March 2013)
1050     - Added hash table iterator interfaces to libpcp.
1051     - Added PCP_SYSCONF_DIR, migrated daemon configuration there.
1052     - Fix Linux swap metrics problems, thanks to Martins Innus.
1053     - Support for IPv6 and revamped networking (libpcp-internal)
1054       APIs, in particular making proper use of getaddrinfo now.
1055     - Initial version of the NetBSD port
1056     - Secure connections are now available and documented.
1057     - Added a PCP_USER setting for globally changing the default
1058       unprivileged user account used by PCP daemons.
1059     - Resolved Debian packaging issues from previous release to
1060       do with the pcp-python subpackage.
1061     - Improve pmdaapache fetch implementation (reduced overhead)
1062     - Close up a file descriptor leak on a pmdaapache error path,
1063       thanks to Ryan Doyle.
1064     - Added the gfs2 PMDA.
1065     - Added the systemd PMDA.
1066     - Alignment issues on ia64 resolved.
1067     - Create pmlogger and pmie logdirs during install.
1068     - Added -L option to pmconfig(1) for reporting libpcp options.
1069     - Further workarounds for sar/sadf XML exporting problems.
1070     - Updates to MinGW PCP builds for native PCP on Windows.
1071     - Use initgroups() to correctly set up supplementary groups in
1072       PCP daemons that are changing user/group from root/root.
1073     - Fix memory leak on scandir failure in several PMDAs.
1074     - Correctly install the pcp user/group during Mac OS X upgrade
1075     - Allow pmdalogger to be installed on multiple platforms
1076     - Series of updates to pmie to improve action %h, %v and %i
1077       substitutions (amongst other pmie improvements and several
1078       corner-case fixes)
1079     - MySQL PMDA now re-connects after a database server re-start.
1080     - Workaround versioning issues between python and rpmbuild.
1081     - Ensure HZ is initialised in Linux proc PMDA, fixing a small
1082       regression from the earlier proc/linux PMDA split.
1083     - Fix -p option to pcp(1) command reporting pmie instances.
1084     - Add one-line help for the proc metrics that did not have it.
1085     - Change primary pmlogger control from symlink to link.
1086     - Add an interface allowing PMAPI clients to explicitly cleanup
1087       (which allows for improved accuracy in valgrind reporting).
1088     - Fix race conditions in pmie and pmlogger startup scripts.
1089     - Updates to the named (name server) PMDA.
1090     - Change __pmSetProcessIdentity to fail more resoundingly.
1091     - Fix issues with pmdashping timeouts observed on multi-core
1092       x86_64 machines related to signals interacting with pthreads.
1093     - Move debian tmpdir settings to match other distros.
1095 pcp-3.6.10 (19 November 2012)
1096     - Transition daemons to run under an unprivileged account.
1097     - Fixes for security advisory CVE-2012-5530: tmpfile flaws.
1098     - Fix pcp(1) command short-form pmlogger reporting.
1099     - Fix pmdalogger error handling for directory files.
1100     - Fix pmstat handling of odd corner case in CPU metrics.
1101     - Correct the python ctype used for pmAtomValue 32bit ints.
1102     - Add missing RPM spec dependency for python-ctypes.
1103     - Corrections to pmdamysql metrics units.
1104     - Add pmdamysql slave status metrics.
1105     - Improve pmcollectl error messages.
1106     - Parameterize pmcollectl CPU counts in interrupt subsys.
1107     - Fix generic RPM packaging for powerpc builds.
1108     - Fix python API use of reentrant libpcp string routines.
1109     - Python code backporting for RHEL5 in qa and pmcollectl.
1110     - Fix edge cases in capturing interrupt error counts.
1112 pcp-3.6.9 (12 October 2012)
1113     - Python wrapper for the pmimport API
1114     - Make sar2pcp work with the sysstat versions from RHEL5,
1115       RHEL6, and all recent Fedora versions (which is almost
1116       all current versions of sysstat verified).
1117     - Added a number of additional metrics into the importer
1118       for people starting to use it to analyse sar data from
1119       real customer incidents.
1120     - Rework use of C99 "restrict" keyword in pmdalogger
1121       (Debian bug: 689552)
1122     - Alot of work on the PCP QA suite, special thanks to Tomas
1123       Dohnalek for all his efforts there.
1124     - Win32 build updates
1125     - Add "raw" disk active metrics so that existing tools like
1126       iostat can be emulated
1127     - Allow sar2pcp to accept XML input directly (.xml suffix),
1128       allowing it to not have to run on the same platform as the
1129       sadc/sadf that originally generated it.
1130     - Add PMI error codes into the PCP::LogImport perl module.
1131     - Fix a typo in pmiUnits man page synopsis section
1132     - Resolve pmdalinux ordering issue in NUMA/CPU indom setup
1133       (Redhat bug: 858384)
1134     - Remove unused pmcollectl imports (Redhat bug: 863210)
1135     - Allow event traces to be used in libpcp interpolate mode
1137 pcp-3.6.8 (14 September 2012)
1138     - Corrects the disk/partition identification for the MMC
1139       driver, which makes disk indom handling correct on the
1140       Raspberry Pi (http://www.raspberrypi.org/)
1141     - Several minor/basic fixes for pmdaoracle.
1142     - Improve pmcollectl compatibility.
1143     - Make a few clarifications to pmcollectl.1.
1144     - Improve python API test coverage.
1145     - Numerous updates to the test suite in general.
1146     - Allow pmda Install scripts to specify own dso name again.
1147     - Reconcile spec file differences between PCP flavours.
1148     - Fix handling of multiple contexts with a remote namespace.
1149     - Core socket interface abstractions to support NSS (later).
1150     - Fix man page SYNOPSIS section for pmUnpackEventRecords.
1151     - Add --disable-shared build option for static builds.
1153 pcp-3.6.6 (28 August 2012)
1154     - Added the python PMAPI bindings and an initial python client
1155       in pmcollectl.  Separate, new package exists for python libs
1156       for those platforms that split out packages (rpm, deb).
1157     - Added a pcp-testsuite package for those platforms that might
1158       want this (rpm, deb again, mainly)
1159     - Re-introduced the pcp/qa subdirectory in pcp and deprecated
1160       the external pcpqa git tree.
1161     - Fix potential buffer overflow in pmlogger host name handling.
1162     - Reworked the configure --prefix handling to be more like the
1163       rest of the open source world.
1164     - Ensure the __pmDecodeText ident parameter is always set
1165       Resolves Red Hat bugzilla bug #841306.
1167 pcp-3.6.5 (16 August 2012)
1168     - Fixes for security advisory CVE-2012-3418
1169         o Add field validation to PCP instance PDU (Red Hat #841240)
1170         o Fix __pmDecodeInstanceReq heap buffer overflow (Red Hat #841284)
1171         o Fix __pmDecodeText heap overflow (Red Hat #841249)
1172         o Multiple issues in result PDU decoding (Red Hat #841159)
1173         o Fix __pmDecodeNameReq buffer overflow (Red Hat #841180)
1174         o Add length checks to __pmDecodeLogControl (Red Hat #841290)
1175         o Add size check to __pmDecodeIDList (Red Hat #841112)
1176         o Fix __pmDecodeNameList buffer overflow (Red Hat #840920)
1177         o Add missing __pmDecodeFetch namelen checks (Red Hat #841183)
1178         o Add length checks to __pmDecodeProfile (Red Hat #841126)
1179         o Add length checks to __pmDecodeCreds (Red Hat #840822)
1180     - Workaround for security advisory CVE-2012-3419
1181         o Split the Linux kernel and proc PMDAs to prevent information
1182           leakage in default installs - esp. /proc/pid/maps exposure,
1183           but other proc metrics as well - and no longer export process
1184           metrics by default (Red Hat #841702)
1185     - Fixes for security advisory CVE-2012-3420
1186         o Memory leak in pmcd DoFetch error path (Red Hat #841298)
1187         o Memory leak in __pmGetPDU in-band signalling (Red Hat #841319)
1188     - Fixes for security advisory CVE-2012-3421
1189         o Resolve event-driven programming flaw in pmcd (Red Hat #841706)
1190     - Correct buffer unpinning logic in a PMNS traversal error path
1191         o Red Hat bugzilla bug #847314.
1192     - All of the above issues were identified by Florian Weimer of the
1193       Red Hat Security Team, who also assisted extensively in fixing
1194       and testing; a huge thank you to Florian from all PCP developers
1195       and users!
1196     - Add modern gcc/glibc security protection mechanisms where
1197       available.  Thanks to the Frank Eigler.
1198     - Harden all boundary checking in the remaining PDU decoders.
1199     - Resolve an issue with configure script checking for the init(1)
1200       process on Fedora 17 (and other systems using systemd).  Thanks
1201       to Lukas Berk.
1202     - pmdaelasticsearch only reports on nodes in the cluster now,
1203       and not other client nodes.  Thanks to Nigel Donaldson.
1204     - Added interfaces to PCP::PMDA Perl module to allow PMDAs to
1205       use a hash instance domain (instead of int/string array).
1206       These make use of the pmdaCacheOp(3) interfaces - the hash
1207       keys are the (external) PCP instance names, and the value
1208       associated with each key is an opaque reference.
1209     - Added an interface to allow PMDAs to register event queues
1210       with existing clients (pmdaEventNewActiveQueue).
1211     - Initial version of the (experimental) bash tracing PMDA.
1213 pcp-3.6.4 (12 June 2012)
1214     - Fix build on s390x platform (thanks to Dan Horak)
1215     - Rethink order of PATH setting for pcp start scripts, to ensure
1216       binaries from other packages with names that conflict with pcp
1217       binaries are not found ahead of the same-named pcp binary.
1219 pcp-3.6.3 (27 April 2012)
1220     - Revert initial attempt at getting configure --prefix option to
1221       make sense for local developer PCP installations
1222     - Fix RPM changelog typo in in-tree spec file
1223     - Further work on Debian/kFreeBSD port (thanks to Robert Millan)
1225 pcp-3.6.2 (18 April 2012)
1226     - Fix Debian builds on FreeBSD (missing header files)
1227     - Resolve Debian startup script (compat) lintian issue
1228     - Resolve FreeBSD kernel PMDA build issue with PCP not installed
1229       in the build root already.
1231 pcp-3.6.1 (12 April 2012)
1232     - Resolve final Mac OS X pthreads build issues
1233     - Debian packaging improvements for split pmlogger/pmcd scripts,
1234       perl module pieces, and other lintian reported issues
1235     - Update the startup script dependencies for /var use
1236     - Support --prefix=... and --exec-prefix=... configure options
1237     - Relaxed the "are you running as root?" test in startup scripts
1238     - Win32 build updates and improvements
1239     - Cache /proc/stat file handle in Linux kernel agent to reduce
1240       syscalls on the most commonly fetched metric subtree
1242 pcp-3.6.0 (21 March 2012)
1243     - Thread-safe libpcp, including additional re-entrant and thread-safe
1244       variants for some routines
1245     - Retire all asynchronous routines from libpcp
1246     - Retire all V1 protocols and services (archive format, PMAPI and
1247       PMDA_INTERFACE)
1248     - PMNS moves to ASCII only (no binary PMNS)
1249     - Rework "init" scripts, splitting pcp into pmcd and pmlogger
1250     - Update elasticsearch PMDA to 0.19+, new transport and shard metrics
1251     - Updates to PMDA new event queueing interfaces for agents wishing to
1252       export that class of performance data.
1253     - First round of Coverity cleanup fixes incorporated.
1254     - Initial version of the SNMP PMDA, thanks to Hamish Coleman.
1255     - Updates to postgres PMDA to export additional recovery metrics.
1257 pcp-3.5.11 (01 December 2011)
1258     - Update FSF contact address in copyright notices to keep
1259       rpmlint happy.
1260     - Fix instance domain checks in elasticsearch PMDA.
1261     - Make KVM PMDA to run as root once more (permissions issues).
1262     - Integration of pmlogger_daily with pmlogrewrite.
1263     - Fix pmlogger_merge corner case for empty archives.
1265 pcp-3.5.10 (04 November 2011)
1266     - Support new 0.18+ elasticsearch metrics.
1267     - Fix handling of elasticsearch version metric cluster.
1268     - Fix trace PMDA build issues.
1269     - Fix some Win32 build issues.
1270     - Run with reduced privileges for more of the perl PMDAs.
1271     - Name Solaris load average metric consistently.
1272     - Small metric documentation tweaks for Solaris PMDA.
1274 pcp-3.5.9 (23 October 2011)
1275     - Add rc script support for condrestart, and condrestart the pcp,
1276       pmie and pmproxy services after an RPM install or upgrade.
1277     - Fix a bug where hinv.ndisk is incorrect if CLUSTER_PARTITIONS
1278       hasn't yet been refreshed immediately following a restart.
1279     - Implementation of client event queueing logic for all PMDAs to
1280       share (all PMDAs wishing to support event metrics, that is).
1281     - New manual pages for new PMDA event queueing interfaces.
1282     - PostgreSQL PMDA, supporting versions 9.0 and 9.1 (at least).
1283     - Reserved ID 111 for Samba Clustered Trivial Database PMDA.
1284     - Add perl interface to allow PMDAs to drop priveleges
1285     - Add an elasticsearch version metric.
1286     - Correct perl module type detection logic for 32/64-bit systems.
1287     - Small pmlogconf source and man page fixes.
1288     - Rework flex usage to resolve build warnings.
1289     - Make Darwin CPU metrics 64 bit.
1290     - Add (long) opaque key support to libpcp_pmda.
1291     - Add pmdaCacheStoreInst() routine to libpcp_pmda.
1292     - Added mssql PMDA for SQL server Dynamic Management View stats.
1293     - Add pmlogrewrite(1) to rewrite archives (fix inconsistencies).
1294     - Fix a cgroup option parsing error on consecutive fetch calls.
1296 pcp-3.5.8 (08 August 2011)
1297     - Rework rsyslog PMDA to remove Switch use, very odd behaviour
1298       observed on RHEL5.2 (mysteriously failing to compile).
1299     - Add in Kens scripting defenses against dodgey toolchains.
1301 pcp-3.5.7 (05 August 2011)
1302     - Fix build issue on SLES11 SP1 IA64 systems.
1303     - Improved rsyslog PMDA handling of queue metrics.
1304     - Add open file-descriptor count metric to the Linux PMDA.
1305     - Implement logger PMDA line-oriented event mode.
1306     - Add regular expression based event filtering in logger PMDA.
1307     - The default pmcd.conf now has an access control section, and
1308       all remote store operations are blocked by default.
1309     - Improve packaging of Perl components.
1311 pcp-3.5.6 (21 July 2011)
1312     - Fix warning from pmie_daily with some /bin/pwd versions.
1313     - Numerous Debian packaging updates for lintian cleanliness.
1314     - Fixed typos in several man pages.
1315     - Added ElasticSearch PMDA.
1316     - Fix build on RHEL4 with older sys/queue.h variant.
1318 pcp-3.5.5 (6 July 2011)
1319     - Resolve Debian packaging issues preventing new uploads.
1320     - Fix warnings from pmie_check with some /bin/pwd versions.
1322 pcp-3.5.4 (6 July 2011)
1323     - Fix warnings from pmlogger_check with some /bin/pwd versions.
1325 pcp-3.5.3 (6 July 2011)
1326     - Remove reliance on a cpp binary being installed locally with
1327       new pmcpp applicaton.
1328     - Ensure compressed pmie log files are also cleaned up daily.
1329     - Extend the event store mechanism to be more generally useful.
1330     - Add memory limiting functionality to pmdalogger.
1331     - Add SQLServer metric for user settable queries.
1332     - Fix potential sigsegv in pmprobe fetching multiple live values.
1333     - Perl changes for Solaris.
1334     - Fix Fedora15 build relating to handling of systemd.
1335     - Solaris pmda zpool_vdev_name() api change.
1336     - Update sar2pcp for sysstat version 9.1.7.
1337     - Resolve realloc issue in event metric handling in libpcp_pmda.
1339 pcp-3.5.2 (3 June 2011)
1340     - pmlogreduce - fix 2 problems (memory leak, additional mark records)
1341     - Initial version of pmdalogger, from David Smith, a log monitoring
1342       PMDA exporting event metrics.
1343     - Make Windows drive instance domain code less chatty.
1344     - RC scripts and pmie_check - Mac OS X porting
1345     - pmlogger_check - symbolic link issue fixed
1346     - Add in the rsyslog PMDA (http://www.rsyslog.com)
1347     - Extend PCP::PMDA so that the log tail mode can be used on named papes.
1348     - Numerous updates to the Perl packaging infrastructure
1349     - Fix build when $HOME is not set.
1350     - pmlogconf - another non-posix awk issue fixed
1351     - Darwin pmda - filesys.maxfiles metric
1352     - pmie_daily - assorted minor fixups
1353     - Unix domain socket issue found on Mac OS X
1354     - pmcd config parsing error handling cleanup
1355     - Quieten pmevent output in the absence of new events.
1356     - Pass process ID out on success of __pmProcessCreate.
1357     - pmdaproc.sh - add PMDA_INTERFACE_5 support
1358     - pcp_completion.sh - add pmevent for bash metic completion
1359     - pmevent - add instance domain support
1360     - Bugfix: fetching hinv.cpu.* aborts if cpu indom is not initialized
1361     - Rearrange the per-CPU intr metrics on Linux to use dynamic namespace
1362     - Add perl modules into Mac OS X installations
1363     - Additional vmstat metrics added to Linux kernel PMDA
1364     - Fix pmieconf after syscall metrics went away on Linux
1365     - pmevent - new util to report event records, with instance domain support
1366     - sample PMDA - instance domain for event records metric
1367     - pmval, pminfo - man page typo corrections
1368     - pmval - fix typo in error message
1369     - pmlogextract, pmlogreduce - auto volume switch at 2^31 bytes
1370     - pmnscomp - defaults to Version 2 of the compiled PMNS
1371     - Remove unconditional diagnostic in MMV agent, log spam
1372     - Rework the code that uncompresses archives for Win32
1373     - Updates to Win32 makefiles to get a clean package build
1374     - Enable compressed log processing for Windows as well
1375     - Sample event consumer code for Windows ETW
1376     - Update PDH Win32 headers to use those from current mingw-m64 tree
1377     - Win32 socket error messages are reporting correctly
1378     - Great strides in getting error reporting correct on Windows
1379     - Add Win32 pthread wrapper for threading work on Windows
1380     - Add PowerDNS recursor stats to the pdns PMDA
1382 pcp-3.5.0 (31 January 2011)
1383     - Infrastucture support for doing distributed event tracing with PCP.
1384       This includes a new metric type (PM_TYPE_EVENT), cunning mechanisms
1385       for encoding event records in pmResults, and providing PMDAs with
1386       per-client context connection information allowing agents to track
1387       which clients have seen which parts of a trace stream so far.  Some
1388       reference uses of these extensions can be seen in pmdasample and in
1389       the pmcd PMDA as well.
1390     - Transparent support for archive de-compression by clients.
1391     - Manual page formatting errors corrected.
1392     - Fix a pmDupContext memory corruption issue seen with derived metrics.
1393     - Added a one-trip optimisation/guard to pcp.env
1394     - Improved pmdaFetch and pmdaFetchCallback man pages with respect to
1395       return codes and value memory allocation models.
1396     - Fix for Windows unintentionally allowing multiple pmcd processes
1397       to startup and bind to the same port, with "undefined" results.
1398     - Fix Windows services interaction, preventing pmcd service stop.
1399     - Fix Mac OS X scandir memory leak on empty directories.
1400     - Fix Mac OS X mem.util.wired metric, was exporting the wrong value.
1401     - Correct the handling of SLES11 distro identification (lsb-release
1402       file not used again, on SuSE Linux distributions).
1403     - Fix postfix PMDA log file path handling for Redhat Linux distros.
1404     - Extend Perl PMDA interfaces to allow additional metrics to be
1405       added at runtime (now makes use of dynamic namespace support).
1406     - Set KEEPALIVE option on pmproxy client sockets, mirroring pmcd
1407       behaviour and reducing open file descriptor pressure.
1408     - Improvements to the native Windows version of pmlogger, preventing
1409       it from exiting prematurely thanks to a socket read race condition.
1410     - Fix /proc/interrupts parser in Linux PMDA, thanks to Arthur Kepner.
1412 pcp-3.4.1 (9 October 2010)
1413     - Remove bogus (expected) errors/warnings from Win32 install/remove.
1414     - Remove couple of no longer needed local Win32 API wrappers.
1415     - Fix rindex code for Win32 so it handles empty strings.
1417 pcp-3.4.0 (29 September 2010)
1418     - Add new libpcp_import C API library to pcp-libs.
1419     - Add perl-PCP-LogImport RPM sub-package for libpcp_import perl binding.
1420     - Add pcp-import-* RPM sub-packages containing front-end tools for
1421       importing data from sar, iostat, generic speadsheets and mrtg.
1422     - Major Solaris PMDA updates: CPUs, vnode ops, disk stats and disk queue
1423       stats, switch to using pmid clusters, internal timers, ZFS Adjustable
1424       Replacement Cache stats, new help text, memory metrics, fsflush stats.
1425     - Use Solaris devinfo to get information about pretty disk names.
1426     - Fix a memory leak in Perl PMDA wrapper string handling.
1427     - Use correct structure to extrace zpool write counters in Solaris PMDA.
1428     - pmafm now supports multiple -a arguments.
1429     - Fix pmie multiple -a options bug.
1430     - Fix pmdaInit() callback handling where it did not handle all the
1431       interface versions correctly.
1432     - Quote filenames reported by pmwtf, else awk can get confused.
1433     - Fix pmdawindows missing metrics help text.
1434     - Add network interface speed metrics into pmdawindows.
1435     - Fix pmdalinux handling of long network interface names.
1436     - Updated pmdaapache to use cross-platform http library.
1437     - Updated pmdaapache install process to allow port selection.
1439 pcp-3.3.3 (16 July 2010)
1440     - Fix two off-by-one errors in NUMA metrics in Linux PMDA.
1441     - Rework timezone environment variable handling to be able to
1442       coexist more peacefully with Perl.
1443     - Remove Fedora specfile now that this is in Fedora CVS.
1445 pcp-3.3.2 (10 July 2010)
1446     - Fix FreeBSD build and packaging issues affecting Debian.
1447     - Move PCP::Glider Perl code into core PCP with other Perl modules.
1448     - Avoid a mingw64-compiler-runtime bug in gettimeofday.
1449     - Fix spec file issue in Fedora/RHEL builds.
1450     - Add in the gpsd PMDA.
1452 pcp-3.3.1 (29 June 2010)
1453     - Fix a sigsegv in pmdalinux in the kernel.pernode.cpu metrics.
1454     - Don't kill dbpmda if namespace cannot be loaded.
1455     - Resolve a Windows build error under latest toolchain.
1456     - Some minor pmieconf and pmimport related cleanups.
1458 pcp-3.3.0 (25 June 2010)
1459     - Rework pmlogconf utility - version 2.0 ondisk format.
1460     - Initial support for Linux kernel cgroup subsystem, using dynamic
1461       metrics (cpu sets, cpu sched, cpu acct, memory, ...)
1462     - Fix per-process I/O (proc.io.*) metric values.
1463     - Fix potential SEGV in derived metrics when pmcd connection lost.
1464     - Fix to allow pmlogger to log derived metrics.
1465     - Fix open file descriptor leak in Linux disk scheduler code.
1466     - Postfix PMDA updated to report aggregate stats from mail.log parsing.
1467     - Add per-node CPU metrics to Linux kernel agent.
1468     - Integrate pmieconf into the build, modernisation and porting work.
1469     - Add install-sh to the set of pcp-internal programs for external code.
1470     - Improved checking of PMDA domain numbers.
1471     - Allow use of SunStudio compiler on Solaris.
1472     - Add load average metrics to Solaris kernel agent.
1473     - Windows 7 porting work.
1474     - Make Win32 build work with more recent versions of gcc and Perl.
1475     - Fix pmie [no]match_inst botch, tweak sleepTight reporting.
1476     - Allow \$ for pmie regular expressions.
1477     - Ensure pmlogger doesn't write extended pmcd host syntax as hostname.
1478     - Switch over to not using local context for bash completion.
1479     - Improve Lustre agent metric help text.
1480     - Added a readonly filesystems metric into Linux kernel agent.
1481     - Ensure xfs.buffer metrics are always properly refreshed.
1482     - Add Linux kernel statistics related to XFS btree operations.
1484 pcp-3.2.1 (3 May 2010)
1485     - Export information about ZFS snapshots
1486     - Correct accounting of PMNS size in a libpcp_pmda helper routine.
1488 pcp-3.2.0 (29 April 2010)
1489     - Change how PM_CONTEXT_LOCAL determines available PMDAs:
1490       rework local context code to retire $PMDA_LOCAL_*, build DSO table
1491       from pmcd.conf at run-time, new __pmLocalPMDA and __pmSpecLocalPMDA
1492       routines in libpcp, -K options for pminfo, pmval and pmprobe.
1493     - Make some pmda dynamic name operations take (const char *) args.
1494     - Fix bash completion so dynamic names expanded, and stderr culled
1495       (culling DSO agent initialisation messages).
1496     - Improve pmlogger handling of alias names (same PMID, different names).
1497     - Honour the -T command line option in pmlogreduce.
1498     - Resolve an MMV issue evident in the Mac OS X installer, which resulted
1499       in failed dmg (binary) installation attempts.
1500     - Solaris startup script improvements.
1501     - Add details of the extended hostname syntax to pcpintro(1).
1502     - Fix a memory leak in pmdawindows help text handling.
1503     - Fix a memory leak in pmdammv help text handling.
1504     - Add anonymous huge page Linux memory utilisation metric.
1505     - Fix local context reporting of help text.
1506     - Solaris man page build changes.
1507     - Clean up diagnostic messages in pmlogextract.
1508     - Teach pmdaproc about Solaris' ping.
1509     - If pmstat fails to connect to local pmcd, fallback to local context.
1510     - Mark as const the final (requested units) pmConvScale argument
1511     - Clean out SGI-isms from build related files (no longer used by SGI).
1512     - Fix mem.numa.util.NFS_Unstable metric.
1513     - Removed pmdajstat, this has long been superceded by the capabilities
1514       of the Parfait package for instrumenting Java applications with PCP.
1516 pcp-3.1.2 (22 March 2010)
1517     - Add indom save and restore logic into Windows PMDA.
1518     - Fix a typo in the Postfix PMDA.
1519     - Update and extend /proc/meminfo stats on Linux.
1520     - Improve handling of monitored process in pmdammv, especially
1521       when the monitored process exits (pmns not cleaned up before).
1523 pcp-3.1.1 (23 February 2010)
1524     - Use a better MMV generation number, using all bits available.
1525     - Fix a metric count calculation error in pmdammv.
1526     - Add precision argument (-p) to pmwtf.
1527     - Added an open socket sockname command to dbpmda.
1528     - Remove use of grep -q, unavailable on OpenSolaris.
1529     - Couple of trivial build fixes for the Win32 platform.
1531 pcp-3.1.0 (28 January 2010)
1532     - Derived metric support.
1533     - Fix a memory leak in the Solaris kernel PMDA.
1534     - Extract information about network links on Solaris.
1535     - MMV PMDA (DSO) is now installed and enabled by default.
1536     - Reintroduced MMV support for cross-(mmap-)file instances.
1537     - Bug fix in pmdammv which was capable of causing SIGSEGV.
1538     - Add dbpmda readline support (and packaging dependencies).
1539     - Add in -Z option to pmwtf, to pass through to pmlogsummary.
1540     - Export NUMA memory statistics from the linux kernel.
1541     - Make pmie_check work on Solaris.
1542     - Make perdisk stats part of the zpool hierarchy.
1543     - dbpmda fix for name lookup and dynamic metrics.
1544     - Add a new PMDA exporting the Postfix queue lengths.
1545     - BuildRequires initscripts for %{_vendor} == redhat.
1547 pcp-3.0.2 (2 December 2009)
1548     - Improvements and fixes to PCP::PMDA perl module.
1549     - Added the SQL Server dtsrun log file parser PMDA.
1550     - Switch MMV PMDA to use dynamic namespace interfaces, which resolves
1551       long-standing spurious EAGAIN error on reconfiguration.
1552     - Separate out the Infiniband and cluster PMDAs into their own
1553       package - removing dependencies and configure complexities from
1554       pcp into specialised, layered packages.
1555     - Configure packaging to use libexecdir for private pcp binaries,
1556       if supported on the platform (also honour --libexecdir configure flag)
1557     - Add sysfs.kernel metrics cluster to Linux PMDA.
1559 pcp-3.0.1 (19 October 2009)
1560     - Reverted rc scripts default start/stop settings back to how
1561       it was in 2.9.3-1, for Debian bug #544350. On Red Hat platforms,
1562       the RPM spec overrides this to be chkconfig off by default.
1563     - Lexical analyser tweaks (various tools) to work on Windows.
1564     - pmlogextract change timezone selection algorithm, add -f for old behaviour
1565     - configure.in clean up more thoroughly on Mac OS X
1566     - Get pcp building on Debian GNU/kFreeBSD port.
1567     - Add missing return statement causing incorrect mem.util on Win32.
1568     - Improved support for Slackware distro makepkg packaging
1569     - Solaris fixes: pass information about compiler into Perl PMDA makefiles,
1570       don't change pointer types of pmCtime's arguments, deal with default lex
1571     - Move Infiniband and Cluster PMDAs to a stand-alone packages
1572     - Trim the set of RPM files marked as %config to just those
1573       that are actually likely to be edited (rpm -qlcv pcp pcp-libs).
1575 pcp-3.0.0 (9 October 2009)
1576     - PMDA_INTERFACE_4 and the support of dynamic subtrees of the PMNS
1577       where the PMDA (not PMCD) maintains knowledge of the PMNS.
1578     - RPM packaging split into pcp, pcp-libs and pcp-libs-devel
1579       pcp-libs is common - it's required by pcp and by pcp-libs-devel but
1580       pcp and pcp-libs-devel can be installed with or without each other.
1581     - Added separate specific licenses for the new subpackages,
1582       particularly pcp-libs, which is LGPL.
1583     - Added ldconfig %post and %postun scriptlets for -libs
1584     - Don't explicitly require Infiniband libs, since they're libs and RPM
1585       figures it out
1586     - No need to explicitly BuildRequire gcc-c++ libstdc++-devel
1587     - Add BuildRequires on perl-ExtUtils-MakeMaker
1588     - Remove explicit ia64 Requires: libunwind
1589     - Preserve generated gram.tab.c in several places since debuginfo needs it
1590     - Create %{_localstatedir}/run/pcp and ship it (so it'll be removed)
1591     - Use %doc in spec for CHANGELOG COPYING INSTALL README VERSION.pcp pcp.lsm
1592     - Tweak configure to move PCP_BINADM_DIR out of /usr/share, into /usr/lib.
1593       Arch dependent binaries should not be installed below /usr/share.
1594     - Delete unneeded "explicit script interpreter" in several places
1595       to keep rpmlint happy
1596     - Remove setuid from pmpost, not needed (and not in debian either)
1597     - Nuke the migrate_pcp_var_dir, script and it's %post scriptlet
1598     - Default "chkconfig off" for all PCP services (retain settings on upgrade)
1599     - Clean-up and simplify the %post scriptlets (rather dramatically)
1600     - Don't ship static libraries in Fedora, we have the debug package for that
1601     - Install .NeedRebuild, add to %files and remove crud from %post scriptlets
1602     - Added %changelog in RPM spec and moved %files to end before %changelog
1603     - Move demos, examples and demo PMDAS to the libs-devel package since they
1604       are not used for production (but are useful for devel and needed for QA).
1605     - Don't install trace demo binaries since src is installed anyway
1606     - Reconciled build/rpm/pcp.spec.in with build/rpm/pcp_fedora.spec
1607     - Integrated RPM packaging support for perl-PCP-PMDA and perl-PCP-MMV
1608       (but perl-PCP-Logsummary is not currently shipped in RPM packages)
1609     - RPM build requires perl(ExtUtils::MakeMaker) rather than
1610       perl-extutils-makemaker (this is the standard notation)
1611     - For easier upgrades, the perl PMDAs only really require pcp >= package
1612       version (until we change or extend an API).
1613     - ReplacePmnsSubtree fix bad signal handling botch (affecting MMV PMDA)
1614     - Fix pmcd.timezone metric such that value updates on daylight savings
1615       (or other timezone) changes.
1616     - Initial packaging work for Slackware Linux, thanks to Roman Revyakin.
1618 pcp-2.9.3 (23 September 2009)
1619     - configure.in fix for Windows iptypes.h header.
1620     - Fixup Windows SQL Server metrics on 64 bit platforms.
1622 pcp-2.9.2 (7 September 2009)
1623     - Final iteration on pmval sample count changes.
1624     - Build fallout on Mac/Win32 in MMV client library.
1625     - Tidy configure.in sys/stat time field/types handling for Alpha builds.
1627 pcp-2.9.1 (2 September 2009)
1628     - Fix a long-standing pmval sample count miscalculation.
1629     - Add missing runlevels and dependencies in start scripts.
1630     - Fix a segv observed in the Windows PMDA accessing SQL Server metrics.
1631     - Fix logic error causing wrong Windows version to be reported sometimes.
1632     - Add kernel.all.uptime to the Windows kernel agent.
1633     - Initial version of the (perl-based) Samba PMDA.
1634     - Fixes to pmdasimple.pl so it functions correctly on all platforms.
1635     - Add PCP::PMDA helper routines for determining native long sizes.
1636     - Extend MMV to allow teardown of MMV file, and set errno on failure.
1637     - Initial stable (1.00) version of MMV Perl interface.
1638     - Correct the metric units for several Windows per-process memory metrics.
1639     - Add network metrics to Solaris PMDA
1640     - Report ZFS statistics from Solaris PMDA
1641     - Export zpool stats from Solaris PMDA
1642     - Generate packages for Solaris
1643     - Allow user to choose her compiler (proper use of AC_PROG_CC)
1645 pcp-2.9.0 (27 July 2009)
1646     - Fix Linux PMDA issue with -fstack-protector gcc option.
1647     - Get socket daemon PMDAs working with Win32 pmcd.
1648     - Bind 9.4 PMDA.
1649     - PowerDNS PMDA.
1650     - Fix atexit handling in the Perl PMDA module.
1651     - Fix a duplicate PMID in the MySQL PMDA.
1652     - Infiniband PMDA improvements and man page.
1653     - Minor packaging tweaks for rpm and deb formats.
1655 pcp-2.8.12 (8 July 2009)
1656     - Bug fixes in Zimbra and MySQL PMDAs.
1657     - Fix memory leaks in the Perl PMDA interface.
1658     - Fix the Mac OS X pmdadarwin metric table direct mapping.
1660 pcp-2.8.11 (6 July 2009)
1661     - Rework namespace file generation for Perl PMDAs.
1663 pcp-2.8.10 (1 July 2009)
1664     - RPM packaging fixes for Perl modules.
1666 pcp-2.8.9 (1 July 2009)
1667     - Remove Cygwin support, we're now committed to native Win32
1668       port - first production install yesterday, hooray!
1669     - Further Win32 work - wrapper batch files for shell scripts
1670       run as commands, moved daemon configs into $PCP_DIR/etc,
1671       bug fixes to process creation code.
1672     - Significant work on the MMV PMDA, including revamped API,
1673       Perl API, updated on-disk support with string values and
1674       help text support, amongst other changes.
1675     - Fix build of Perl PMDA module when PCP not installed.
1676     - Fix Zimbra PMDA status metrics.
1678 pcp-2.8.8 (9 June 2009)
1679     - Added a Zimbra Collaboration Suite PMDA.
1680     - Build fixes for OpenSolaris.
1681     - Perl PMDA fixes in tail mode.
1682     - Correct physical memory reporting in Windows PMDA on 32 bit
1683       machines.
1684     - Other small tweaks and improvements to Windows PMDA also.
1686 pcp-2.8.7 (29 May 2009)
1687     - Windows PMDA major rework to improve memory footprint.
1688     - Yet another Mac OS X build issue resolution.
1690 pcp-2.8.6 (26 May 2009)
1691     - Fix build on Mac OS X after lex warning cleanups.
1692     - Fix pmdate build when PCP headers not in the root.
1693     - A single PMNS domain number file now used in-tree.
1694     - Added tmpfs filesystem metrics to Linux PMDA.
1696 pcp-2.8.5 (21 May 2009)
1697     - Packaging tweaks for Debian (builddefs/rules moved).
1698     - Make timezone manipulation in Windows work (mimic MSYS).
1699     - Numerous warnings fixed.
1700     - Several changes to tempfile handling for Vista.
1701     - Make setting pcp_rc_dir in configure.in more robust.
1702     - Further pathname separator auditing for Windows.
1703     - Fixed a libpcp_gui linker issue on Mac OS X.
1705 pcp-2.8.4 (12 May 2009)
1706     - Descend into src/bashrc.  D'oh!
1708 pcp-2.8.3 (11 May 2009)
1709     - Bash auto-completion of metric names.
1710     - Fix a memory leak in xfs project quotas metrics.
1711     - Several Win32 fixes for Windows Server 2008.
1712     - Add Linux per-CPU and aggregate "guest" CPU utilisation metrics.
1713     - Add a pmlogsummary option to report a "header" line (-H).
1714     - Add optional pmstat support for time control via pmtime.
1715     - Add pmcd.client.* metrics for identifying connected clients.
1717 pcp-2.8.2 (24 April 2009)
1718     - Fix pmie bug in the handling of && and || operators.
1719     - Improve daily pmie/pmlogger script behaviour.
1721 pcp-2.8.1 (19 April 2009)
1722     - Fix build issue with libpcp_mmv - would not build-from-source
1723       if <pcp/pmapi.h> was not in the root filesystem.
1724     - Finer control of pmie2col(1) reporting precision.
1726 pcp-2.8.0 (9 April 2009)
1727     - Linux netfilter (IP connection tracking) PMDA included
1728     - Memory Mapped Value (MMV) PMDA and client library included
1729     - Linux bonding (bonded network interface) PMDA included
1730     - Lustre PMDA included
1731     - Added pcp_gui library as pcpmon replacement, supporting the
1732       new (open source) version of pmtime for console tools.
1733     - Perl PCP::LogSummary module included.
1734     - KVM (Linux Kernel Virtualisation layer) PMDA
1735     - Infiniband PMDA included
1736     - VMware PMDA included
1737     - Perl PCP::PMDA module completed, stabilised and incorporated.
1738     - Default pmcd and pmproxy ports changed to IANA registered ones.
1739       ( The old behaviour - i.e. both original and IANA ports - is
1740       still available using PMCD_PORTS and PMPROXY_PORTS variables ).
1742 pcp-2.7.7 (5 September 2008)
1743     - Infiniband metric enhancements
1744     - Handle missing "which" binary during rpm installation
1745     - Added new quota metrics (XFS project quota)
1746     - Aggregate and per-CPU hypervisor "steal" time metrics added
1747     - NFS v4 metrics
1748     - commitLimit meminfo metric added
1749     - Namespace locking fix in pmdaproc.sh
1750     - Additional Windows memory metrics
1751     - Several pmie fixes from Ken
1752     - Kens pmlogreduce archive corruption fix
1753     - Kens pmproxy PDU size fix
1754     - Nathan's pmlogsummary sum calulation fix
1755     - Added a (cheap) runnable processes metric.
1757 pcp-2.7.4 (7 September 2007)
1758     - MaxOSX and Debian/Ubuntu build/package fixes
1759     - Add sqlserver active_transactions metrics to the Windows PMDA.
1760     - Fix a pmie_check typo causing mis-identification of pmie processes.
1761     - Allow pmie and/or operators to function with some data missing.
1762     - Resolve path naming issues with more recent versions of autoconf.
1763     - pmlogsummary report sum option
1764     - pmval kmtime support
1765     - Additional Linux SNMP metrics
1766     - Fix Linux vmstat nr_slab metrics
1767     - Make pcp status command report build version
1768     - Windows split_io metrics
1769     - Fix pmdapmcd empty pmie instance
1770     - pmdamailq filename regex
1771     - Windows TCP metrics
1772     - pmie log file rotation
1773     - Changed the default compression program to be bzip2(1)
1775 pcp-2.7.3 (July 2007)
1776     - add network.ib.control to timeout infiniband stats workthread
1777     - add mem.util.anonpages 
1779 pcp-2.7.2 (8 Jun 2007)
1780     - pcp doc updates
1781     - pmdalinux death from open file descriptors: pclose needed in network.ib
1782     - network.ib stats updated to cope with OFED 1.2 changes
1783     - some numa.link fixes for shub2 & NL4
1784     - Improve start/stop times of pmcd,pmlogger,pmie
1785     - create portable pmsleep (subsecond sleep) exe
1787 pcp-2.7.0 (7 Feb 2007)
1788     This log has been allowed to lapse for some time. Blanket catch-up..
1789     the following PVs describe changes made in that time:
1790     - 947510 - UNIX95 patches break pcp tools
1791     - 948548 - [SUSE#182852] Buffer overflow in linux proc_pmda
1792     - 948551 - Update pcp configure and build infrastructure
1793     - 948799 - Move telnet-probe to oss part of pcp
1794     - 948958 - *nodeid conversions have inconsistent naming
1795     - 952623 - possible use-after-free of pmProfile objects used by pmda
1796     - 952932 - pcp-open RPM requires libpcp.so.2 but doesn't provide it
1797     - 953015 - Promote libpcp_pmc to DSO
1798     - 953301 - Update irix pcp bits
1799     - 953876 - Use swap.pagesin/pagesout instead of swap.in/.out in pmstat
1800     - 954035 - Update macosx build infrastructure
1801     - 954165 - pmdumptext reports wrong time with sub-second intervals
1802     - 954173 - pmReceiveNamesOfChildren returns bogus value
1803     - 954203 - pmnscomp generates bogus binary pmns files
1804     - 954342 - Add support for FreeBSD
1805     - 954343 - Update windows pmda
1806     - 954432 - Use a pidfile to stop pcp
1807     - 954652 - telnet-probe ate my arguments
1808     - 954842 - Update qa on sles10 for pcp 2.5 and 2.6
1809     - 956190 - add IB traffic stats to linux PMDA
1810     - 956199 - pmlogsummary double free causes graph failures
1811     - 957598 - add debuginfo to pcp-open build in mangrove
1812     - 957758 - valgrind finds "invalid read of size 8" etc in __pmStuffValue
1813     - 957884 - need network.ib.status for per-port IB status and description
1814     - 958273 - If OFED is installed but no ports are found, return PM_ERR_VALUE from refresh_ib
1815     - 958379 - IB PMDA broken (port num appearing twice in perfquery calls)
1816     - 958476 - path to pmie_check binary incorrect in pmie crontab config file
1818 pcp-2.5.0-2 (15 Jan 2006)
1819     - 947602 - pmdas/aix/common.h is missing from the tarball
1821 pcp-2.5.0-1 (ProPack4/SP3)
1822     - 942325 - bump to version 2.5.0-1
1823     - 936279 - pminfo -f hinv.machine gives 'linux'. Now scans for the
1824       SGI hardware IP number from /proc/sgi_prominfo/node0/version
1825       and exports that if found.
1826     - 936795 - tool to aid PMDA development, see genpmda(1)
1827     - 941663 - pmdaInstance broken for name == NULL and inst != PM_IN_NUL
1828     - 939448 - pcp rc script needs better handling of .NeedInstall
1829     - 857601 - pmview-args uses long lines in value/instance caches
1830     - 942030 - Improve efficiency of instance cache in libpcp_pmda
1832 pcp-2.4.1-2 (ProPack4/SP2)
1833     - bug:928986 support slabinfo v2.1 and earlier for recent 2.6.11 kernels
1834     - bug:930708 fix linkstats bandwidth measurements (in pcp-sgi package)
1835     - rfe:924904 add fixed format support for numbers reported by pmval
1836     - bug:928021 correct handling of -S and -T options when resultant time
1837       window is empty
1838     - bug:929411 tighten integrity checking in libpcp routine
1839       pmGetArchiveEnd() to avoid possible segv
1840     - bug:930467 fix fd leak on error path in __pmLogFindLocalPorts()
1841       within libpcp
1842     - rfe:932180 document pmval -i option syntax
1843     - bug:925858 add disk.{dev,all}.{read_merges,write_merges}
1844     - bug:931699 added mem.util.other back in, see help text for details
1845     - bug:931698 added mem.util.cache_clean, see help text for details
1846     - bug:933668 support netif names longer than 6 characters 
1847     - bug:935490 fix pmcd exposure to attack from malformed PDUs
1848     - bug:924909 excise all usage of file(1) and reliance on its "magic"
1849       control file ... the old way cannot be made reliable in on all
1850       platforms
1851     - bug:929411 tighten tests for valid but truncated archives so
1852       pmGetArchiveEnd() no longer dumps core
1853     - add pmdumptext (and the metric class library libpcp_pmc) to
1854       the open source release
1855     - bug:935071 fix metrics broken by bug:925858, deprecate support
1856       for disk stats collected from /proc/stat (linux 2.2 kernels).
1857     - bug:934913 pmdumptext and libpcp_pmc migrated to open source
1858     - bug:934332 change save/free profile logic in __pmdaMainPDU() to
1859       avoid memory leaks
1860     - bug:934333 fix memory leak in __pmdaMainPDU() associated with
1861       instance names
1862     - bug:936975 merge pmcd.conf with pmcd.conf.rpm{new,old,save} so that
1863       foreign (non-pcp) PMDAs will continue to be configured correctly.
1864     - bug:937241 update toplevel GNUmakefile to work with modern autoconf.
1865     - bug:937243: tg3 pmda doesn't see unconfigured interfaces on sles9
1866     - bug:936506: added new cache functions to libpcp_pmda to make it
1867       much easier to implement persistent instance domains. Rolled from
1868       libpcp_pmda.so.2 to libpcp_pmda.so.3, retained symlink for v2.
1869       Converted proc_net_dev and proc_partitions in the linux PMDA to
1870       use the new pmdaCache functionality, see pmdacache(3).
1871     - refine pmcd's handling of SIGINT and SIGTERM to use sigaction() and
1872       try to report the details of the process terminating pmcd
1873     - added the summary PMDA to the open source distribution, to provide
1874       high-level summary of system activity for large machines or large
1875       clusters of machines.
1876     - bug:939275 pmstat output format does not scale for large systems
1877     - bug:939284 correct man page source and packaging to ensure all of
1878       the man pages are in the correct package, and will be correctly
1879       indexed once installed
1880     - bug:861705 add pmproxy to support pmcd protocol proxying for
1881       clusters with head nodes and for monitoring through a firewall
1882     - rfe:919678 added new tool (pmie2col) to convert pmie -v output
1883       into pretty multi-column format
1884     - bug:939467 pcp needs to explicitly provide libpcp_pmda.so.2
1885     - 940865 - network security probe crashes pmcd
1887 pcp-2.4.0-7 (with ProPack4/SP0)
1888     - bug:919901 cisco PMDA confused by Description: line containing '>'
1889     - bug:920140 inapppropriate glob expansion of "disallow * : all;"
1890       in pmcd.conf after PCP upgrade from pcp-2.3.2 to version 2.4.0
1891     - bug:913157 "proc.runq.swapped shows 0 in this state" - updated help
1892       text for linux PMDA to indicate that kernel threads are not
1893       counted in the "swapped" tally.
1894     - bug:918205 fix build issues in SuSE, disallow install-sh ambiguity
1895     - bug:921103 correct build issues for SuSE
1896     - bug:923770 ProPack 4 pmieconf on Oct 22 image wont start
1897     - bug:923777 reconcile changes made to PCP in SLES9 by SuSE
1898     - bug:924714 remove disk.xvm metrics. Now handled by xvm PMDA.
1899     - bug:923732 added new mem.util metrics from /proc/meminfo for 2.6 kernels
1900     - bug:925627 instance domain for proc metrics now includes PNTL threads
1901     - bug:924909 excise all references to file(1) and the "magic" file
1902     - bug:925865 cleanup makefiles for more consistent modes and remove
1903       replicated or questionable directory creations
1904     - assorted rework to support SLES9 and RH Fedora Core 2 Linux
1905       distributions
1906     - clean up of Mac OS X port, including additional O/S metrics
1907     - bug:923773: new metrics mem.vmstat from /proc/vmstat for 2.6 kernels
1908       This also fixes swap.{pagesin,pagesout,in,out}, which have been
1909       deleted from /proc/stat
1910     - rfe:926192 add -u option for pmlogger(1) to force unbuffered writes
1911       (useful when applications monitoring a growing archive)
1912     - rfe:912895 Add pmlogreduce(1) to perform statistical reduction
1913       of PCP archives over the temporal domain by increasing the sample
1914       interval and greatly reducing the size of long-term archives
1916 pcp-2.4.0-1 (5 Aug 2004)
1917     - Installation layout changed to conform to FHS on platforms
1918       where this is appropriate:
1919             Old         New
1920             /var/pcp    /var/lib/pcp
1921             /usr/doc    /usr/share/doc/pcp
1922     - bug:916484: %post script to migrate /var/pcp to /var/lib/pcp
1923       and bump to PCP 2.4.0.
1924     - bug:916657 mem.util.* metrics were incorrectly exported when zero
1925     - add demo program procmemstat to report per-process memory usage
1926     - Add Mac OS X support - port libraries, collection and logging
1927       infrastructure, provide Mac OS X PMDA.  Target is Mac OS X 10.3.
1928     - Add Windows support - port libraries, collection and logging
1929       infrastructure, provide Windows PMDA using the PDH (Performance
1930       Data Helper) APIs.  Target is Windows 98 or later, but must have
1931       either Cygwin or SFU (aka Interix) run-time installation.
1932     - Enhance Solaris support - provide Solaris PMDA using the kstat()
1933       APIs. Target is SunOS 5.8.
1934     - Add AIX support - port libraries, collection and logging
1935       infrastructure, provide AIX PMDA using ther perfstat() APIs.
1936       Target is AIX 5.2.
1937     - rfe:916189 Improvements to archive interpolation diagnostics
1938       under -Dinterp
1939     - bug:916189 use snprintf in preference to sprintf to harden defences
1940       against possible buffer overrun issues
1941     - bug:918878 avoid using file(1) in pmafm and mkaf due to problems
1942       with "magic" extensions for PCP file typing on some platforms
1943     - Linux "rc" scripts enhanced to support both the SuSE and RedHat
1944       regimes
1945     - bug:916354 set SO_KEEPALIVE on the pmcd connection socket to stop fd
1946       leaks with noisy networks
1947     - bug:916189 Fix up handling of tty name (from command line) for
1948       roomtemp PMDA
1950 pcp-2.3.2-13 (SGI Internal release)
1951     - fix bug 902034 for pcp-sgi proprietary package. Added topdisk,
1952       topsys and man pages. Fixed shubstats and enhanced pmshub.
1953     - support for 2.6 style /proc/diskstats
1954     - support 2.6 /proc/stat cpu stats, new metrics:
1955       kernel.percpu.cpu.{intr,wait.total}
1956     - bug #905010 some minor man page tweaking
1957     - bug 907846: pcp cpu.idle metrics wrap prematurely on 2.6 kernels
1958     - bug 907673: linux swap.{pagesin,pagesout} metrics are wrong
1959     - bug 909111 hinv.machine was wrong for Altix. Also, changed several
1960       hinv metrics from instant to discrete.  
1961     - bug 909141: /etc/init.d/pcp now supports "restart"
1962     - bug 911201: PCP network.udp statistics are incorrect
1963     - bug:912971: install rc script to /etc/init.d, works on both RH and SuSE
1964     - bug:912972: promote network.interface metrics to 64bit unsigned,
1965       detect and handle 32bit wraps
1966     - bug:914790 parameterize /var/pcp paths, use /var/lib/pcp by default
1967     - bug:914555: not all mem.util.* metrics available on all kernels
1968     - bug:904478: pcp slabinfo metrics broken for 2.6.x kernels
1970 pcp-2.3.2-4 (6th October 2003)
1971     - fix - on SGI Altix systems, scan topology from /hw rather than /dev/hw
1972     - fix - bug #896808 kernel.{all,percpu}.cpu.idle is unsigned long and is
1973       hence exported as a 64bit ascii number in /proc/stat on 64bit kernels.
1974       Same fix for the per-process cpu metrics in /proc/*/stat affecting
1975       proc.psinfo.{utime,stime,cutime,cstime}
1976     - (proprietary) pcp-pro now obsoletes pcp-snia for the Altix platform
1977     - deprecate the PCP_LIB_COMPAT_DIR variable in /etc/pcp.conf
1978     - add Linux memory metric (mem.util.other) and memory metrics help text
1979     - add lockstat PMDA identifier into stdpmid list
1980     - add Linux vfs metrics (files, inodes, dentries)
1981     - fix - bug #900363 in linux PMDA to handle > 128 CPUs in /proc/stat
1982     - minor cleanup in libpcp, bug #901776
1984 pcp-2.3.1-4 (16 July 2003)
1985     - fix - repair Linux fallout from TRIX changes
1986     - Makepkgs now extracts src tarball from srpm and includes build version
1987       in the tar filename
1988     - fix - make pmtrace and libpcp_trace endian safe, bug 893884
1989     - fix - don't sum non-disk entries from /proc/partitions in disk.all
1990       metrics, and add new SGI XVM metrics below disk.xvm, bug 895611
1991     - minor help text changes in the linux PMDA
1993 pcp-2.3.0-17 (for dev testing)
1994     - fix - compilation warnings in the mount PMDA.
1995     - fix - pmie builds with recent versions of bison.
1996     - fix - several XFS metrics to work with the current/previous XFS versions.
1997     - fix - build on Redhat 9 wrt errno.h changes.
1998     - added several new XFS metrics.
1999     - remove inclusion of some kernel headers from the Linux PMDA code.
2000     - fix - sginap() macro platform_defs.h overflows causing pmie, pmval and
2001       assorted qa tests to hang, bug 891861
2002     - fix - repair fallout from autoconf-2.57 changes in Redhat 9 (broke
2003       "echo without newline" detection for pcp.conf), bug 892029
2004     - fix - under rare conditions, pmFetchArchive() may return with
2005       a bogus return value, bug 892037
2006     - fix - make pmlogger_check tolerant of hostname(1) returning the fully
2007       qualified domain name, bug 892079
2008     - fix race in pmTimeConnect (for pcp-pro only), bug 892827
2010 pcp-2.3.0-15 (21 May 2003)
2011     - fix - pmdampi name space issue issue, bug 891599
2013 pcp-2.3.0-14 (27 Feb 2003)
2014     - Fix for 882525: Linux pmda fails with openafs module at Fermilab
2015       problem in symbol table management, correction also involved
2016       removing the regexp() use and cleanup resulting in a 60% speed-up.
2017       Thanks to Troy Dawson <dawson@fnal.gov> for helping to track this down.
2019 pcp-2.3.0-13 (21 Feb 2003)
2020     - portablility changes to enable building the PCP infrastructure on
2021       Solaris, based on contributions from Alan Hoyt <ahoyt@moser-inc.com>
2023 pcp-2.3.0-12 (17 Feb 2003)
2024     - fix segfault for kernels which do not have CONFIG_MODULES
2025       reported by David Douthitt <DDouthitt@cuna.coop>
2027 pcp-2.3.0-11 (12 Feb 2003)
2028     - patch from Anas Nashif <nashif@planux.com> to work with glibc 2.3.1
2029     - fix - pmlogger_check failure messages are too verbose
2030     - fix - pmclient sometimes reports bad Busy CPU (#) on MP systems
2031     - fix - Piggy-back PDU and endian conversion error
2032     - fix - Minor problem with error-handling in pmlc-pmlogger
2033       connection protocol
2034     - fix - cleanup handling of children's exit status for pmie
2035     - fix - need better diagnostics to debug trace PMDA
2036     - fix - Minor cleanup of PCP man pages
2037     - fix - command buffer too small in pmnsdel
2038     - Solaris portability changes from Alan Hoyt <ahoyt@moser-inc.com>
2039       (qa only so far)
2040     - fix - minor warnings and build cleanup
2041     - fix - serialize the pcp build
2043 pcp-2.3.0-10 (16 December 2002)
2044     - Changes to pmlogconf to improve usability
2045     - pmie_check fails when log files relocated via symlink
2046       reported by Micah Altman <Micah_Altman@harvard.edu>
2047     - fix linux pcp upgrade saves pmns but doesn't save pmcd.conf
2048     - fix pmlc logic error in handling descriptor fetch failures
2049     - pmdumplog reports incorrect sizes for PDUs on ia64
2050     - fix /proc scanning for newer 2.4.x kernels and for 2.5.x
2051     - pmproxy support in libpcp
2052     - change the units of kernel.all.uptime from hours to seconds
2053       contributed by Mike Mason <mmlnx@us.ibm.com>
2054     - fix pmafm remove does not list all files
2055     - Units wrong for proc.psinfo.rss_rlim, Mike Mason <mmlnx@us.ibm.com>
2056     - in build/rpm/GNUmakefile, remove '=' from --target since rpm v4
2057       doesn't seem to like it Todd Davis <todd.c.davis@intel.com>
2058     - fix rpm upgrade post install processing for pmieconf rules
2059     - large number of new metrics and bug fixes from Mike Mason
2060       <mmlnx@us.ibm.com> to support metrics required by libgtop. These
2061       include the following:
2063       (new) Total idle time since boot
2064             kernel.all.idletime
2065       
2066       (new) current # of user sessions
2067             kernel.all.nusers
2068       
2069       (new) Last pid used
2070             kernel.all.lastpid
2071       
2072       (new) Filesystem blocksize from statfs()
2073             filesys.blocksize
2074       
2075       (new) Filesystem free space available to non-superusers from statfs()
2076             filesys.avail
2077       
2078       (modified) Per process command name
2079             proc.psinfo.cmd
2080       
2081       (new) Per process command line from /proc/<pid>/cmdline
2082             proc.psinfo.psargs
2083       
2084       (new) Per process CPU number from /proc/<pid>/stat
2085             proc.psinfo.processor
2086       
2087       (new) Per process wait channel symbol name
2088             proc.psinfo.wchan_s
2089       
2090       (new) Per process signal info from /proc/<pid>/status
2091             proc.psinfo.signal_s
2092             proc.psinfo.blocked_s
2093             proc.psinfo.sigignore_s
2094             proc.psinfo.sigcatch_s
2095       
2096       (new) Per process map info from /proc/<pid>/maps
2097             proc.memory.maps
2098       
2099       (new) Per process memory info from /proc/<pid>/status
2100             proc.memory.vmsize
2101             proc.memory.vmlock
2102             proc.memory.vmrss
2103             proc.memory.vmdata
2104             proc.memory.vmstack
2105             proc.memory.vmexe
2106             proc.memory.vmlib
2107       
2108       (new) Per process user and group ids from /proc/<pid>/status
2109             proc.id.uid
2110             proc.id.euid
2111             proc.id.suid
2112             proc.id.fsuid
2113             proc.id.gid
2114             proc.id.egid
2115             proc.id.sgid
2116             proc.id.fsgid
2117       
2118       (new) Per process user and group ids converted to names
2119             proc.id.uid_nm
2120             proc.id.euid_nm
2121             proc.id.suid_nm
2122             proc.id.fsuid_nm
2123             proc.id.gid_nm
2124             proc.id.egid_nm
2125             proc.id.sgid_nm
2126             proc.id.fsgid_nm
2127       
2128       (new) Semaphore limits from semctl()(needed by libgtop)
2129             ipc.sem.max_semmap
2130             ipc.sem.max_semid
2131             ipc.sem.max_sem
2132             ipc.sem.num_undo
2133             ipc.sem.max_perid
2134             ipc.sem.max_ops
2135             ipc.sem.max_undoent
2136             ipc.sem.sz_semundo
2137             ipc.sem.max_semval
2138             ipc.sem.max_exit
2139       
2140       (new) Message queue limits from msgctl()(needed by libgtop)
2141             ipc.msg.sz_pool
2142             ipc.msg.mapent
2143             ipc.msg.max_msgsz
2144             ipc.msg.max_defmsgq
2145             ipc.msg.max_msgqid
2146             ipc.msg.max_msgseg
2147             ipc.msg.num_smsghdr
2148             ipc.msg.max_seg
2149       
2150       (new) Shared memory limits from shmctl() (needed by libgtop)
2151             ipc.shm.max_segsz
2152             ipc.shm.min_segsz
2153             ipc.shm.max_seg
2154             ipc.shm.max_segproc
2155             ipc.shm.max_shmsys
2157     - fix libpcp_trace stub library does not build on ia64
2158     - fix make clean doesn't remove all that it should
2159     - fix pmlogger gram.y syntax error for newer bison
2160     - fix pmstore value "too big" test does not work on 64bit platforms
2161     - fix memory leak in pmlogger on 64bit platforms
2162     - fix update-magic to recompile the magic file after install
2163     - fix pmie alarm actions, suggested by Todd Davis <todd.c.davis@intel.com>
2164     - fix man pages to be compatible with khelpcenter and man2html
2165     - use rpmbuild rather than rpm --rebuild for RH8, contributed by
2166       Todd Davis <todd.c.davis@intel.com>
2167     - use rpm instead of rpmbuild if rpmbuild isn't available, contributed
2168       my Mike Mason <mmlnx@us.ibm.com>
2169     - in pmdas/linux/ksyms.c, use __psint and %p format for for address
2170       scanning, contributed my Mike Mason <mmlnx@us.ibm.com>
2171     - use "make" by default in Makepkgs rather than explicitly gmake
2172     - Add top level GNUmakefile check for gmake (stolen from glibc)
2173     - Correctly check status in rule for pcp.src in build/GNUmakefile
2174     - correctly check rpmbuild exit status in Installpkgs.
2175     - fix NULL ptr deref in src/pmdas/linuyx/proc_pid.c for the
2176       case where a process exits while we're reading /proc/<pid>/status
2178 pcp-2.2.2-9 (11 December 2001)
2179     - fixed mangle-src to catch all copyrights in the open source package
2180     - fixes from gilly@exanet.com for /proc/cpuinfo on alpha platform.
2181     - change configure.in to work with autoconf version 2.50
2182     - fix configure.in to work when ps gives warnings on stderr;
2183       (eg. System.map doesn't match running kernel)
2184     - added lmsensors PMDA, contributed by Troy Dawson <dawson@fnal.gov>
2185     - added kernel.all.uptime, contributed by Gilly <gilly@exanet.com>
2186     - fixed int overflow with kernel.*.cpu.* metrics. Fix contributed
2187       by Gilly <gilly@exanet.com>
2188     - use sysconf(_SC_CLK_TCK) to determine HZ
2189     - fix sapic scanning for sn-ia64 in proc_cpuinfo.c
2190     - fix from gilly@exanet.com for scanning 2.4.x /proc/stat disk stats
2191     - bug 826904 Ensure atomicity of PMNS updates as seen by PMNS readers,
2192       and add transactional-level locking to ensure mutual exclusion
2193       between PMNS updaters
2194     - bug 817376 pmlogger makes too many round trips to pmcd
2195     - bug 828416 - pmlogger access control will not accept hostnames
2196       containing hyphens
2197     - bug 820891 More robust mapping of system error codes to strings to
2198       accommodate the growing range of errno values in IRIX and differences
2199       between IRIX and Linux
2200     - bug 826681 - Having $MAGIC set screws up Linux file(1) with consequent
2201       havoc for PCP scripts. Fixes to mkaf and pmie_check.
2202     - fix from Brian Harvell <harvell@aol.net> to allow pcp.conf.in to be
2203       configured with the following cmdline options to the configure script:
2204       --datadir --sbindir --localstatedir --libdir --mandir --bindir
2205       --includedir and --prefix
2206     - fixes from Brian Harvell <harvell@aol.net> for incorrectly
2207       configured paths in src/pmie/src/pmie.c src/pmns/pmnsdel.c 
2208       and src/pmns/pmnsmerge.c
2209     - from Thomas Graichen <tgr@spoiled.org>, support for bzip2 compressed
2210       man pages (such as used in Mandrake 8.x)
2211     - from Martin Knoblauch <Martin.Knoblauch@TeraPort.de>, fix for a problem
2212       where if LANG is not "C", the is_chkconfig_on() shell function in
2213       rc-proc.sh does not work, causing problems with the rc scripts.
2214       src/libpcp/src/pdu.c - 1.3
2215     - bug 836236 in libpcp: better handling of piggy-back PDU in the boundary
2216       case where the second PDU is so short that it does not contain even a
2217       full PDU header.
2218     - fix src RPM build on Turbo Linux. If /usr/lib/rpm/brp-compress
2219       exists then always use gzipped man pages.
2220     - fix buglet where file-3.35 in RH7.2 uses a compiled magic file
2221     - fix buglet where gawk complained about "\{" on Mandrake linux
2222     - on SGI SNIA systems, map node number from sapic to cnode in /dev/hw/nodenum
2223     - bug 843215, fix pmie's sprintf looking for it's config file
2224     - bug 842905, when /var/log/pcp is a symbolic link, pmie_check fails
2226 pcp-2.2.1-3 (21 June 2001)
2227     - remove unwanted *.rpmorig files after upgrade 
2228     - fixed bug #827972, pcp root exploit with pmpost
2229     - fixed assorted other security issues.
2231 pcp-2.2.0-15 (23 May 2001)
2232     - don't include linux/kernel_stat.h and avoid __sparc__ conditional code 
2233     - from Michal Kara: rc will rebuild PMNS if root_* files newer than root
2234     - add the roomtemp PMDA for measuring temperatures using the 1-Wire
2235       serial network ans sensor technology from Dallas Semiconductor
2236     - zero network.tcpconn values before counting them in /proc/net/tcp
2237       (Michal Kara's original code was correct - markgw busted it!)
2238     - add new LGPL library libpcp_http. Used by permission of the author,
2239       Laurent Demailly <L@Demailly.com>
2240     - minor surgery on apache PMDA to link with -lpcp_http
2241     - minor fix diagnostic from __pmLogRead
2242     - as reported by Alexander L. Belikoff <abel@vallinor4.com>, it was
2243       not possible to disable the primary logger via changes to the
2244       /var/pcp/config/pmlogger/control file ... this has been fixed
2245     - as reported by Alan Bailey <bailey@mcs.anl.gov>, the assumption
2246       that /var/pcp/config/pmlogger/control was version 1.1 was implicit 
2247       ... this is now documented and the pmlogger_* scripts will warn
2248       if the deprecated version 1.0 format is used accidently
2249     - from Michal Kara: fix mem leak in apache PMDA
2250     - from Michal Kara: install /var/pcp/config/pmlogger/Makefile
2251       (src is in src/pmlogctl/Makefile.install). This provides pre-processing
2252       of pmlogger config files with cpp.
2253     - reintroduction of "impl.h" header, deprecate "pmapi_dev.h" and major
2254       makefile surgery to reintegrate the IRIX and Linux PCP source trees
2255     - add ia64 support infrastructure.
2256     - use -fno-strict-aliasing for correct ia64 compilation
2257     - use -fpic to avoid gprel errors linking shlibs on ia64
2258     - don't use -P with cpp, thus preserve line numbers
2259     - post-process help text to reformat long lines
2260     - pv:789819 fixes to mailq and sendmail PMDAs
2261     - fix endian-sensitive IP addr construction in cisco PMDA
2262     - fix sscanf unaligned access warnings on ia64 for cisco PMDA
2263     - support v1 help text again, conditional on HAVE_NDBM
2264     - fix pmval's qsort compare routine for instances
2265     - surgery on almost all man pages, merge with IRIX PCP man pages
2266     - promote shping to open-source status
2267     - fix bug #814989 where disk.all.* not summed correctly (if the sard
2268       patch has been applied to running kernel)
2269     - with the sard patch applied to the kernel, disk.all metrics were
2270       being summed as the total of disk.partitions and disk.dev metrics,
2271       resulting in approximately twice the rate of disk I/O for the
2272       disk.all metrics
2273     - added more disk metrics and update help text
2274     - the "cpu" instance domain is now dynamic and supports any number of CPUs
2275     - fixed pmie rc and pmie_{check,daily} scripts
2276     - a bunch of places were using $PCP_VAR_DIR/config/pmcd/pmcd.conf
2277       as the path to pmcd.conf (which is correct). Others were using
2278       /etc/pmcd.conf (which is only correct on IRIX).
2279     - merged IRIX/Linux versions of pmsocks
2280     - mimic the IRIX xconfirm behaviour more closely, pv 817289
2281     - pv:817367 Handle SIGCHLD from xconfirm problem on Linux
2282     - minor changes in error messages to make them less IRIX-centric
2283       and hence more sensible for Linux
2284     - fix weblog link in doc dir logic and old netscape should be
2285       detected as CERN not NS_PROXY.
2286     - fix weblog so regex in the configuration file is recognized
2287       correctly on all platforms
2288     - only run weblogconv.sh on linux
2289     - conversion to more simple copyright in numerous places
2290     - avoid grep -q usage: not supported on early IRIX
2291     - pv:803341 Change Creator: for mkaf from mkaf to pmchart to assist
2292       with pmafm replay when pcp also installed.
2293     - updated man page text for platform-agnostic descriptions.
2294     - fix 817880 pmafm remove does not list all files
2295     - src/pmie/GNUmakefile Fix busted sed translation of the control
2296       file so the logfiles (and hence directories) are ...pmie/<hostname>
2297       rather than pmie<hostname>
2298     - renamed all Makefiles to GNUmakefile
2299     - makefile surgery to allow multiple RPMs to be built from one src tree
2300     - fixes to src/pmcd/pmdaproc.sh to not use test -e
2301     - pv:815326 fix pcp linux /usr/share/magic doesn't detect pmie config
2302     - pv:818381 fix pmie_check fails esp integration
2303     - man page for pmlogsummary was in both pcp and pcp-pro
2304     - fix to src/pmie/pmie_check.sh, improve pattern to match No such
2305       file or directory for linux
2306     - fix all linux specs to install root,root rather than root,bin
2307       (needed to avoid warnings when installing on redhat7.1)
2308     - add GNUmakefile.install for all PMDAs, installed in each PMDA dir
2309     - fix src/pmdas/weblog/server.sh to use quotes on -d that was breaking
2310       when parameter empty.
2311     - pv:807561 change pmprobe -i and -I semantics to call pmGetInDom
2312       rather than using the returned indom from pmFetch
2313     - add hinv.machine for oview to use
2314     - change the cpu instance domain to use the numa names if they are
2315       present on the machine, else revert to cpuX syntax
2316     - numerous fixes so the src RPM builds on all platforms
2317     - pv:824382 - xfs block metrics were scaled incorrectly
2318     - add support for /proc/slabinfo metrics (mem.slabinfo.*)
2319     - add new "process" and "mounts" PMDAs, contributed by Alan Baily
2320     - added GPL copyrights to process and mounts src, fixed makefiles
2321       to extract domain number from stdpmid and added install targets,
2322       and small change to ignore comments in conf files.
2323     - added hinv.pagesize (uses the getpagesize(2) system call)
2324     - fixed bug #825229 where rpm upgrade would clobber root pmns for PMDAs
2326 pcp-2.1.10-8 (released circa Oct 18 2000, with SGI ACE1.4)
2327     - guard against DOS attack by restring incoming PDU size to 64K.
2328     - add hinv.map.cpu and hinv.cpu metrics exported by /proc/cpuinfo
2329     - fix small error in INSTALL_MAN rule in src/include/builddefs.in
2330     - fix for bug #793427 - correct symlinks for man pages with multiple
2331       entries in the .SH NAME section.
2332     - add network.tcpconn metrics to export counts of tcp connections in each
2333       state. Code contributed by Michal Kara (lemming@arthur.plbohnice.cz)
2334     - few minor fixes for build on ia64
2336 pcp-2.1.9-12 (released circa Sept 13 2000, with SGI Propack1.4)
2337     - for 2.4 without sard, correctly match disk numbers in /proc/stat
2338       with major,minor numbers in /proc/partitions.
2340 pcp-2.1.9-11 (unreleased)
2341     - add pagebuf metrics (Daniel and Nathan)
2342     - fixes so the build works if pcp is not already installed
2343     - minor security fix to pcp.spec.in (force mode 644 for .NeedRebuild)
2344     - make sure the src RPM builds correctly (LSRCFILE issues from LinuxWorld)
2345     - fix for bug #797756, upgrade from pcp2.1.6 to any newer version leaves
2346       pcp chkconfig off and the name space does not get rebuilt.
2347     - extended the weblogs PCP agent so it can report proxy/squid
2348       http servers, and added assorted http cache statistics.
2349     - fixed the Cisco router PCP agent (it was broken in pp1.3).
2350     - add support for disk stats in 2.4.x kernels with "disk_io" field
2351       in /proc/stat (only used when sard patch is not installed)
2352     - if the pcp-pro package (SGI proprietary) is installed, all libpcp
2353       clients on linux are now "authorized" to monitor IRIX systems that
2354       do not have a pmcd collector license.
2356 pcp-2.1.9-6 (released 2 Aug 2000 for propack1.4 - alpha, not final)
2357     - install /usr/share/pcp/lib/rc-proc.sh containing common
2358       shell functions for use by rc scripts - these functions
2359       are tolerant of the chkconfig command missing (as in SUSE).
2360     - update all rc scripts and {pmlogger,pmie}_{check,daily} scripts
2361       to use the new rc-proc.sh functions. Remove the /etc/sysconfig
2362       stuff entirely (it was not being used anyway).
2363     - fix for #795934 : after rpm -U, pcp is chkconfig off. It turned
2364       out that an upgrade executes the %post _and_ the %preun scripts,
2365       which resulted in pcp being chkconfig'd on then off again.
2366     - fix pmie rc scripts so they work, are chkconfig friendly,
2367       and cope with _and_ without pmieconf (which is in pcp-pro).
2368       Also install /var/pcp/config/pmie/config.default as a simple example
2369       to monitor the load average and report to syslog. The pmie
2370       daemon is chkconfig off by default.
2371     - default run levels for pmcd and pmie (daemon) are now 2345, for SUSE
2372     - reconcile troff and groff differences in man page sources
2373     - fix for bug #797049 use strftime(%z) to determine timezone offsets
2374       w.r.t. daylight savings
2375     - portability surgery on src/libpcp_trace, and add new pmtracecounter()
2376       function, see pmtracebegin(3) for details.
2377     - reconcile pcp.env and pmcd.options from IRIX
2378     - fix for bug #797048 update-magic does not fully remove old entries
2379       before adding new, hence the magic file would grow after each upgrade
2380     - other minor reconciliation work with IRIX
2381     - fix build environment to allow proper handling of compressed man pages
2382     - add support for RPM version 4.
2383     - add support for add kernel.{all,percpu}.syscall metrics
2384       (requires kernel patch)
2385     - fixed for bug #797164: potential SEGV due to calling realloc on a 
2386       misused pointer - src/pmdas/weblog/weblog.c
2387     - use realpath(3) to resolve devices in /proc/mounts for filesys.* metrics
2390 pcp-2.1.8-2 (released 30 June 2000)
2391     - fix for bug #793871 pmlogger_check fails after redhat upgrade
2392       (because PCP entries in /usr/share/magic were clobbered)
2393     - also install /var/pcp/pmdas/linux/pmdalinux (as a non-DSO
2394       agent for debugging and profiling purposes).
2395     - added pmda.uname (uname -a) and pmda.version (linux pmda version)
2396       metrics. The pmda.uname metric is needed by the "pcp" command.
2397     - fix for #789025 fix to ensure rpm --verify succeeds immediately
2398       after an install, and other errors in pmlogger_check
2399     - released with ACE 1.3 (MR 19 Jul 2000)
2401 pcp-2.1.7 (internal release for testing)
2402     - merged changes from IRIX for multiple namespace support in
2403       pmdaproc.sh
2404     - parameterized path to pmcd.conf and pmcd.options to avoid
2405       having to move these files in IRIX. Use PCP_PMCDCONF_PATH and
2406       PCP_PMCDOPTIONS_PATH respectfully.
2407     - add new error define PM_ERR_LOGFILE (reconciled from IRIX)
2408     - conditional pragma for pmGetConfig (not used in linux)
2409     - use if defined(HAVE_OBJECT_STYLE) to guard __pmCheckObjectStyle
2410       since it's not used in linux (reconciled with irix code)
2411     - correct logic used to scan for pmlogger pid in pmlogger_check
2412       in case where pmlogger exits prematurely, part of #789025
2413     - added -Wall to default CFLAGS and LDFLAGS
2414     - added xfs metrics (needs kernel support else no values available)
2415       extracted from /proc/fs/xfs/stat
2416     - added nfs (version 3) metrics, same names as on irix, bug #789669
2417     - fix instance domain for kernel.percpu.interrupts, bug #790372
2419 pcp-2.1.6 (released 3 May 2000)
2420     - released with ISE 1.2 (MR 25 May 2000)
2421     - released with ISEMAIL 1.0 (MR 24 May 2000)
2422     - this is the version shipped with SGI ProPack1.3
2423     - change use of __clone to pthread_create for portability
2424     - add support for raid disk stats (previously ignored)
2425     - fix for bug #789425 pmie suspect behaviour with "delta" keyword
2426     - add support for devfs style scsi disk names
2427     - fixed a problem where nfs stats were always showing NFSv3 stats
2428       rather than NFSv2 stats. We are not (yet) supporting NFSv3 stats.
2430 pcp-2.1.5 (released 12 April 2000)
2431     - released with SGI ACE 1.2 (MR 19 Apr 200)
2432     - fix bug #786743 filesys metrics are wrong
2433     - fix potential segfault bug in timezone handling
2434     - tolerate SUSE's location of magic file different to Redhat's
2435     - tolerate no chkconfig on SUSE (use %postinstall create rc symlinks)
2437 pcp-2.1.4 (released 15 Feb 2000)
2438     - fix for segfault src/pmdas/linux/pmda.c on linuxppc, found by
2439       Dale F. Brantly <dale.brantly@sgi.com>
2440     - fix build error in src/pmclient, was trying to use pmgenmap
2441       without /etc/pcp.env, also found by Dale.
2442     - setlinebuf(stdout) for all clients that loop
2443       (fixes a buffering problem on alpha-linux).
2444     - fixed some missing "{" in conditional variable assignments
2445       in src/pmie/etc_init.d_pmie (found by lstep@free.fr)
2446     - changed use of pmgenmap in build for pmclient and
2447       pmkstat to be consistent (found by lstep@free.fr)
2448     - don't assume clock tick rate is 100/second. Use the CLK_TCK macro
2449       instead. Rearrange arithmetic in src/pmdas/linux/pmda.c where we
2450       divide by CLK_TCK to avoid truncation in conversions from jiffies
2451       to milliseconds.
2452     - return "no values available" rather than PM_ERR_APPVERSION for
2453       the metrics disk.{all,dev}.{read,write,total}_bytes since these
2454       are not available on systems without the "sard disk patch".  This
2455       is now consistent with requests for disk.partitions.* metrics.
2457 pcp-2.1.3 (released with 2.1.4)
2458     - released with ISE 1.0 (MR 1 Mar 2000)
2459     - added hinv.map.scsi metric as a map of SCSI devices (if any)
2460     - added disk.dev.{read,write,total}_bytes
2461     - filter devpts from filesys.* metrics to avoid FPE errors
2462     - added support for new style Apache configuration file and
2463       "silent" install to weblog scripts
2465 pcp-2.1.2 (released with 2.1.4)
2466     - released with SGI ACE 1.0
2467     - fixed date field in LSM
2468     - install pmiestats.h for pmieconf
2469     - renamed /var/pcp/config/pmafm/pcp-col to
2470       /var/pcp/config/pmafm/pcp
2471     - added network.{ip,icmp,tcp,udp} metrics
2472       extracted from /proc/net/snmp
2473     - fixed shell syntax error in pmlogger_daily(1)
2474       (changed test -l to test -f)
2475     - fixed problem with definition of __psint_t on 64bit machines
2476     - fixed timezone problem with daylight saving
2478 pcp-2.1.1 (released 7 Dec 1999)
2479     - initial pcp-2.1.1 open source release