Remarks

Sc16is752
Status Status badge: working
Source code GitHub
Datasheet(s) GitHub
NuGet package NuGet Gallery for Meadow.Foundation.ICs.IOExpanders.Sc16is7x2

Code Example

private Sc16is752? _expander = null;

private ISerialPort? _expanderPort = null;
private ISerialPort? _nativePort = null;

private const int Rate = 9600;

public override async Task Initialize()
{
    // NOTE: This sample connects PortA on the expander back to COM1 on the F7Feather
    Resolver.Log.Info("Initialize...");

    var address = Sc16is7x2.Addresses.Address_0x4D;

    try
    {
        _expander = new Sc16is752(
            Device.CreateI2cBus(),
            new Meadow.Units.Frequency(1.8432, Meadow.Units.Frequency.UnitType.Megahertz),
            address);

        _expanderPort = _expander.PortA.CreateSerialPort(Rate);
        _nativePort = Device.PlatformOS.GetSerialPortName("com1")?.CreateSerialPort(Rate);
    }
    catch (Exception ex)
    {
        Resolver.Log.Error($"Failed to initialize 0x{(byte)address:X2}: {ex.Message}");
        await Task.Delay(1000);
    }
}

public override Task Run()
{
    if (_expander == null || _expanderPort == null || _nativePort == null)
    {
        return Task.CompletedTask;
    }

    Task.Run(() => PingReply(_expanderPort, _nativePort));

    while (true)
    {
        Thread.Sleep(1000);
    }
}

private async Task PingReply(ISerialPort portA, ISerialPort portB)
{
    var readBuffer = new byte[64];

    Resolver.Log.Info("Opening ports...");
    portA.Open();
    portB.Open();

    var abMessage = "ping\n";
    var baMessage = "reply\n";
    var count = 0;

    while (true)
    {
        try
        {
            // A -> B
            Resolver.Log.Info($"TEST A->B");
            var messageAB = Encoding.ASCII.GetBytes(abMessage);
            Resolver.Log.Info($"Writing {messageAB.Length} bytes on A...");
            Resolver.Log.Info($"  {BitConverter.ToString(messageAB)}");

            portA.Write(messageAB);

            Resolver.Log.Info($"Reading on B...");
            count = 0;
            while (count < messageAB.Length)
            {
                count += portB.Read(readBuffer, count, messageAB.Length);
            }

            Resolver.Log.Info($"Read {count} bytes on B");
            Resolver.Log.Info($"  {BitConverter.ToString(readBuffer, 0, count)}");

            var rxString = Encoding.ASCII.GetString(readBuffer, 0, count);
            Resolver.Log.Info($"A sent: {abMessage}");
            Resolver.Log.Info($"B received: {rxString}\n");


            // B -> A
            Resolver.Log.Info($"TEST B->A");
            var messageBA = Encoding.ASCII.GetBytes(baMessage);
            Resolver.Log.Info($"Responding with {messageBA.Length} bytes on B...");
            Resolver.Log.Info($"  {BitConverter.ToString(messageBA)}");

            portB.Write(messageBA);
            Resolver.Log.Info($"Reading on A...");
            count = 0;
            while (count < messageBA.Length)
            {
                count += portA.Read(readBuffer, count, messageBA.Length);
            }

            Resolver.Log.Info($"Read {count} bytes on A");
            Resolver.Log.Info($"  {BitConverter.ToString(readBuffer, 0, count)}");

            rxString = Encoding.ASCII.GetString(readBuffer, 0, count);
            Resolver.Log.Info($"B sent: {baMessage}");
            Resolver.Log.Info($"A received: {rxString}\n");


            await Task.Delay(30000);
        }
        catch (Exception ex)
        {
            Resolver.Log.Error($"Test error: {ex.Message}");
            await Task.Delay(5000);
        }
    }
}

Sample project(s) available on GitHub

Characteristic Locus
Inheritance object Sc16is7x2 > Sc16is752
Implements ISerialController II2cPeripheral ISpiPeripheral
Inherited Members Sc16is7x2.PortA Sc16is7x2.PortB Sc16is7x2.CreateSerialPort(SerialPortName, int, int, Parity, StopBits, int) Sc16is7x2.CreateRs485SerialPort(Sc16is7x2.Sc16SerialPortName, int, int, Parity, StopBits, bool) Sc16is7x2.DefaultI2cAddress Sc16is7x2.MaxI2cBusSpeed Sc16is7x2.DefaultSpiBusMode Sc16is7x2.DefaultSpiBusSpeed Sc16is7x2.SpiBusMode Sc16is7x2.SpiBusSpeed object.Equals(object) object.Equals(object, object) object.GetHashCode() object.GetType() object.MemberwiseClone() object.ReferenceEquals(object, object) object.ToString()
Namespace Meadow.Foundation.ICs.IOExpanders
Assembly Sc16is7x2.dll

Syntax

public class Sc16is752 : Sc16is7x2, ISerialController, II2cPeripheral, ISpiPeripheral

Constructors

Sc16is752(II2cBus, Frequency, Addresses, IDigitalInterruptPort?)

Initializes a new instance of the Sc16is752 class using an I2C bus, oscillator frequency, an address, and an optional IRQ digital interrupt port.

Declaration
public Sc16is752(II2cBus i2cBus, Frequency oscillatorFrequency, Sc16is7x2.Addresses address = Addresses.Address_0x48, IDigitalInterruptPort? irq = null)

Parameters

Type Name Description
II2cBus i2cBus

The I2C bus for communication.

Frequency oscillatorFrequency

The oscillator frequency of the device.

Sc16is7x2.Addresses address

The I2C address of the device (default is 0x48).

IDigitalInterruptPort irq

An optional digital interrupt port for IRQ (Interrupt Request).

Remarks

Sc16is752
Status Status badge: working
Source code GitHub
Datasheet(s) GitHub
NuGet package NuGet Gallery for Meadow.Foundation.ICs.IOExpanders.Sc16is7x2

Code Example

private Sc16is752? _expander = null;

private ISerialPort? _expanderPort = null;
private ISerialPort? _nativePort = null;

private const int Rate = 9600;

public override async Task Initialize()
{
    // NOTE: This sample connects PortA on the expander back to COM1 on the F7Feather
    Resolver.Log.Info("Initialize...");

    var address = Sc16is7x2.Addresses.Address_0x4D;

    try
    {
        _expander = new Sc16is752(
            Device.CreateI2cBus(),
            new Meadow.Units.Frequency(1.8432, Meadow.Units.Frequency.UnitType.Megahertz),
            address);

        _expanderPort = _expander.PortA.CreateSerialPort(Rate);
        _nativePort = Device.PlatformOS.GetSerialPortName("com1")?.CreateSerialPort(Rate);
    }
    catch (Exception ex)
    {
        Resolver.Log.Error($"Failed to initialize 0x{(byte)address:X2}: {ex.Message}");
        await Task.Delay(1000);
    }
}

public override Task Run()
{
    if (_expander == null || _expanderPort == null || _nativePort == null)
    {
        return Task.CompletedTask;
    }

    Task.Run(() => PingReply(_expanderPort, _nativePort));

    while (true)
    {
        Thread.Sleep(1000);
    }
}

private async Task PingReply(ISerialPort portA, ISerialPort portB)
{
    var readBuffer = new byte[64];

    Resolver.Log.Info("Opening ports...");
    portA.Open();
    portB.Open();

    var abMessage = "ping\n";
    var baMessage = "reply\n";
    var count = 0;

    while (true)
    {
        try
        {
            // A -> B
            Resolver.Log.Info($"TEST A->B");
            var messageAB = Encoding.ASCII.GetBytes(abMessage);
            Resolver.Log.Info($"Writing {messageAB.Length} bytes on A...");
            Resolver.Log.Info($"  {BitConverter.ToString(messageAB)}");

            portA.Write(messageAB);

            Resolver.Log.Info($"Reading on B...");
            count = 0;
            while (count < messageAB.Length)
            {
                count += portB.Read(readBuffer, count, messageAB.Length);
            }

            Resolver.Log.Info($"Read {count} bytes on B");
            Resolver.Log.Info($"  {BitConverter.ToString(readBuffer, 0, count)}");

            var rxString = Encoding.ASCII.GetString(readBuffer, 0, count);
            Resolver.Log.Info($"A sent: {abMessage}");
            Resolver.Log.Info($"B received: {rxString}\n");


            // B -> A
            Resolver.Log.Info($"TEST B->A");
            var messageBA = Encoding.ASCII.GetBytes(baMessage);
            Resolver.Log.Info($"Responding with {messageBA.Length} bytes on B...");
            Resolver.Log.Info($"  {BitConverter.ToString(messageBA)}");

            portB.Write(messageBA);
            Resolver.Log.Info($"Reading on A...");
            count = 0;
            while (count < messageBA.Length)
            {
                count += portA.Read(readBuffer, count, messageBA.Length);
            }

            Resolver.Log.Info($"Read {count} bytes on A");
            Resolver.Log.Info($"  {BitConverter.ToString(readBuffer, 0, count)}");

            rxString = Encoding.ASCII.GetString(readBuffer, 0, count);
            Resolver.Log.Info($"B sent: {baMessage}");
            Resolver.Log.Info($"A received: {rxString}\n");


            await Task.Delay(30000);
        }
        catch (Exception ex)
        {
            Resolver.Log.Error($"Test error: {ex.Message}");
            await Task.Delay(5000);
        }
    }
}

Sample project(s) available on GitHub

Sc16is752(ISpiBus, Frequency, IDigitalOutputPort?, IDigitalInterruptPort?)

Initializes a new instance of the Sc16is752 class using an SPI bus, oscillator frequency, an optional chip select digital output port, and an optional IRQ digital interrupt port.

Declaration
public Sc16is752(ISpiBus spiBus, Frequency oscillatorFrequency, IDigitalOutputPort? chipSelect = null, IDigitalInterruptPort? irq = null)

Parameters

Type Name Description
ISpiBus spiBus

The SPI bus for communication.

Frequency oscillatorFrequency

The oscillator frequency of the device.

IDigitalOutputPort chipSelect

An optional digital output port for chip select (CS).

IDigitalInterruptPort irq

An optional digital interrupt port for IRQ (Interrupt Request).

Remarks

Sc16is752
Status Status badge: working
Source code GitHub
Datasheet(s) GitHub
NuGet package NuGet Gallery for Meadow.Foundation.ICs.IOExpanders.Sc16is7x2

Code Example

private Sc16is752? _expander = null;

private ISerialPort? _expanderPort = null;
private ISerialPort? _nativePort = null;

private const int Rate = 9600;

public override async Task Initialize()
{
    // NOTE: This sample connects PortA on the expander back to COM1 on the F7Feather
    Resolver.Log.Info("Initialize...");

    var address = Sc16is7x2.Addresses.Address_0x4D;

    try
    {
        _expander = new Sc16is752(
            Device.CreateI2cBus(),
            new Meadow.Units.Frequency(1.8432, Meadow.Units.Frequency.UnitType.Megahertz),
            address);

        _expanderPort = _expander.PortA.CreateSerialPort(Rate);
        _nativePort = Device.PlatformOS.GetSerialPortName("com1")?.CreateSerialPort(Rate);
    }
    catch (Exception ex)
    {
        Resolver.Log.Error($"Failed to initialize 0x{(byte)address:X2}: {ex.Message}");
        await Task.Delay(1000);
    }
}

public override Task Run()
{
    if (_expander == null || _expanderPort == null || _nativePort == null)
    {
        return Task.CompletedTask;
    }

    Task.Run(() => PingReply(_expanderPort, _nativePort));

    while (true)
    {
        Thread.Sleep(1000);
    }
}

private async Task PingReply(ISerialPort portA, ISerialPort portB)
{
    var readBuffer = new byte[64];

    Resolver.Log.Info("Opening ports...");
    portA.Open();
    portB.Open();

    var abMessage = "ping\n";
    var baMessage = "reply\n";
    var count = 0;

    while (true)
    {
        try
        {
            // A -> B
            Resolver.Log.Info($"TEST A->B");
            var messageAB = Encoding.ASCII.GetBytes(abMessage);
            Resolver.Log.Info($"Writing {messageAB.Length} bytes on A...");
            Resolver.Log.Info($"  {BitConverter.ToString(messageAB)}");

            portA.Write(messageAB);

            Resolver.Log.Info($"Reading on B...");
            count = 0;
            while (count < messageAB.Length)
            {
                count += portB.Read(readBuffer, count, messageAB.Length);
            }

            Resolver.Log.Info($"Read {count} bytes on B");
            Resolver.Log.Info($"  {BitConverter.ToString(readBuffer, 0, count)}");

            var rxString = Encoding.ASCII.GetString(readBuffer, 0, count);
            Resolver.Log.Info($"A sent: {abMessage}");
            Resolver.Log.Info($"B received: {rxString}\n");


            // B -> A
            Resolver.Log.Info($"TEST B->A");
            var messageBA = Encoding.ASCII.GetBytes(baMessage);
            Resolver.Log.Info($"Responding with {messageBA.Length} bytes on B...");
            Resolver.Log.Info($"  {BitConverter.ToString(messageBA)}");

            portB.Write(messageBA);
            Resolver.Log.Info($"Reading on A...");
            count = 0;
            while (count < messageBA.Length)
            {
                count += portA.Read(readBuffer, count, messageBA.Length);
            }

            Resolver.Log.Info($"Read {count} bytes on A");
            Resolver.Log.Info($"  {BitConverter.ToString(readBuffer, 0, count)}");

            rxString = Encoding.ASCII.GetString(readBuffer, 0, count);
            Resolver.Log.Info($"B sent: {baMessage}");
            Resolver.Log.Info($"A received: {rxString}\n");


            await Task.Delay(30000);
        }
        catch (Exception ex)
        {
            Resolver.Log.Error($"Test error: {ex.Message}");
            await Task.Delay(5000);
        }
    }
}

Sample project(s) available on GitHub

Sc16is752(Frequency, IDigitalInterruptPort?)

Initializes a new instance of the Sc16is752 class using an oscillator frequency and an optional IRQ digital interrupt port.

Declaration
public Sc16is752(Frequency oscillatorFrequency, IDigitalInterruptPort? irq)

Parameters

Type Name Description
Frequency oscillatorFrequency

The oscillator frequency of the device.

IDigitalInterruptPort irq

An optional digital interrupt port for IRQ (Interrupt Request).

Remarks

Sc16is752
Status Status badge: working
Source code GitHub
Datasheet(s) GitHub
NuGet package NuGet Gallery for Meadow.Foundation.ICs.IOExpanders.Sc16is7x2

Code Example

private Sc16is752? _expander = null;

private ISerialPort? _expanderPort = null;
private ISerialPort? _nativePort = null;

private const int Rate = 9600;

public override async Task Initialize()
{
    // NOTE: This sample connects PortA on the expander back to COM1 on the F7Feather
    Resolver.Log.Info("Initialize...");

    var address = Sc16is7x2.Addresses.Address_0x4D;

    try
    {
        _expander = new Sc16is752(
            Device.CreateI2cBus(),
            new Meadow.Units.Frequency(1.8432, Meadow.Units.Frequency.UnitType.Megahertz),
            address);

        _expanderPort = _expander.PortA.CreateSerialPort(Rate);
        _nativePort = Device.PlatformOS.GetSerialPortName("com1")?.CreateSerialPort(Rate);
    }
    catch (Exception ex)
    {
        Resolver.Log.Error($"Failed to initialize 0x{(byte)address:X2}: {ex.Message}");
        await Task.Delay(1000);
    }
}

public override Task Run()
{
    if (_expander == null || _expanderPort == null || _nativePort == null)
    {
        return Task.CompletedTask;
    }

    Task.Run(() => PingReply(_expanderPort, _nativePort));

    while (true)
    {
        Thread.Sleep(1000);
    }
}

private async Task PingReply(ISerialPort portA, ISerialPort portB)
{
    var readBuffer = new byte[64];

    Resolver.Log.Info("Opening ports...");
    portA.Open();
    portB.Open();

    var abMessage = "ping\n";
    var baMessage = "reply\n";
    var count = 0;

    while (true)
    {
        try
        {
            // A -> B
            Resolver.Log.Info($"TEST A->B");
            var messageAB = Encoding.ASCII.GetBytes(abMessage);
            Resolver.Log.Info($"Writing {messageAB.Length} bytes on A...");
            Resolver.Log.Info($"  {BitConverter.ToString(messageAB)}");

            portA.Write(messageAB);

            Resolver.Log.Info($"Reading on B...");
            count = 0;
            while (count < messageAB.Length)
            {
                count += portB.Read(readBuffer, count, messageAB.Length);
            }

            Resolver.Log.Info($"Read {count} bytes on B");
            Resolver.Log.Info($"  {BitConverter.ToString(readBuffer, 0, count)}");

            var rxString = Encoding.ASCII.GetString(readBuffer, 0, count);
            Resolver.Log.Info($"A sent: {abMessage}");
            Resolver.Log.Info($"B received: {rxString}\n");


            // B -> A
            Resolver.Log.Info($"TEST B->A");
            var messageBA = Encoding.ASCII.GetBytes(baMessage);
            Resolver.Log.Info($"Responding with {messageBA.Length} bytes on B...");
            Resolver.Log.Info($"  {BitConverter.ToString(messageBA)}");

            portB.Write(messageBA);
            Resolver.Log.Info($"Reading on A...");
            count = 0;
            while (count < messageBA.Length)
            {
                count += portA.Read(readBuffer, count, messageBA.Length);
            }

            Resolver.Log.Info($"Read {count} bytes on A");
            Resolver.Log.Info($"  {BitConverter.ToString(readBuffer, 0, count)}");

            rxString = Encoding.ASCII.GetString(readBuffer, 0, count);
            Resolver.Log.Info($"B sent: {baMessage}");
            Resolver.Log.Info($"A received: {rxString}\n");


            await Task.Delay(30000);
        }
        catch (Exception ex)
        {
            Resolver.Log.Error($"Test error: {ex.Message}");
            await Task.Delay(5000);
        }
    }
}

Sample project(s) available on GitHub