Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jmojiwat/libmpssenet
F# thin wrapper around FTDI Chip Multi Protocol Synchronous Serial Engine (MPSSE) 1.0.5.
https://github.com/jmojiwat/libmpssenet
fsharp ftdi mpsse
Last synced: about 1 month ago
JSON representation
F# thin wrapper around FTDI Chip Multi Protocol Synchronous Serial Engine (MPSSE) 1.0.5.
- Host: GitHub
- URL: https://github.com/jmojiwat/libmpssenet
- Owner: jmojiwat
- Created: 2024-03-15T03:08:00.000Z (10 months ago)
- Default Branch: master
- Last Pushed: 2024-03-25T07:17:24.000Z (9 months ago)
- Last Synced: 2024-11-21T04:36:46.390Z (about 1 month ago)
- Topics: fsharp, ftdi, mpsse
- Language: F#
- Homepage:
- Size: 59.6 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# LibMpsseNet
LibMpsseNet is a thin F# wrapper for FTDI Chip Multi Protocol Synchronous Serial Engine (MPSSE) library 1.0.5.
MPSSE provides a flexible means of interfacing synchronous serial devices to a USB port. The FT-serices device supported includes the FT2232D, FT2232H, FT4232H and FT232H.
## Requirements
LibMpsseNet requires libmpsse.lib C library to be present from the [LibMPSSE library](https://ftdichip.com/wp-content/uploads/2024/01/LibMPSSE_1.0.5.zip).
## API
API closely follows the API in the MPSSE documentation that can be found in the [FTDI Chip Application Notes](https://ftdichip.com/document/application-notes/).
[AN 177 User Guide for LibMPSSE-I2C](https://ftdichip.com/wp-content/uploads/2020/08/AN_177_User_Guide_For_LibMPSSE-I2C.pdf)
[AN 178 User Guide for LibMPSSE-SPI](https://ftdichip.com/wp-content/uploads/2023/08/AN_178_User-Guide-for-LibMPSSE-SPI.pdf)
## Example
```fsharp
use lib = useLibMpsse ()
let config =
{ ClockRate = I2cClockRate.FastMode
LatencyTimer = 255uy
Enable3PhaseClocking = true
EnableLoopback = false
EnableClockStretching = false
PinStateConfig = Disable }
let status =
i2cOpenChannel 0u
|> Result.bind (i2cInitChannel config)// some code
status
|> Result.map i2cCloseChannel
|> ignore```