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