Project home: https://bues.ch/a/profibus Original repository at: https://git.bues.ch/git/pyprofibus.git https://bues.ch/a/profibus

Michael Buesch 1d323cefb4 Small cleanups 1 year ago
debian a732cc7ec3 Bump version 1 year ago
doc f2f3d98611 doc: Fix yosys links 2 years ago
examples 8760b66b70 linuxcnc-hal: Provide information about connection status 2 years ago
maintenance 2609ba723c Fix generating documentation 2 years ago
micropython 2d93987064 micropython: Fixes for moved examples 2 years ago
misc 1ed8a3484a Remove Python2/Cython2 support 4 years ago
phy_fpga b01d4ca760 Update fpgamakelib 1 year ago
pyprofibus 1d323cefb4 Small cleanups 1 year ago
stublibs 18ead5c7c2 stub/configparser: Minor fixes and improvements of error texts 3 years ago
tests bc1490e908 tests: Add testcase for connection status 2 years ago
.gitignore 67495644a2 doc: Convert to RST 3 years ago
.gitmodules d0ef8d44fe fpga: Update makefiles 3 years ago
COPYING 076c799f00 Initial commit 8 years ago
MANIFEST.in 381499d8ca Move LinuxCNC demo to examples directory 2 years ago
README.rst 20ba3a28a7 Update Readme 1 year ago
gsdparser f0bf510eaf gsdparser: Add option to set output file 3 years ago
profisniff 692377512c phy_serial: Some simple speed optimizations 3 years ago
pyprofibus-linuxcnc-hal 899cb8b7f1 linuxcnc-hal: Avoid dead time between connecting and connected state 2 years ago
setup.py 78f06da789 Use setuptools instead of distutils 2 years ago

README.rst

pyprofibus - PROFIBUS-DP stack
==============================

`https://bues.ch/a/profibus `_

pyprofibus is an Open Source `PROFIBUS-DP `_ stack written in Python.


Hardware
========

pyprofibus is able to run on any machine that supports Python. It also runs on embedded machines such as the `Raspberry Pi `_ or even tiny microcontrollers such as the `ESP32 `_ (Micropython).

Please read the hardware documentation for more information:

`pyprofibus hardware documentation `_


Speed / Baud rate
=================

The achievable Profibus-DP speed depends on the hardware that it runs on and what kind of serial transceiver is used. There is no software side artificial limit.

Please see the `pyprofibus hardware documentation `_


Examples
========

pyprofibus comes with a couple of examples that can teach you how to use pyprofibus in your project.

* Example that runs pyprofibus without any hardware. This example can be used to play around with pyprofibus.
* examples/example_dummy_oneslave.py
* examples/example_dummy_oneslave.conf
* examples/example_dummy_twoslaves.py
* examples/example_dummy_twoslaves.conf
* examples/example_dummy_inputonly.py
* examples/example_dummy_inputonly.conf

* Example that runs pyprofibus as master connected to an ET200S as slave.
* examples/example_et200s.py
* examples/example_et200s.conf

* Example that runs pyprofibus as master connected to an S7-315-2DP as *slave*.
* examples/example_s7-315-2dp.py
* examples/example_s7-315-2dp.conf


Dependencies
============

* `Python `_ 3.5 or later.
* Or alternatively `Micropython `_. Please see the `pyprofibus Micropython help `_ for more information.


License
=======

Copyright (c) 2013-2023 Michael Buesch

Licensed under the terms of the GNU General Public License version 2, or (at your option) any later version.