little-atf-programmer


Namelittle-atf-programmer JSON
Version 2024.1019 PyPI version JSON
download
home_pageNone
SummaryLittle ATF150x Programmer Board utility programs
upload_time2024-11-23 10:50:33
maintainerNone
docs_urlNone
authorNone
requires_python>=3.9
licenseCopyright (c) 2024 The Really Old-School Company Limited Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. ############################## ############################## Portions Copyright (C) 2019-2020 whitequark@whitequark.org Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted. THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. ############################## ############################## Portions Copyright (c) 2015 Marcelo Roberto Jimenez <marcelo.jimenez (at) gmail (dot) com> All rights reserved. Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. ############################## ############################## Portions Copyright 2008, SoftPLC Corporation http://softplc.com Dick Hollenbeck dick@softplc.com This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, you may find one here: http://www.gnu.org/licenses/old-licenses/gpl-2.0.html or you may search the http://www.gnu.org website for the version 2 license, or you may write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
keywords cpld atf1502 atf1504 atf1508 logic programmer
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # Little ATF150x Programmer Board
## Software utilities

### What

This repository contains the official standard programmer software and utilities 
for the Little ATF150x Programmer Board.

![Picture of The Little ATF150x Programmer](https://github.com/roscopeco/atfprog-tools/raw/main/images/board.jpeg)

This is a plug-and-play USB-connected programmer and breakout board for
Atmel (Microchip) ATF150{2,4,8}{AS,ASV} CPLDs, featuring:

* Support for JED, SVF or XSVF files
* Support for both PLCC44 and 84 packages on-board
* Ability to drive ICSP via the JTAG headers (single-device only - chains **not** currently supported)
* Ability to erase JTAG-locked and secured devices

The board is **now available** on the on the [rosco_m68k store](https://store.rosco-m68k.com/products/little-atf-programmer) 🥳

### Software Installation

Prerequisites:

* Recent macOS, Linux or Windows operating system
* Working Python (3.9+) installation
  * Recent macOS and Linux will likely have this by default
  * If not, it can be installed with your package manager
  * Windows users can download from https://www.python.org/downloads/windows
  * `python` and `pip` should be in your `PATH` for easiest installation experience

> **Note**: on some systems, your `python` may instead be named `python3`, with `pip`
> being similarly named `pip3`. As long as Python is version 3.9 or higher 
> (as reported by `python3 --version`) it should work just fine.

#### Latest release

With a Python environment that meets these requirements, installation
is as simple as:

```shell
pip install little-atf-programmer
```

> **Note**: on Windows, when installing you may receive a message from pip
> warning that the installed binaries are not in your `PATH`. If you see this,
> for easier installation you may wish to add the directory in the warning
> to your `PATH` by editing in
> `Control Panel / System / Advanced / Environment Variables.`

#### From source

Developers and project collaborators may wish to install from source. 

To do this, clone the project from GitHub (or grab a source tarball).

Then either run `python src/atfu.py` or install with pip if you like:

```shell
pip install .
```

If you're hacking on the code, you'll probably want to install it `--editable`.

### Usage

#### General arguments

General command line arguments look like this:

```
atfu [-h] [--version] [-q] [-v] [-t] {program,erase,check,programmer} ...

Little ATF150x Programmer Board Utility

positional arguments:
  {scan,program,erase,check,verify,programmer}
    scan                Scan for ATF150x devices
    program             Program an ATF150x device
    erase               Erase an ATF150x device
    check               Check if an ATF150x device is blank
    verify              Verify an ATF150x device
    programmer          Little ATF150x Programmer Board device functions

options:
  -h, --help            show this help message and exit
  --version             show program's version number and exit
  -q, --quiet           Silence almost all output
  -v, --verbose         Allow additional output
  -t, --trace           Enable debugging output (can be noisy!)
```

#### Device scan mode

This mode is used to scan the connected ATF CPLD, and try to autodetect the specific
type of the chip.

By default, the first detected programmer will be used. This can be changed
with the `-p` option.

The `-n` option can be used to obtain unadorned output. This can be useful for
passing to other commands, or to `atfu` itself if you want to work with whatever
device is detected, e.g.

```shell
atfu program -d $(atfu scan -n) my_file.jed
```

Usage: 

```
atfu scan [-h] [-n] [-p PROGRAMMER]

options:
  -h, --help            show this help message and exit
  -n, --plain           Plain output, only the unadorned device name, no newline
  -p PROGRAMMER, --programmer PROGRAMMER
                        Programmer device (default: <detected>)
```
#### Program mode

This mode is used to program JEDEC, SVF or XSVF files to an ATF150x device.

By default, the first detected programmer will be used. This can be changed
with the `-p` option.

If you have problems programming, try erasing first with the `-e` option,
or force-erasing with the `-f` option, which can be useful when you have a
JTAG-locked or secured device.

```
atfu program [-h] [-e] [-f] [-d {ATF1502,ATF1504,ATF1508}] [-p PROGRAMMER] filename [filename ...]

positional arguments:
  filename              .jed, .svf or .xsvf file(s) to program

options:
  -h, --help            show this help message and exit
  -e, --erase           Erase before programming
  -f, --force           Force-erase before programming (implies -e)
  -d {ATF1502AS,ATF1504AS,ATF1508AS,ATF1502ASV,ATF1504ASV,ATF1508ASV}, --device {ATF1502AS,ATF1504AS,ATF1508AS,ATF1502ASV,ATF1504ASV,ATF1508ASV}
                        Device to program (default: ATF1502AS)
  -p PROGRAMMER, --programmer PROGRAMMER
                        Programmer device (default: <detected>)
```

#### Erase mode

This mode is used to erase an ATF150x device, and can also be used to 
force erase JTAG-locked or secured devices.

By default, the first detected programmer will be used. This can be changed
with the `-p` option.

> **Note** that the force mode might be... _stressful_ for your device, 
> so try a regular erase first :)

```
atfu erase [-h] [-f] [-p PROGRAMMER] [-d {ATF1502,ATF1504,ATF1508}]

options:
  -h, --help            show this help message and exit
  -f, --force           Force erase
  -p PROGRAMMER, --programmer PROGRAMMER
                        Programmer device (default: <detected>)
  -d {ATF1502AS,ATF1504AS,ATF1508AS,ATF1502ASV,ATF1504ASV,ATF1508ASV}, --device {ATF1502AS,ATF1504AS,ATF1508AS,ATF1502ASV,ATF1504ASV,ATF1508ASV}
                        Device to erase (default: ATF1502AS)
```

#### Check mode

This mode is used to determine whether an ATF150x device is blank.

By default, the first detected programmer will be used. This can be changed
with the `-p` option.

```
atfu check [-h] [-p PROGRAMMER] [-d {ATF1502,ATF1504,ATF1508}]

options:
  -h, --help            show this help message and exit
  -p PROGRAMMER, --programmer PROGRAMMER
                        Programmer device (default: <detected>)
  -d {ATF1502AS,ATF1504AS,ATF1508AS,ATF1502ASV,ATF1504ASV,ATF1508ASV}, --device {ATF1502AS,ATF1504AS,ATF1508AS,ATF1502ASV,ATF1504ASV,ATF1508ASV}
                        Device to check (default: ATF1502AS)
```

#### Verify mode

This mode is used to verify the contents of an ATF150x device against a JESD3-C (.jed) file.

By default, the first detected programmer will be used. This can be changed
with the `-p` option.

**Verification cannot be performed against SVF or XSVF files**. The expectation for those is that
verification would be encoded into the vectors themselves.

```
atfu verify [-h] [-d {ATF1502,ATF1504,ATF1508,ATF1502AS,ATF1504AS,ATF1508AS,ATF1502ASV,ATF1504ASV,ATF1508ASV}] [-p PROGRAMMER] filename [filename ...]

positional arguments:
  filename              .jed file(s) to verify against

options:
  -h, --help            show this help message and exit
  -d {ATF1502,ATF1504,ATF1508,ATF1502AS,ATF1504AS,ATF1508AS,ATF1502ASV,ATF1504ASV,ATF1508ASV}, --device {ATF1502,ATF1504,ATF1508,ATF1502AS,ATF1504AS,ATF1508AS,ATF1502ASV,ATF1504ASV,ATF1508ASV}
                        Device to verify (default: ATF1502AS)
  -p PROGRAMMER, --programmer PROGRAMMER
                        Programmer device (default: <detected>)
```

#### Programmer mode

This mode can be used to list detected programmer boards, and query them.

```
atfu programmer [-h] {list,query} ...

positional arguments:
  {list,query}

options:
  -h, --help    show this help message and exit


atfu programmer list [-h] [--plain]

Functions for listing connected programmers

options:
  -h, --help   show this help message and exit
  -n, --plain  Display a plain list of device paths
```

### Copyright

Copyright ©2024 [The Really Old-School Company Limited](https://rosco_m68k.com).

Portions Copyright (C) 2019-2020 whitequark@whitequark.org

Portions Copyright (c) 2015 Marcelo Roberto Jimenez <marcelo.jimenez (at) gmail (dot) com>

Portions Copyright 2008, SoftPLC Corporation  http://softplc.com [Dick Hollenbeck dick@softplc.com]

Mostly MIT License, portions under other licenses - see LICENSE.md & source code comments.



            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "little-atf-programmer",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.9",
    "maintainer_email": null,
    "keywords": "cpld, atf1502, atf1504, atf1508, logic, programmer",
    "author": null,
    "author_email": "The Really Old-School Company Limited <info@rosco-m68k.com>",
    "download_url": "https://files.pythonhosted.org/packages/f6/54/932778de12322a0d693d562e669120bcd46676ef1fc6db94eb0638ed015d/little_atf_programmer-2024.1019.tar.gz",
    "platform": null,
    "description": "# Little ATF150x Programmer Board\n## Software utilities\n\n### What\n\nThis repository contains the official standard programmer software and utilities \nfor the Little ATF150x Programmer Board.\n\n![Picture of The Little ATF150x Programmer](https://github.com/roscopeco/atfprog-tools/raw/main/images/board.jpeg)\n\nThis is a plug-and-play USB-connected programmer and breakout board for\nAtmel (Microchip) ATF150{2,4,8}{AS,ASV} CPLDs, featuring:\n\n* Support for JED, SVF or XSVF files\n* Support for both PLCC44 and 84 packages on-board\n* Ability to drive ICSP via the JTAG headers (single-device only - chains **not** currently supported)\n* Ability to erase JTAG-locked and secured devices\n\nThe board is **now available** on the on the [rosco_m68k store](https://store.rosco-m68k.com/products/little-atf-programmer) \ud83e\udd73\n\n### Software Installation\n\nPrerequisites:\n\n* Recent macOS, Linux or Windows operating system\n* Working Python (3.9+) installation\n  * Recent macOS and Linux will likely have this by default\n  * If not, it can be installed with your package manager\n  * Windows users can download from https://www.python.org/downloads/windows\n  * `python` and `pip` should be in your `PATH` for easiest installation experience\n\n> **Note**: on some systems, your `python` may instead be named `python3`, with `pip`\n> being similarly named `pip3`. As long as Python is version 3.9 or higher \n> (as reported by `python3 --version`) it should work just fine.\n\n#### Latest release\n\nWith a Python environment that meets these requirements, installation\nis as simple as:\n\n```shell\npip install little-atf-programmer\n```\n\n> **Note**: on Windows, when installing you may receive a message from pip\n> warning that the installed binaries are not in your `PATH`. If you see this,\n> for easier installation you may wish to add the directory in the warning\n> to your `PATH` by editing in\n> `Control Panel / System / Advanced / Environment Variables.`\n\n#### From source\n\nDevelopers and project collaborators may wish to install from source. \n\nTo do this, clone the project from GitHub (or grab a source tarball).\n\nThen either run `python src/atfu.py` or install with pip if you like:\n\n```shell\npip install .\n```\n\nIf you're hacking on the code, you'll probably want to install it `--editable`.\n\n### Usage\n\n#### General arguments\n\nGeneral command line arguments look like this:\n\n```\natfu [-h] [--version] [-q] [-v] [-t] {program,erase,check,programmer} ...\n\nLittle ATF150x Programmer Board Utility\n\npositional arguments:\n  {scan,program,erase,check,verify,programmer}\n    scan                Scan for ATF150x devices\n    program             Program an ATF150x device\n    erase               Erase an ATF150x device\n    check               Check if an ATF150x device is blank\n    verify              Verify an ATF150x device\n    programmer          Little ATF150x Programmer Board device functions\n\noptions:\n  -h, --help            show this help message and exit\n  --version             show program's version number and exit\n  -q, --quiet           Silence almost all output\n  -v, --verbose         Allow additional output\n  -t, --trace           Enable debugging output (can be noisy!)\n```\n\n#### Device scan mode\n\nThis mode is used to scan the connected ATF CPLD, and try to autodetect the specific\ntype of the chip.\n\nBy default, the first detected programmer will be used. This can be changed\nwith the `-p` option.\n\nThe `-n` option can be used to obtain unadorned output. This can be useful for\npassing to other commands, or to `atfu` itself if you want to work with whatever\ndevice is detected, e.g.\n\n```shell\natfu program -d $(atfu scan -n) my_file.jed\n```\n\nUsage: \n\n```\natfu scan [-h] [-n] [-p PROGRAMMER]\n\noptions:\n  -h, --help            show this help message and exit\n  -n, --plain           Plain output, only the unadorned device name, no newline\n  -p PROGRAMMER, --programmer PROGRAMMER\n                        Programmer device (default: <detected>)\n```\n#### Program mode\n\nThis mode is used to program JEDEC, SVF or XSVF files to an ATF150x device.\n\nBy default, the first detected programmer will be used. This can be changed\nwith the `-p` option.\n\nIf you have problems programming, try erasing first with the `-e` option,\nor force-erasing with the `-f` option, which can be useful when you have a\nJTAG-locked or secured device.\n\n```\natfu program [-h] [-e] [-f] [-d {ATF1502,ATF1504,ATF1508}] [-p PROGRAMMER] filename [filename ...]\n\npositional arguments:\n  filename              .jed, .svf or .xsvf file(s) to program\n\noptions:\n  -h, --help            show this help message and exit\n  -e, --erase           Erase before programming\n  -f, --force           Force-erase before programming (implies -e)\n  -d {ATF1502AS,ATF1504AS,ATF1508AS,ATF1502ASV,ATF1504ASV,ATF1508ASV}, --device {ATF1502AS,ATF1504AS,ATF1508AS,ATF1502ASV,ATF1504ASV,ATF1508ASV}\n                        Device to program (default: ATF1502AS)\n  -p PROGRAMMER, --programmer PROGRAMMER\n                        Programmer device (default: <detected>)\n```\n\n#### Erase mode\n\nThis mode is used to erase an ATF150x device, and can also be used to \nforce erase JTAG-locked or secured devices.\n\nBy default, the first detected programmer will be used. This can be changed\nwith the `-p` option.\n\n> **Note** that the force mode might be... _stressful_ for your device, \n> so try a regular erase first :)\n\n```\natfu erase [-h] [-f] [-p PROGRAMMER] [-d {ATF1502,ATF1504,ATF1508}]\n\noptions:\n  -h, --help            show this help message and exit\n  -f, --force           Force erase\n  -p PROGRAMMER, --programmer PROGRAMMER\n                        Programmer device (default: <detected>)\n  -d {ATF1502AS,ATF1504AS,ATF1508AS,ATF1502ASV,ATF1504ASV,ATF1508ASV}, --device {ATF1502AS,ATF1504AS,ATF1508AS,ATF1502ASV,ATF1504ASV,ATF1508ASV}\n                        Device to erase (default: ATF1502AS)\n```\n\n#### Check mode\n\nThis mode is used to determine whether an ATF150x device is blank.\n\nBy default, the first detected programmer will be used. This can be changed\nwith the `-p` option.\n\n```\natfu check [-h] [-p PROGRAMMER] [-d {ATF1502,ATF1504,ATF1508}]\n\noptions:\n  -h, --help            show this help message and exit\n  -p PROGRAMMER, --programmer PROGRAMMER\n                        Programmer device (default: <detected>)\n  -d {ATF1502AS,ATF1504AS,ATF1508AS,ATF1502ASV,ATF1504ASV,ATF1508ASV}, --device {ATF1502AS,ATF1504AS,ATF1508AS,ATF1502ASV,ATF1504ASV,ATF1508ASV}\n                        Device to check (default: ATF1502AS)\n```\n\n#### Verify mode\n\nThis mode is used to verify the contents of an ATF150x device against a JESD3-C (.jed) file.\n\nBy default, the first detected programmer will be used. This can be changed\nwith the `-p` option.\n\n**Verification cannot be performed against SVF or XSVF files**. The expectation for those is that\nverification would be encoded into the vectors themselves.\n\n```\natfu verify [-h] [-d {ATF1502,ATF1504,ATF1508,ATF1502AS,ATF1504AS,ATF1508AS,ATF1502ASV,ATF1504ASV,ATF1508ASV}] [-p PROGRAMMER] filename [filename ...]\n\npositional arguments:\n  filename              .jed file(s) to verify against\n\noptions:\n  -h, --help            show this help message and exit\n  -d {ATF1502,ATF1504,ATF1508,ATF1502AS,ATF1504AS,ATF1508AS,ATF1502ASV,ATF1504ASV,ATF1508ASV}, --device {ATF1502,ATF1504,ATF1508,ATF1502AS,ATF1504AS,ATF1508AS,ATF1502ASV,ATF1504ASV,ATF1508ASV}\n                        Device to verify (default: ATF1502AS)\n  -p PROGRAMMER, --programmer PROGRAMMER\n                        Programmer device (default: <detected>)\n```\n\n#### Programmer mode\n\nThis mode can be used to list detected programmer boards, and query them.\n\n```\natfu programmer [-h] {list,query} ...\n\npositional arguments:\n  {list,query}\n\noptions:\n  -h, --help    show this help message and exit\n\n\natfu programmer list [-h] [--plain]\n\nFunctions for listing connected programmers\n\noptions:\n  -h, --help   show this help message and exit\n  -n, --plain  Display a plain list of device paths\n```\n\n### Copyright\n\nCopyright \u00a92024 [The Really Old-School Company Limited](https://rosco_m68k.com).\n\nPortions Copyright (C) 2019-2020 whitequark@whitequark.org\n\nPortions Copyright (c) 2015 Marcelo Roberto Jimenez <marcelo.jimenez (at) gmail (dot) com>\n\nPortions Copyright 2008, SoftPLC Corporation  http://softplc.com [Dick Hollenbeck dick@softplc.com]\n\nMostly MIT License, portions under other licenses - see LICENSE.md & source code comments.\n\n\n",
    "bugtrack_url": null,
    "license": "Copyright (c) 2024 The Really Old-School Company Limited  Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the \"Software\"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:  The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.  THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.   ############################## ##############################   Portions Copyright (C) 2019-2020 whitequark@whitequark.org  Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted.  THE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.   ############################## ##############################   Portions Copyright (c) 2015 Marcelo Roberto Jimenez <marcelo.jimenez (at) gmail (dot) com> All rights reserved.  Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:  1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.  2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.   ############################## ##############################   Portions Copyright 2008, SoftPLC Corporation  http://softplc.com Dick Hollenbeck dick@softplc.com   This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.  This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more details.  You should have received a copy of the GNU General Public License along with this program; if not, you may find one here: http://www.gnu.org/licenses/old-licenses/gpl-2.0.html or you may search the http://www.gnu.org website for the version 2 license, or you may write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA   ",
    "summary": "Little ATF150x Programmer Board utility programs",
    "version": "2024.1019",
    "project_urls": {
        "Homepage": "https://github.com/roscopeco/atfprog-tools"
    },
    "split_keywords": [
        "cpld",
        " atf1502",
        " atf1504",
        " atf1508",
        " logic",
        " programmer"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "e3098d4f3def33a5d11f8c95ba866f162615b330033ef43b6fea565a9cab1c68",
                "md5": "a475deb10651b34e5ea899851bc0b121",
                "sha256": "67b4a8c7b511787375b9689f8f3f4714f0d294588dcae868427c0a8e7d34ace2"
            },
            "downloads": -1,
            "filename": "little_atf_programmer-2024.1019-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "a475deb10651b34e5ea899851bc0b121",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.9",
            "size": 69939,
            "upload_time": "2024-11-23T10:50:31",
            "upload_time_iso_8601": "2024-11-23T10:50:31.398270Z",
            "url": "https://files.pythonhosted.org/packages/e3/09/8d4f3def33a5d11f8c95ba866f162615b330033ef43b6fea565a9cab1c68/little_atf_programmer-2024.1019-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "f654932778de12322a0d693d562e669120bcd46676ef1fc6db94eb0638ed015d",
                "md5": "c7feeb6de864b2f69380a41419628b36",
                "sha256": "41eeb08c0a4dac443a572af1305c9c70b6f3bbae545637d11891224b52473713"
            },
            "downloads": -1,
            "filename": "little_atf_programmer-2024.1019.tar.gz",
            "has_sig": false,
            "md5_digest": "c7feeb6de864b2f69380a41419628b36",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.9",
            "size": 70228,
            "upload_time": "2024-11-23T10:50:33",
            "upload_time_iso_8601": "2024-11-23T10:50:33.468966Z",
            "url": "https://files.pythonhosted.org/packages/f6/54/932778de12322a0d693d562e669120bcd46676ef1fc6db94eb0638ed015d/little_atf_programmer-2024.1019.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-11-23 10:50:33",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "roscopeco",
    "github_project": "atfprog-tools",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "requirements": [],
    "lcname": "little-atf-programmer"
}
        
Elapsed time: 3.66485s