Home | History | Annotate | Download | only in bktr
History log of /src/sys/dev/pci/bktr/bktr_os.c
RevisionDateAuthorComments
 1.69  23-May-2022  rin Audit unload/unmap v.s. free against DMA buffer for sys/dev/pci;
make sure that bus_dmamap_unload(9) [or bus_dmamap_destroy(9)] or
bus_dmamem_unmap(9) are preceding to freeing DMA buffer, if it is
loaded or mapped, respectively.

This is mandatory for some archs. See, e.g.:

http://www.nerv.org/netbsd/?q=id:20210511T013030Z.013443cc790088147e4beed43f53dedabeaf9312
http://www.nerv.org/netbsd/?q=id:20220511T172220Z.561179f0b6fcc5b9cd73e274f69d74e2ce9e4c93

XXX XXX XXX
Compile test only (for amd64/ALL).

Thanks riastradh@ for double check.
 1.68  09-Dec-2018  jdolecek use pci_intr_establish_xname()
 1.67  14-Jul-2016  msaitoh branches: 1.67.16; 1.67.18;
- Use aprint*() more in xxx_attach().
- Add missing aprint_naive("\n").
- Remove extra spaces and tabs.
- KNF.
 1.66  07-Jul-2016  msaitoh KNF. Remove extra spaces. No functional change.
 1.65  25-Jul-2014  dholland branches: 1.65.4;
Add d_discard to all struct cdevsw instances I could find.

All have been set to "nodiscard"; some should get a real implementation.
 1.64  29-Mar-2014  christos branches: 1.64.2;
make pci_intr_string and eisa_intr_string take a buffer and a length
instead of relying in local static storage.
 1.63  16-Mar-2014  dholland Change (mostly mechanically) every cdevsw/bdevsw I can find to use
designated initializers.

I have not built every extant kernel so I have probably broken at
least one build; however I've also found and fixed some wrong
cdevsw/bdevsw entries so even if so I think we come out ahead.
 1.62  10-Aug-2013  dholland Redo -r1.53 correctly.
 1.61  27-Oct-2012  chs branches: 1.61.2;
split device_t/softc for all remaining drivers.
replace "struct device *" with "device_t".
use device_xname(), device_unit(), etc.
 1.60  30-Jun-2011  wiz branches: 1.60.2; 1.60.12;
dependant -> dependent
 1.59  23-Apr-2010  macallan don't try to print a bus_space_handle_t
now this at least compiles on sparc64
 1.58  22-Mar-2010  dyoung MI code must not printf() a bus_space_tag_t, so don't do that.
 1.57  06-May-2009  cegger branches: 1.57.2; 1.57.4;
struct device * -> device_t, no functional changes intended.
 1.56  06-May-2009  cegger struct cfdata * -> cfdata_t, no functional changes intended.
 1.55  15-Mar-2009  cegger ansify function definitions
 1.54  14-Mar-2009  dsl Change about 4500 of the K&R function definitions to ANSI ones.
There are still about 1600 left, but they have ',' or /* ... */
in the actual variable definitions - which my awk script doesn't handle.
There are also many that need () -> (void).
(The script does handle misordered arguments.)
 1.53  24-Jun-2008  gmcgarry branches: 1.53.4; 1.53.10;
Both legs of a digraph must return the same type. Therefore, replace digraph.
 1.52  08-Jun-2008  tsutsui branches: 1.52.2;
Use device_lookup_private() rather than using cd_devs[] directly to get softc.

XXX maybe we should change a type of cd_devs[] in struct cfdriver
from (void *) to device_t.
 1.51  10-Apr-2008  cegger branches: 1.51.2; 1.51.4; 1.51.6;
use aprint_*_dev and device_xname
 1.50  01-Mar-2008  rmind Welcome to 4.99.55:

- Add a lot of missing selinit() and seldestroy() calls.

- Merge selwakeup() and selnotify() calls into a single selnotify().

- Add an additional 'events' argument to selnotify() call. It will
indicate which event (POLL_IN, POLL_OUT, etc) happen. If unknown,
zero may be used.

Note: please pass appropriate value of 'events' where possible.
Proposed on: <tech-kern>
 1.49  16-Jan-2008  jmcneill branches: 1.49.2; 1.49.6;
Don't assume that sizeof(long) == sizeof(int); makes bktr work on amd64.
 1.48  19-Oct-2007  ad branches: 1.48.2; 1.48.8;
machine/{bus,cpu,intr}.h -> sys/{bus,cpu,intr}.h
 1.47  25-Sep-2007  ad branches: 1.47.2;
Use selinit() / seldestroy().
 1.46  04-Mar-2007  christos branches: 1.46.2; 1.46.14; 1.46.16; 1.46.18;
Kill caddr_t; there will be some MI fallout, but it will be fixed shortly.
 1.45  16-Nov-2006  christos branches: 1.45.2; 1.45.4; 1.45.8;
__unused removal on arguments; approved by core.
 1.44  12-Oct-2006  christos - sprinkle __unused on function decls.
- fix a couple of unused bugs
- no more -Wno-unused for i386
 1.43  03-Sep-2006  bouyer branches: 1.43.2; 1.43.4;
stop attaching when a bus_dma operation fails, instead of using bogus
addresses.
Remplace vtophys() with proper bus_dma(9) use.
This driver now works properly on Xen
 1.42  28-Aug-2006  christos remove unreachable code.
 1.41  28-Aug-2006  christos add missing initializer.
 1.40  28-Mar-2006  thorpej branches: 1.40.6;
Use device_unit().
 1.39  11-Dec-2005  christos branches: 1.39.4; 1.39.6; 1.39.8; 1.39.10; 1.39.12;
merge ktrace-lwp.
 1.38  29-Oct-2004  yamt branches: 1.38.10; 1.38.12;
constify audio_hw_if, midi_hw_if, and radio_hw_if.
 1.37  29-Jun-2003  fvdl branches: 1.37.2;
Back out the lwp/ktrace changes. They contained a lot of colateral damage,
and need to be examined and discussed more.
 1.36  28-Jun-2003  darrenr Pass lwp pointers throughtout the kernel, as required, so that the lwpid can
be inserted into ktrace records. The general change has been to replace
"struct proc *" with "struct lwp *" in various function prototypes, pass
the lwp through and use l_proc to get the process pointer when needed.

Bump the kernel rev up to 1.6V
 1.35  12-Mar-2003  wiz Merge first bktr-sf import.
 1.34  10-Jan-2003  mjl Make this work on big endian platforms (mostly from OpenBSD):
Uploaded scripts work better if they are little endian, as the
card's engine expects, so convert to le first.

Also clean up attach routine a bit (use pa_id and PCI_REVISION
instead of fetching it ourselves).

This makes the driver work on my macppc G4, it can decode and
display video and tuner input. Sound does not seem to work, but
this may be my wonky formac bktr-for-macintosh card.
 1.33  23-Oct-2002  jdolecek merge kqueue branch into -current

kqueue provides a stateful and efficient event notification framework
currently supported events include socket, file, directory, fifo,
pipe, tty and device changes, and monitoring of processes and signals

kqueue is supported by all writable filesystems in NetBSD tree
(with exception of Coda) and all device drivers supporting poll(2)

based on work done by Jonathan Lemon for FreeBSD
initial NetBSD port done by Luke Mewburn and Jason Thorpe
 1.32  02-Oct-2002  thorpej Add trailing ; to CFATTACH_DECL.
 1.31  01-Oct-2002  thorpej Use CFATTACH_DECL().
 1.30  27-Sep-2002  thorpej Declare all cfattach structures const.
 1.29  06-Sep-2002  gehenna Merge the gehenna-devsw branch into the trunk.

This merge changes the device switch tables from static array to
dynamically generated by config(8).

- All device switches is defined as a constant structure in device drivers.

- The new grammer ``device-major'' is introduced to ``files''.

device-major <prefix> char <num> [block <num>] [<rules>]

- All device major numbers must be listed up in port dependent majors.<arch>
by using this grammer.

- Added the new naming convention.
The name of the device switch must be <prefix>_[bc]devsw for auto-generation
of device switch tables.

- The backward compatibility of loading block/character device
switch by LKM framework is broken. This is necessary to convert
from block/character device major to device name in runtime and vice versa.

- The restriction to assign device major by LKM is completely removed.
We don't need to reserve LKM entries for dynamic loading of device switch.

- In compile time, device major numbers list is packed into the kernel and
the LKM framework will refer it to assign device major number dynamically.
 1.28  07-Jan-2002  jmcneill branches: 1.28.8;
Re-enable radio at bktr, only if NRADIO > 0 and an FM tuner is present.
 1.27  07-Jan-2002  tron Disable broken radio(4) support for bktr(4). The configuration code doesn't
even check if the TV card has a radio tuner.
 1.26  07-Jan-2002  tron Clean up preprocess handling of optional radio(4) support a little bit.
 1.25  06-Jan-2002  tron Compile in radio(4) only it is activated in the kernel configuration.
 1.24  06-Jan-2002  jmcneill Add missing definition of STATUSBIT_STEREO.
 1.23  06-Jan-2002  jmcneill Add basic support for the radio(4) interface.
 1.22  13-Nov-2001  lukem add RCSIDs
 1.21  18-Oct-2001  wiz Fix check in device open.
Patch by KUROSAWA Takahiro in kern/14289.
 1.20  18-Sep-2001  wiz Give initiali[sz]e all the "i"s it deserves.
 1.19  15-Mar-2001  ross branches: 1.19.2; 1.19.4;
LP64 a kprintf(9)
 1.18  03-Mar-2001  mjl branches: 1.18.2;
Correct wrong error return in mmap fn.
 1.17  30-Dec-2000  wiz Undo pci_intr_map change in non-NetBSD part of the file.
 1.16  30-Dec-2000  wiz Merge 2.18 to trunk.
 1.15  28-Dec-2000  sommerfeld Change pci_intr_map to get interrupt source information from a "struct
pci_attach_args *" instead of from four separate parameters which in
all cases were extracted from the same "struct pci_attach_args".

This both simplifies the driver api, and allows for alternate PCI
interrupt mapping schemes, such as one using the tables described in
the Intel Multiprocessor Spec which describe interrupt wirings for
devices behind pci-pci bridges based on the device's location rather
the bridge's location.

Tested on alpha and i386; welcome to 1.5Q
 1.14  28-Oct-2000  wiz branches: 1.14.2;
Replace remaining vm_offset_t's in NetBSD code by vaddr_t; remove now
unnecessary casts added by thorpej in 1.11 of bktr_core.c. Strike one
from the TODO list.
 1.13  28-Oct-2000  wiz Merge 2.17 changes to trunk.
 1.12  03-Sep-2000  wiz Use NetBSD's pcidevs file for vendors/cards as much as possible.
Recognize Pinnacle Studio PCTV Rave as Miro card, tested by rh@netbsd.org.
 1.11  01-Jul-2000  wiz remove unnecessary #ifdef __NetBSD__'s in #ifdef __FreeBSD__;
move one #include <vm/vm.h> into #ifndef __NetBSD__
 1.10  01-Jul-2000  wiz resolve conflicts.
 1.9  30-Jun-2000  veego Move the include of <vm/vm.h> into the ifndef __NetBSD__ part.
 1.8  27-Jun-2000  simonb Revert some of the previous mmap() changes that were in "#ifdef FreeBSD"
parts of this file.
 1.7  26-Jun-2000  mrg remove/move more mach vm header files:

<vm/pglist.h> -> <uvm/uvm_pglist.h>
<vm/vm_inherit.h> -> <uvm/uvm_inherit.h>
<vm/vm_kern.h> -> into <uvm/uvm_extern.h>
<vm/vm_object.h> -> nothing
<vm/vm_pager.h> -> into <uvm/uvm_pager.h>

also includes a bunch of <vm/vm_page.h> include removals (due to redudancy
with <vm/vm.h>), and a scattering of other similar headers.
 1.6  26-Jun-2000  simonb Change the kernel mmap interface so that the offset to map is an
"off_t" and the return value is a "paddr_t" to allow mappings
at offsets past 2^31 bytes. Somewhat inspired by FreeBSD, which
only changed the offset to a "vm_offset_t".

Includes updates for the i386, pc532 and sh3 mmmmap from Jason Thorpe.
 1.5  21-May-2000  wiz branches: 1.5.4;
Use bktr_softc.bktr_dev.dv_xname instead of "bktr0" when printf'ing as
requested by Klaus Klein in kern/10166.
Also add device instance name to all printf's that didn't have it.
 1.4  07-May-2000  veego It is a bad idea to declare a static bootverbose variable here. Remove it.
 1.3  07-May-2000  wiz compilation fix
 1.2  07-May-2000  wiz Some NetBSD specific changes; also TODO, and import script, based
on bind2netbsd by Bernd Ernesti
 1.1  07-May-2000  wiz branches: 1.1.1;
Initial revision
 1.1.1.5  12-Mar-2003  wiz Import of current state of bktr(4) in sourceforge repository.
Changes since last import:
. lots of whitespace cleanups
. typo fixes (e.g. hz, compatibilty)
. fix brightness ioctl return value
. wait for int ready using DELAY() instead of tight loop
 1.1.1.4  30-Dec-2000  wiz Import release 2.18 of the bktr driver. Changes since 2.17:
o Add new ioctls to allow userland programs fuller access to the I2C
bus, BT848_MSP_READ BT848_MSP_WRITE and BT848_MSP_RESET.
o Add tuner type 0x2a. Remove 0x2c which was incorrect.
o Christian Gusenbauer <Christian.Gusenbauer@netway.at> added support
for audio on Hauppauge cards without the audio mux. The MSP is used
for audio selection. (the 44xxx models)
 1.1.1.3  28-Oct-2000  wiz Import release 2.17 of the bktr driver.
Changes: Integration of some NetBSD changes. (FreeBSD version now is also
usable as a KLD (~= LKM).)
 1.1.1.2  01-Jul-2000  wiz Import release 2.14 of the bktr driver. Changes: mostly integration
of NetBSD changes; support for new Hauppauge tuner types.
 1.1.1.1  07-May-2000  wiz Import of (finally busspaced) bktr-driver from FreeBSD (part 1).
This version is from the location specified in the README, modified
by bktr2netbsd, to be committed later.
 1.5.4.3  24-Oct-2001  jhawk Pull up revision 1.21 (requested by lukem):
Check unit count correctly (correct fencepost error)
on device open.
 1.5.4.2  03-Jul-2000  wiz Pull up revision 1.11 (requested by wiz):
Sync with release 2.14 of the bktr driver. Changes: mostly integration
of NetBSD changes; support for new Hauppauge tuner types.

Approved by thorpej.
 1.5.4.1  30-Jun-2000  simonb Pull up mmap paddr_t/off_t changes from trunk.
 1.14.2.6  27-Mar-2001  bouyer Sync with HEAD.
 1.14.2.5  12-Mar-2001  bouyer Sync with HEAD.
 1.14.2.4  05-Jan-2001  bouyer Sync with HEAD
 1.14.2.3  22-Nov-2000  bouyer Sync with HEAD.
 1.14.2.2  20-Nov-2000  bouyer Update thorpej_scsipi to -current as of a month ago
A i386 GENERIC kernel compiles without the siop, ahc and bha drivers
(will be updated later). i386 IDE/ATAPI and ncr work, as well as
sparc/esp_sbus. alpha should work as well (untested yet).
siop, ahc and bha will be updated once I've updated the branch to current
-current, as well as machine-dependant code.
 1.14.2.1  28-Oct-2000  bouyer file bktr_os.c was added on branch thorpej_scsipi on 2000-11-20 22:35:47 +0000
 1.18.2.10  15-Jan-2003  thorpej Sync with HEAD.
 1.18.2.9  11-Nov-2002  nathanw Catch up to -current
 1.18.2.8  18-Oct-2002  nathanw Catch up to -current.
 1.18.2.7  17-Sep-2002  nathanw Catch up to -current.
 1.18.2.6  28-Feb-2002  nathanw Catch up to -current.
 1.18.2.5  11-Jan-2002  nathanw More catchup.
 1.18.2.4  14-Nov-2001  nathanw Catch up to -current.
 1.18.2.3  22-Oct-2001  nathanw Catch up to -current.
 1.18.2.2  21-Sep-2001  nathanw Catch up to -current.
 1.18.2.1  09-Apr-2001  nathanw Catch up with -current.
 1.19.4.3  01-Oct-2001  fvdl Catch up with -current.
 1.19.4.2  26-Sep-2001  fvdl * add a VCLONED vnode flag that indicates a vnode representing a cloned
device.
* rename REVOKEALL to REVOKEALIAS, and add a REVOKECLONE flag, to pass
to VOP_REVOKE
* the revoke system call will revoke all aliases, as before, but not the
clones
* vdevgone is called when detaching a device, so make it use REVOKECLONE
to get rid of all clones as well
* clean up all uses of VOP_OPEN wrt. locking.
* add a few VOPS to spec_vnops that need to do something when it's a
clone vnode (access and getattr)
* add a copy of the vnode vattr structure of the original 'master' vnode
to the specinfo of a cloned vnode. could possibly redirect getattr to
the 'master' vnode, but this has issues with revoke
* add a vdev_reassignvp function that disassociates a vnode from its
original device, and reassociates it with the specified dev_t. to be
used by cloning devices only, in case a new minor is allocated.
* change all direct references in drivers to v_devcookie and v_rdev
to vdev_privdata(vp) and vdev_rdev(vp). for diagnostic purposes
when debugging race conditions that still exist wrt. locking and
revoking vnodes.
* make the locking state of a vnode consistent when passed to
d_open and d_close (unlocked). locked would be better, but has
some deadlock issues
 1.19.4.1  07-Sep-2001  thorpej Commit my "devvp" changes to the thorpej-devvp branch. This
replaces the use of dev_t in most places with a struct vnode *.

This will form the basic infrastructure for real cloning device
support (besides being architecurally cleaner -- it'll be good
to get away from using numbers to represent objects).
 1.19.2.2  10-Oct-2002  jdolecek sync kqueue with -current; this includes merge of gehenna-devsw branch,
merge of i386 MP branch, and part of autoconf rototil work
 1.19.2.1  10-Jan-2002  thorpej Sync kqueue branch with -current.
 1.28.8.1  16-May-2002  gehenna Add the character device switch.
 1.37.2.4  02-Nov-2004  skrll Sync with HEAD.
 1.37.2.3  21-Sep-2004  skrll Fix the sync with head I botched.
 1.37.2.2  18-Sep-2004  skrll Sync with HEAD.
 1.37.2.1  02-Jul-2003  darrenr Apply the aborted ktrace-lwp changes to a specific branch. This is just for
others to review, I'm concerned that patch fuziness may have resulted in some
errant code being generated but I'll look at that later by comparing the diff
from the base to the branch with the file I attempt to apply to it. This will,
at the very least, put the changes in a better context for others to review
them and attempt to tinker with removing passing of 'struct lwp' through
the kernel.
 1.38.12.6  17-Mar-2008  yamt sync with head.
 1.38.12.5  21-Jan-2008  yamt sync with head
 1.38.12.4  27-Oct-2007  yamt sync with head.
 1.38.12.3  03-Sep-2007  yamt sync with head.
 1.38.12.2  30-Dec-2006  yamt sync with head.
 1.38.12.1  21-Jun-2006  yamt sync with head.
 1.38.10.1  16-Sep-2006  ghen Pull up following revision(s) (requested by bouyer in ticket #1511):
sys/dev/pci/bktr/bktr_core.c: revision 1.38
sys/dev/pci/bktr/bktr_os.c: revision 1.43
sys/dev/pci/bktr/bktr_core.h: revision 1.8
stop attaching when a bus_dma operation fails, instead of using bogus
addresses.
Remplace vtophys() with proper bus_dma(9) use.
This driver now works properly on Xen
 1.39.12.1  31-Mar-2006  tron Merge 2006-03-31 NetBSD-current into the "peter-altq" branch.
 1.39.10.1  19-Apr-2006  elad sync with head.
 1.39.8.3  14-Sep-2006  yamt sync with head.
 1.39.8.2  03-Sep-2006  yamt sync with head.
 1.39.8.1  01-Apr-2006  yamt sync with head.
 1.39.6.1  22-Apr-2006  simonb Sync with head.
 1.39.4.1  09-Sep-2006  rpaulo sync with head
 1.40.6.1  14-Sep-2006  riz Pull up following revision(s) (requested by bouyer in ticket #151):
sys/dev/pci/bktr/bktr_core.c: revision 1.38
sys/dev/pci/bktr/bktr_os.c: revision 1.43
sys/dev/pci/bktr/bktr_core.h: revision 1.8
stop attaching when a bus_dma operation fails, instead of using bogus
addresses.
Remplace vtophys() with proper bus_dma(9) use.
This driver now works properly on Xen
 1.43.4.2  10-Dec-2006  yamt sync with head.
 1.43.4.1  22-Oct-2006  yamt sync with head
 1.43.2.1  18-Nov-2006  ad Sync with head.
 1.45.8.1  03-Jun-2008  skrll Sync with netbsd-4.
 1.45.4.1  12-Mar-2007  rmind Sync with HEAD.
 1.45.2.1  21-Jan-2008  bouyer Pull up following revision(s) (requested by jmcneill in ticket #1046):
sys/dev/pci/bktr/bktr_reg.h: revision 1.18
sys/dev/pci/bktr/bktr_audio.c: revision 1.18
sys/dev/pci/bktr/bktr_os.c: revision 1.49
sys/dev/pci/bktr/bktr_core.c: revision 1.46
sys/dev/ic/bt8xx.h: revision 1.9
sys/dev/pci/bktr/bktr_core.h: revision 1.10
Don't assume that sizeof(long) == sizeof(int); makes bktr work on amd64.
 1.46.18.1  06-Oct-2007  yamt sync with head.
 1.46.16.2  23-Mar-2008  matt sync with HEAD
 1.46.16.1  06-Nov-2007  matt sync with HEAD
 1.46.14.2  26-Oct-2007  joerg Sync with HEAD.

Follow the merge of pmap.c on i386 and amd64 and move
pmap_init_tmp_pgtbl into arch/x86/x86/pmap.c. Modify the ACPI wakeup
code to restore CR4 before jumping back into kernel space as the large
page option might cover that.
 1.46.14.1  02-Oct-2007  joerg Sync with HEAD.
 1.46.2.2  23-Oct-2007  ad Sync with head.
 1.46.2.1  09-Oct-2007  ad Sync with head.
 1.47.2.1  25-Oct-2007  bouyer Sync with HEAD.
 1.48.8.1  19-Jan-2008  bouyer Sync with HEAD
 1.48.2.1  18-Feb-2008  mjf Sync with HEAD.
 1.49.6.4  29-Jun-2008  mjf Sync with HEAD.
 1.49.6.3  02-Jun-2008  mjf Sync with HEAD.
 1.49.6.2  05-Apr-2008  mjf - add "file-system DEVFS" and "pseudo-device devfsctl" to conf/std seeing
as these are always needed.

- convert many, many drivers over to the New Devfs World Order. For a
list of device drivers yet to be converted see,
http://www.netbsd.org/~mjf/devfs-todo.html.

- add a new device_unregister_all(device_t) function to remove all device
names associated with a device_t, which saves us having to construct
device names when the driver is detached.

- add a DEV_AUDIO type for devices.
 1.49.6.1  03-Apr-2008  mjf Sync with HEAD.
 1.49.2.1  24-Mar-2008  keiichi sync with head.
 1.51.6.2  18-Sep-2008  wrstuden Sync with wrstuden-revivesa-base-2.
 1.51.6.1  23-Jun-2008  wrstuden Sync w/ -current. 34 merge conflicts to follow.
 1.51.4.3  11-Aug-2010  yamt sync with head.
 1.51.4.2  16-May-2009  yamt sync with head
 1.51.4.1  04-May-2009  yamt sync with head.
 1.51.2.1  17-Jun-2008  yamt sync with head.
 1.52.2.1  27-Jun-2008  simonb Sync with head.
 1.53.10.1  13-May-2009  jym Sync with HEAD.

Commit is split, to avoid a "too many arguments" protocol error.
 1.53.4.1  28-Apr-2009  skrll Sync with HEAD.
 1.57.4.1  30-May-2010  rmind sync with head
 1.57.2.1  30-Apr-2010  uebayasi Sync with HEAD.
 1.60.12.3  03-Dec-2017  jdolecek update from HEAD
 1.60.12.2  20-Aug-2014  tls Rebase to HEAD as of a few days ago.
 1.60.12.1  20-Nov-2012  tls Resync to 2012-11-19 00:00:00 UTC
 1.60.2.2  22-May-2014  yamt sync with head.

for a reference, the tree before this commit was tagged
as yamt-pagecache-tag8.

this commit was splitted into small chunks to avoid
a limitation of cvs. ("Protocol error: too many arguments")
 1.60.2.1  30-Oct-2012  yamt sync with head
 1.61.2.2  18-May-2014  rmind sync with head
 1.61.2.1  28-Aug-2013  rmind sync with head
 1.64.2.1  10-Aug-2014  tls Rebase.
 1.65.4.2  05-Oct-2016  skrll Sync with HEAD
 1.65.4.1  09-Jul-2016  skrll Sync with HEAD
 1.67.18.1  10-Jun-2019  christos Sync with HEAD
 1.67.16.1  26-Dec-2018  pgoyette Sync with HEAD, resolve a few conflicts

RSS XML Feed