; $URL: http://subversion:8080/svn/gsc/trunk/drivers/LINUX/PEX8111/PEX8111_Linux_1.x.x.x_GSC_DN/doc/release.txt $
; $Rev: 51710 $
; $Date: 2022-10-10 14:06:24 -0500 (Mon, 10 Oct 2022) $

PEX8111: Linux Driver Release Notes

Revision History
================

--------------------------------------------------------------------------------

Version 2.2.101.43.0, Released 10/10/2022

driver: Removed compiler warning for Fedora Fedora 35.
driver: White space cleanup.
driver: Improved driver start script.
driver: Updated per changes to directory organization.
driver: Updated comments for consistency.
driver: Removed unintended debug output statements.
driver: Renamed gsc_irq_reset_pci to gsc_irq_cpi_reset for consistency.
driver: Segregated additional PLX specific code.
driver: Updated system message to begin with the driver module name.
driver: Began implementation for MSI support.
driver: Segregated all PLX specific code to accommodate alternate device implementations.
driver: Updated debugging display output.
driver: LINTed sources.
driver: Added temporary experimental write code in gsc_write.c for performance testing.
driver: The code is partially retained but is not included for compilation.
driver: Fixed a DMA bug relating to the use of a timeout setting of zero.
driver: Updated for changes to Red Hat Enterprise Linux 8.6.
driver: Added the os_irq_t.created field.
driver: Updated os_irq_create, destroy, open and close services.
driver: Removed unused debugging messages.
driver: Began implementing MSI support.
driver: Added macro DEV_IRQ_SHOW to report assigned IRQ assigned to device.
driver: Removed unused macros.
driver: Updated for the 5.14 kernel.
driver: Made spelling corrections in version notes.
driver: Changed all printk instances to printf to support porting activities.
driver: Expanded files removed for a clean operation.
driver: Updated to support the 5.9 kernel.
driver: Modified os_common.h so application code compiles under Cygwin.
driver: Reduced the minimum tick sleep from 1 to 0 ticks.
driver: Modified debug specific register access code to enhance usage.

--------------------------------------------------------------------------------

Version 2.1.93.35.0, Released 1/11/2021

driver: Added support for the 5.x kernel series.
driver: Added Endianness support.
driver: Removed compiler warnings for Fedora 31.
driver: Updated initial file content for consistency.
driver: White space cleanup.
driver: Renumbered the QUERY options.
driver: Updated per changes to the low level register interface.
driver: Updated per changes to the OS specific PCI services.
driver: Made updates for DEV_SUPPORTS_XXX macro changes.
driver: Corrected endian error message.
driver: Added Endianess support for the PEX8111 and PEX8112.
driver: Fixed a timeout bug in gsc_write_pio_work_32_bit().
driver: Updated IRQ code for improved clarity and modularity.
driver: Updated DMA code to support multiple DMA implementations.
driver: Removed I/O debug code.
driver: Removed compiler warnings under Windows.
driver: Fixed a IOCTL bug in which alt->sem wasn't being unlocked.
driver: Increased modularization for porting effort to another OS.
driver: Made DMA code more modular.
driver: Added support for Big Endian hosts.
driver: Updated per OS specific DMA memory allocation interface.
driver: Fixed bug in gsc_dma_perform(): timeouts were being ignored.
driver: Fixed bug in gsc_dma_perform(): the timeout detection logic was incorrect.
driver: Improved register validation.
driver: Subsystem Vendor ID and Subsystem ID can each be ignored if -1 in device table.
driver: #define for GSC_REG_ENCODE_MASK is moved here from gsc_reg.c.
driver: Enhanced error reporting for the process of validating register definitions.
driver: Fixed bug in DMA completion code.
driver: Updated initialization for the write service.
driver: Updated muti-channel ISR code for new I/O streams structure.
driver: DEV_WAIT_IO_ALL is now required if WAIT is supported along with READ or WRITE
driver: I/O WAIT macros are now defined by the device API and are passed to GSC code in dev_io_t.
driver: Updated Block Mode DMA macro name (_DMA to _BMDMA).
driver: Added I/O, DMA and register access debug code.
driver: Added stream selection field in the "size" argument for the read and writecalls.
driver: Added OS IRQ calls: os_irq_create() and os_irq_destroy()
driver: Renamed field in gsc_irq_t for clarity.
driver: Fixed a bug in which wait list node removal didn't always have the list locked.
driver: Added support for some DMA metrics.
driver: Improved IOCTL argument validation.
driver: Moved a typedef to device specific code.
driver: Udated some utility services: applying a setting, end by reading it back
driver: Updated for support of some drivers under older kernels.
driver: Updated #include files for consistancy.
driver: Fixed a DMA timeout calculation bug.
driver: Updated to accommodate porting to Windows KMDF.
driver: Updated the driver initialization logic.
driver: Updated IOCTL init and reset code.
driver: Added support to exclude the WAIT feature.
driver: Updated macros to include/exclude IRQ support.
driver: Fixed bug in init code where last PCI device is one of ours.
driver: Improvved Red Hat Enterprise Linux 8.x detection logic.
driver: Added support under the 4.x kernel for Red Hat Enterprise Linux 8.x.
driver: Added validation checking of the interrupt number in os_irq_open().
driver: Updated the /proc/ code for changes in the 5.6.6 kernel.
driver: Updated memory code for improved clarity and modularity.
driver: Code cleanup in open service.
driver: Fixed open bug applicable to multi-board devices.
driver: Made mods to accommodatedate porting to another OS.
driver: Added DMA support for an IOMMU.
driver: Added error reporting when DMA memory cound not be allocated.
driver: Reduced code included when read and writ are both unsupported.
driver: Added error reporting when IRQ cound not be acquired during open requests.
driver: Some minor code reorganization.
driver: Updated BAR creation logic.
driver: Implemented support for a stream selection field in the I/O bytes argument.
driver: Implemented register access debug code.
driver: Implemented calls: os_irq_create() and os_irq_destroy()
driver: Field in gsc_irq_t renamed for clarity.
driver: Changed macro name for clarity.
driver: Updated to accommodate Fedora 27.
driver: Updated the low level register interface.

--------------------------------------------------------------------------------

Version 2.0.69.18.0, Released 12/7/2016

driver: Updated to use the newer common driver sources.
driver: Removed GNU notice from non-Linux specific files.
driver: Removed Linux specific content from non-Linux specific source files.
driver: White space cleanup.
driver: Now using a spinlock rather than enabling and disabling interrupts.
driver: Made PCI registers accessible from inside an ISR.
driver: The BAR code has been updated to include the data under a single structure.
driver: The register definitions have been updated.
driver: White space cleanup.
driver: Changed the arbitrary wait event callback argument to a void* type.
driver: Modified to allow multiple apps to simultaneously access a single device.
driver: Corrected the IOCTL code for the register write and mod services.

--------------------------------------------------------------------------------

Version 1.7.52.0, Released 2/28/2014

Driver version 1.7.52
Driver: Reduced #include list in driver interface header.
Additional LINTing.
White space cleanup.

--------------------------------------------------------------------------------

Version 1.6.51.0, Released 1/9/2014

Driver version 1.6.51
Driver: Modified the conditional definition of flags used by kmalloc().
Driver: Updated /proc file support for the 3.10 kernel changes.
Driver: Additional porting for the 2.2 kernel.

--------------------------------------------------------------------------------

Version 1.6.49.0, Released 11/13/2013

Driver version 1.5.49
Driver: The IOCTL command code is now treated as an integer.
Driver: Numerous minor changes for LINTing of the code.
Driver: Numerous updates for Concurrent and for PEX8311 issues.

--------------------------------------------------------------------------------

Version 1.6.45.0, Released 7/17/2013

Driver version 1.5.45
Driver: Added PEX8111_IOCTL_MAX_READ_REQ_SIZE.
Driver: Renamed PEX8111_IOCTL_PREFETCH_ENABLE to PEX8111_IOCTL_BLIND_PREFETCH.
Driver: Removed PEX8111_QUERY_PREFETCH_SIZE_LIM.
id: Updated for driver API change.
payload: Altered some output text.
prefetch: Altered some text output.
prefetch: Updated for driver API change.
prefetch: Added the -fcc+ and -fcc- command line arguments.

--------------------------------------------------------------------------------

Version 1.5.41.0, Released 4/8/2013

Driver version 1.5.41
Driver: Added the IOCTL service PEX8111_IOCTL_PAYLOAD_SIZE_MAX.
payload: Add sample application to the release.
utils: Added file util_payload_size_max.c.

--------------------------------------------------------------------------------

Version 1.4.39.1, Released 7/25/2012

Driver version 1.4.39
Driver: Corrected a bug in the Prefetch Enable service.
Made corrections to the user manual.

--------------------------------------------------------------------------------

Version 1.3.39.0, Released 7/24/2012

Driver version 1.3.39
Driver: Updated for the 3.x kernel.
Driver: Added support for boards that need additional setup after a DMA channel has been selected.
Driver: Made the IOCTL buffer larger - 512 bytes.
Driver: Removed compile warnings from the copy_from_user_ret macro.
Updated makefiles for consistency.
Applications: Updated the parameter list to gsc_id_driver().

--------------------------------------------------------------------------------

Version 1.2.34.0, Released 12/27/2011

Driver version 1.2.34
id: Set the default board selection to zero when only one board bresent.
id: Corrected a bug in main() where errs was not initialized.
Split the utility code into two libraries: common and device specific.

--------------------------------------------------------------------------------

Version 1.1.33.0, Released 12/6/2011

Driver version 1.1.33
Driver: Added several query options.
Driver: Added several IOCTL services.
id: Expanded id information to include: Payload Size Capability, Payload Size
	Configuration, Prefetch Size Limit and Cache Line Size.
prefetch: Added to release.

--------------------------------------------------------------------------------

Version 1.0.32.0, Released 11/2/2011

Driver version 1.0.32
Initial release

--------------------------------------------------------------------------------
