Metadata-Version: 2.4
Name: pyspiflash
Version: 0.6.5
Summary: SPI data flash device drivers (pure Python)
Home-page: http://github.com/eblot/pyspiflash
Author: Emmanuel Blot
Author-email: emmanuel.blot@free.fr
Maintainer: Emmanuel Blot
Maintainer-email: emmanuel.blot@free.fr
License: MIT
Keywords: driver,ftdi,usb,spi,flash,mtd
Classifier: Development Status :: 4 - Beta
Classifier: Environment :: Other Environment
Classifier: Natural Language :: English
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: MacOS :: MacOS X
Classifier: Operating System :: POSIX
Classifier: Operating System :: Microsoft :: Windows
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Classifier: Topic :: System :: Hardware :: Hardware Drivers
Requires-Python: >=3.5
License-File: LICENSE
Requires-Dist: pyftdi<0.60,>=0.42
Dynamic: author
Dynamic: author-email
Dynamic: classifier
Dynamic: description
Dynamic: home-page
Dynamic: keywords
Dynamic: license
Dynamic: license-file
Dynamic: maintainer
Dynamic: maintainer-email
Dynamic: requires-dist
Dynamic: requires-python
Dynamic: summary

pyspiflash
==========

.. image:: https://github.com/eblot/pyspiflash/workflows/Python%20package/badge.svg
   :alt: Python package build status

SPI data flash device drivers (pure Python)

SPI flash devices, also known as *DataFlash* are commonly found in embedded
products, to store firmware, microcode or configuration parameters.

PySpiFlash_ comes with several pure Python drivers for those flash devices, that
demonstrate use of SPI devices with PyFtdi_. It could also be useful to dump
flash contents or recover from a bricked devices.

.. _PySpiFlash : https://github.com/eblot/pyspiflash
.. _Python: http://python.org/
.. _PyFtdi : https://github.com/eblot/pyftdi

Supported SPI flash devices
---------------------------

============= ======= ========== ======== ====== ======= ========== ==========
Vendor        Atmel   Atmel      Macronix SST    Winbond  Micron     Adesto
------------- ------- ---------- -------- ------ ------- ---------- ----------
DataFlash     AT45_   AT25_      MX25L_   SST25_ W25Q_   N25Q       AT25XE041B_
============= ======= ========== ======== ====== ======= ========== ==========
Status        Tested  Tested     Tested   Tested Tested  Tested     Tested
------------- ------- ---------- -------- ------ ------- ---------- ----------
Sizes (MiB)       2,4      2,4,8 2,4,8,16    2,4     2,4 8          0.5
------------- ------- ---------- -------- ------ ------- ---------- ----------
Read (KiB/s)     1278       1279     1329    642    1252 1315       1695
------------- ------- ---------- -------- ------ ------- ---------- ----------
Write (KiB/s)      56         64       71      2      63 107        32
------------- ------- ---------- -------- ------ ------- ---------- ----------
Erase (KiB/s)      60         63       31    500      60 84         28
============= ======= ========== ======== ====== ======= ========== ==========

Other supported SPI flash devices
---------------------------------

Support for the following devices have also been added, but have not been tested
by the maintainer:

* Boya BY25QxxB
* GigaDevice GD25QxxB
* Spansion S25FL, S25FS

Notes about performances
........................

* *Read* operation is synchronous with SPI bus clock: it therefore only depends
  on the achievable frequency on the SPI bus, which is bound to the highest
  supported frequency of the flash device.
* *Write* operation depends mostly on the flash device performance, whose upper
  limit comes mostly from the maximum write packet size of the device, as the
  device needs to be polled for completion after each packet: the shorter the
  packet, the higher traffic on the SPI and associated overhead.
* *Erase* operation depends mostly on the flash device performance, whose fully
  depends on the flash device internal technology, as very few and short
  packets are exchanged over the SPI bus.

Supporting new flash devices of series '25'
...........................................

Many flash devices support a common subset to for read/write/erase operations.
Critical differences appear with lock and protection features, and with
security features. An NDA is often required to obtain details about the
advanced security features of these devices.

It should be nevertheless quite easy to add support for new flash device
variants:

* ``match`` method in the PyFtdi flash device API should be the first to look
  at to detect more compatible flash devices.

.. _AT45: http://www.adestotech.com/sites/default/files/datasheets/doc8784.pdf
.. _AT25: http://www.atmel.com/Images/doc8693.pdf
.. _SST25: http://ww1.microchip.com/downloads/en/DeviceDoc/25071A.pdf
.. _MX25L: http://www.mxic.com.tw/
.. _W25Q: http://www.nexflash.com/hq/enu/ProductAndSales/ProductLines/FlashMemory/SerialFlash/
.. _AT25XE041B: https://www.adestotech.com/wp-content/uploads/DS-AT25XE041B_062.pdf

Supported SPI flash commands
----------------------------

Identification
  The SPI device driver is automatically selected based on the detected SPI
  flash device

Read
  Read byte sequences of any size, starting at any location from the SPI
  flash device

Write
  Write arbitrary byte sequences of any size, starting at any location to the
  SPI flash device

Erase
  Erase SPI flash device blocks, whose size depend on the capabilities of the
  flash device, typically 4KiB and/or 64KiB.

Unlock
  Unlock any protected flash device sectors

Dependencies
------------

* Python_ 3.9 or above is required.
* PyFTDI_ 0.42 or above is required.

Note about previous releases
............................

If you have no choice but using previous releases of Python (including Python
2.x) or PyFTDI_ , please checkout the latest PySpiFlash_ 0.4.1 which provides
support for these deprecated environmement, but is no longer actively
maintained.

PySpiFlash_ heavily relies on PyFtdi_ module to access the SPI flash device.
The PyFtdi_ API has been changed several times, see the compatibility matrix
below.

The ``setup.py`` script should take care of those dependencies.

==================== ===============
PySpiFlash_ version  PyFtdi_ version
-------------------- ---------------
0.2.*                0.9 .. 0.10
0.3.*                0.11+
0.4.*                0.13.2+
0.5.*                0.20.0+
0.6.*                0.42.0+
==================== ===============
