Mesa 7i96s with 5 encoders and Modbus

More
23 Sep 2024 18:15 #310664 by nartburg
Mesa 7i96s with 5 encoders and Modbus was created by nartburg
Dear folks,

I have a mesa 7i96s and want to set up 5 encoders and a pktUART Modbus connection.

So following talla83 youtube videos I got myself the efinity toolchain and started my experiments:

Adding the additional encoder input was straight forward except that my encoders are differential and additional encoder input on the mesa card take an a b signal so I had to get optical isolated rs485 to ttl boards

Now the pktUART part bugs me -- .as I want to use the smart serial as well.

so the first question: Is it possible to use two pins of the expansion port for Modbus communication?

the modified bitfile compiles (or whatever it is called) flashing is OK reloading is OK a mesaflash --read shows the pins (sry I can not attach it at the moment as I'm not in the shop at the moment) the modbus component description loads and at debug level 3 try's to send and receive but  nothing is happening on the assigned pins.

Please Log in or Create an account to join the conversation.

More
23 Sep 2024 18:21 #310665 by PCW
Replied by PCW on topic Mesa 7i96s with 5 encoders and Modbus
Typically you would use 3 pins for Modbus: RX, TX, and TXEN

Please Log in or Create an account to join the conversation.

More
24 Sep 2024 14:08 #310709 by nartburg
Replied by nartburg on topic Mesa 7i96s with 5 encoders and Modbus
Now in the shop I retrived the .vhd File used to generate the bitfile

library IEEE;
use IEEE.std_logic_1164.all;  -- defines std_logic types
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;

-- Copyright (C) 2007, Peter C. Wallace, Mesa Electronics
-- www.mesanet.com
--
-- This program is is licensed under a disjunctive dual license giving you
-- the choice of one of the two following sets of free software/open source
-- licensing terms:
--
--    * GNU General Public License (GPL), version 2.0 or later
--    * 3-clause BSD License
--
--
-- The GNU GPL License:
--
--     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, write to the Free Software
--     Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA
--
--
-- The 3-clause BSD License:
--
--     Redistribution and use in source and binary forms, with or without
--     modification, are permitted provided that the following conditions
--     are met:
--
--   * Redistributions of source code must retain the above copyright
--     notice, this list of conditions and the following disclaimer.
--
--   * 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.
--
--   * Neither the name of Mesa Electronics nor the names of its
--     contributors may be used to endorse or promote products
--     derived from this software without specific prior written
--     permission.
--
--
-- Disclaimer:
--
--     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 OWNER 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.
--

use work.IDROMConst.all;

package PIN_7I96SD_Test_51 is
    constant ModuleID : ModuleIDType :=(
        (HM2DPLLTag,            x"00",    ClockLowTag,        x"01",    HM2DPLLBaseRateAddr&PadT,        HM2DPLLNumRegs,            x"00",    HM2DPLLMPBitMask),
        (WatchDogTag,            x"00",    ClockLowTag,        x"01",    WatchDogTimeAddr&PadT,            WatchDogNumRegs,        x"00",    WatchDogMPBitMask),
        (IOPortTag,                x"00",    ClockLowTag,        x"03",    PortAddr&PadT,                    IOPortNumRegs,            x"00",    IOPortMPBitMask),
        (OutMTag,                x"00",    ClockLowTag,        x"01",    OutMDataAddr&PadT,                OutMNumRegs,            x"00",    OutMMPBitMask),
        (PWMTag,                x"00",    ClockHighTag,        x"01",    PWMValAddr&PadT,                PWMNumRegs,                x"00",    PWMMPBitMask),
        (StepGenTag,            x"02",    ClockLowTag,        x"05",    StepGenRateAddr&PadT,            StepGenNumRegs,            x"00",    StepGenMPBitMask),
        (QcountTag,                x"02",    ClockLowTag,        x"06",    QcounterAddr&PadT,                QCounterNumRegs,        x"00",    QCounterMPBitMask),
        (SSerialTag,            x"00",    ClockLowTag,        x"01",    SSerialCommandAddr&PadT,        SSerialNumRegs,            x"10",    SSerialMPBitMask),
        (XFrmrOutTag,            x"00",    ClockLowTag,        x"01",    XFrmrDataAddr&PadT,                XFrmrNumRegs,            x"00",    XFrmrMPBitMask ),
        (InMTag,                x"00",    ClockLowTag,        x"01",    InMControlAddr&PadT,            InMNumRegs,                x"00",    InMMPBitMask),
        (LEDTag,                x"00",    ClockLowTag,        x"01",    LEDAddr&PadT,                    LEDNumRegs,                x"00",    LEDMPBitMask),
        (PktUARTTTag,            x"02",    ClockLowTag,        x"01",    PktUARTTDataAddr&PadT,            PktUARTTNumRegs,        x"00",    PktUARTTMPBitMask),
        (PktUARTRTag,            x"02",    ClockLowTag,        x"01",    PktUARTRDataAddr&PadT,            PktUARTRNumRegs,        x"00",    PktUARTRMPBitMask),
        (NullTag,                x"00",    NullTag,            x"00",    NullAddr&PadT,                    x"00",                    x"00",    x"00000000"),
        (NullTag,                x"00",    NullTag,            x"00",    NullAddr&PadT,                    x"00",                    x"00",    x"00000000"),
        (NullTag,                x"00",    NullTag,            x"00",    NullAddr&PadT,                    x"00",                    x"00",    x"00000000"),
        (NullTag,                x"00",    NullTag,            x"00",    NullAddr&PadT,                    x"00",                    x"00",    x"00000000"),
        (NullTag,                x"00",    NullTag,            x"00",    NullAddr&PadT,                    x"00",                    x"00",    x"00000000"),
        (NullTag,                x"00",    NullTag,            x"00",    NullAddr&PadT,                    x"00",                    x"00",    x"00000000"),
        (NullTag,                x"00",    NullTag,            x"00",    NullAddr&PadT,                    x"00",                    x"00",    x"00000000"),
        (NullTag,                x"00",    NullTag,            x"00",    NullAddr&PadT,                    x"00",                    x"00",    x"00000000"),
        (NullTag,                x"00",    NullTag,            x"00",    NullAddr&PadT,                    x"00",                    x"00",    x"00000000"),
        (NullTag,                x"00",    NullTag,            x"00",    NullAddr&PadT,                    x"00",                    x"00",    x"00000000"),
        (NullTag,                x"00",    NullTag,            x"00",    NullAddr&PadT,                    x"00",                    x"00",    x"00000000"),
        (NullTag,                x"00",    NullTag,            x"00",    NullAddr&PadT,                    x"00",                    x"00",    x"00000000"),
        (NullTag,                x"00",    NullTag,            x"00",    NullAddr&PadT,                    x"00",                    x"00",    x"00000000"),
        (NullTag,                x"00",    NullTag,            x"00",    NullAddr&PadT,                    x"00",                    x"00",    x"00000000"),
        (NullTag,                x"00",    NullTag,            x"00",    NullAddr&PadT,                    x"00",                    x"00",    x"00000000"),
        (NullTag,                x"00",    NullTag,            x"00",    NullAddr&PadT,                    x"00",                    x"00",    x"00000000"),
        (NullTag,                x"00",    NullTag,            x"00",    NullAddr&PadT,                    x"00",                    x"00",    x"00000000"),
        (NullTag,                x"00",    NullTag,            x"00",    NullAddr&PadT,                    x"00",                    x"00",    x"00000000"),
        (InMWidth0Tag,            x"00",    NullTag,            x"00",    NullAddr&PadT,                    x"00",                    x"00",    x"0000000B") -- hide this tag here until we find a better way
        );
            
    constant PinDesc : PinDescType :=(
    
--     Base func  sec unit sec func     sec pin                                   
        
                                                                            --        
        IOPortTag & x"00" & InMTag & InMData0Pin,           -- I/O 00     embedded 7I96 Simple I/O
        IOPortTag & x"00" & InMTag & InMData1Pin,           -- I/O 01       
        IOPortTag & x"00" & InMTag & InMData2Pin,           -- I/O 02   
        IOPortTag & x"00" & InMTag & InMData3Pin,           -- I/O 03        
        IOPortTag & x"00" & InMTag & InMData4Pin,           -- I/O 04    
        IOPortTag & x"00" & InMTag & InMData5Pin,            -- I/O 05        
        IOPortTag & x"00" & InMTag & InMData6Pin,           -- I/O 06   
        IOPortTag & x"00" & InMTag & InMData7Pin,           -- I/O 07       
        IOPortTag & x"00" & InMTag & InMData8Pin,            -- I/O 08   
        IOPortTag & x"00" & InMTag & InMData9Pin,           -- I/O 09   
        IOPortTag & x"00" & InMTag & InMDataAPin,           -- I/O 10   
        IOPortTag & x"00" & XfrmrOutTag & XfrmrOut0Pin,       -- I/O 11   
        IOPortTag & x"00" & XfrmrOutTag & XfrmrOut1Pin,       -- I/O 12   
        IOPortTag & x"00" & XfrmrOutTag & XfrmrOut2Pin,       -- I/O 13        
        IOPortTag & x"00" & XfrmrOutTag & XfrmrOut3Pin,       -- I/O 14       
        IOPortTag & x"00" & OutMTag & OutMData4Pin,           -- I/O 15       
        IOPortTag & x"00" & OutMTag & OutMData5Pin,           -- I/O 16       

        IOPortTag & x"00" & StepGenTag & StepGenStepPin,    -- I/O 17    embedded 7I96 Step/Dir/Enc/Serial
        IOPortTag & x"00" & StepGenTag & StepGenDirPin,        -- I/O 18    
        IOPortTag & x"01" & StepGenTag & StepGenStepPin,    -- I/O 19    
        IOPortTag & x"01" & StepGenTag & StepGenDirPin,        -- I/O 20    
        IOPortTag & x"02" & StepGenTag & StepGenStepPin,    -- I/O 21    
        IOPortTag & x"02" & StepGenTag & StepGenDirPin,        -- I/O 22    
        IOPortTag & x"03" & StepGenTag & StepGenStepPin,    -- I/O 23    
        IOPortTag & x"03" & StepGenTag & StepGenDirPin,        -- I/O 24    
        IOPortTag & x"04" & StepGenTag & StepGenStepPin,    -- I/O 25    
        IOPortTag & x"04" & StepGenTag & StepGenDirPin,        -- I/O 26    
        IOPortTag & x"00" & QCountTag & QCountQAPin,        -- I/O 27
        IOPortTag & x"00" & QCountTag & QCountQBPin,        -- I/O 28    
        IOPortTag & x"00" & QCountTag & QCountIdxPin,        -- I/O 29    
        IOPortTag & x"00" & SSerialTag & SSerialRX0Pin,        -- I/O 30    
        IOPortTag & x"00" & SSerialTag & SSerialTX0Pin,        -- I/O 31    
        IOPortTag & x"00" & SSerialTag & SSerialTXEn0Pin,    -- I/O 32    
        IOPortTag & x"00" & XfrmrOutTag & XfrmrRefPin,        -- I/O 33
        
                                        --    Expansion port
        IOPortTag & x"01" & QCountTag & QCountQAPin,                   -- I/O 34   PIN 1
        IOPortTag & x"01" & QCountTag & QCountQBPin,                   -- I/O 35   PIN 14
        IOPortTag & x"02" & QCountTag & QCountQAPin,                  -- I/O 36   PIN 2
        IOPortTag & x"02" & QCountTag & QCountQBPin,                   -- I/O 37   PIN 15
        IOPortTag & x"03" & QCountTag & QCountQAPin,                  -- I/O 38   PIN 3
        IOPortTag & x"03" & QCountTag & QCountQBPin,                   -- I/O 39   PIN 16
        IOPortTag & x"04" & QCountTag & QCountQAPin,                  -- I/O 40   PIN 4
        IOPortTag & x"04" & QCountTag & QCountQBPin,                   -- I/O 41   PIN 17
        IOPortTag & x"05" & QCountTag & QCountQAPin,                  -- I/O 42   PIN 5
        IOPortTag & x"05" & QCountTag & QCountQBPin,                   -- I/O 43   PIN 18
        IOPortTag & x"00" & PktUARTTTag & PktUTDataPin,                -- I/O 44   PIN 6
        IOPortTag & x"00" & PktUARTRTag & PktURDataPin,                -- I/O 45   PIN 19
        IOPortTag & x"00" & NullTag & x"00",                   -- I/O 46   PIN 9
        IOPortTag & x"00" & NullTag & x"00",                   -- I/O 47   PIN 10
        IOPortTag & x"00" & NullTag & x"00",                   -- I/O 48   PIN 11
        IOPortTag & x"00" & NullTag & x"00",                   -- I/O 49   PIN 12
        IOPortTag & x"00" & NullTag & x"00",                   -- I/O 50   PIN 13
        
        LIOPortTag & x"00" & PWMTag  & PWMAOutPin,             -- 7I96S analog out PWM
        LIOPortTag & x"00" & PWMTag  & PWMBDirPin,             -- dummy for now
                                                                                                        
        emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,
        emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,

        emptypin,emptypin,emptypin,emptypin,emptypin,
        emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,emptypin, -- added for IDROM v3
        emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,
        
        emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,
        emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,
        emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,
        emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,
        emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,
        emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,
        emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,emptypin,emptypin);

end package PIN_7I96SD_Test_51;

and the output of the mesaflash --read

Configuration Name: HOSTMOT2

General configuration information:

  BoardName : MESA7I96
  FPGA Size: 20 KGates
  FPGA Pins: 256
  Number of IO Ports: 3
  Width of one I/O port: 17
  Clock Low frequency: 100.0000 MHz
  Clock High frequency: 160.0000 MHz
  IDROM Type: 3
  Instance Stride 0: 4
  Instance Stride 1: 64
  Register Stride 0: 256
  Register Stride 1: 256

Modules in configuration:

  Module: DPLL
  There are 1 of DPLL in configuration
  Version: 0
  Registers: 7
  BaseAddress: 7000
  ClockFrequency: 100.000 MHz
  Register Stride: 256 bytes
  Instance Stride: 4 bytes

  Module: WatchDog
  There are 1 of WatchDog in configuration
  Version: 0
  Registers: 3
  BaseAddress: 0C00
  ClockFrequency: 100.000 MHz
  Register Stride: 256 bytes
  Instance Stride: 4 bytes

  Module: IOPort
  There are 3 of IOPort in configuration
  Version: 0
  Registers: 5
  BaseAddress: 1000
  ClockFrequency: 100.000 MHz
  Register Stride: 256 bytes
  Instance Stride: 4 bytes

  Module: OutM
  There are 1 of OutM in configuration
  Version: 0
  Registers: 1
  BaseAddress: B000
  ClockFrequency: 100.000 MHz
  Register Stride: 256 bytes
  Instance Stride: 4 bytes

  Module: PWM
  There are 1 of PWM in configuration
  Version: 0
  Registers: 5
  BaseAddress: 4100
  ClockFrequency: 160.000 MHz
  Register Stride: 256 bytes
  Instance Stride: 4 bytes

  Module: StepGen
  There are 5 of StepGen in configuration
  Version: 2
  Registers: 10
  BaseAddress: 2000
  ClockFrequency: 100.000 MHz
  Register Stride: 256 bytes
  Instance Stride: 4 bytes

  Module: QCount
  There are 6 of QCount in configuration
  Version: 2
  Registers: 5
  BaseAddress: 3000
  ClockFrequency: 100.000 MHz
  Register Stride: 256 bytes
  Instance Stride: 4 bytes

  Module: SSerial
  There are 1 of SSerial in configuration
  Version: 0
  Registers: 6
  BaseAddress: 5B00
  ClockFrequency: 100.000 MHz
  Register Stride: 256 bytes
  Instance Stride: 64 bytes

  Module: SSR
  There are 1 of SSR in configuration
  Version: 0
  Registers: 2
  BaseAddress: 7D00
  ClockFrequency: 100.000 MHz
  Register Stride: 256 bytes
  Instance Stride: 4 bytes

  Module: InM
  There are 1 of InM in configuration
  Version: 0
  Registers: 5
  BaseAddress: 8500
  ClockFrequency: 100.000 MHz
  Register Stride: 256 bytes
  Instance Stride: 4 bytes

  Module: LED
  There are 1 of LED in configuration
  Version: 0
  Registers: 1
  BaseAddress: 0200
  ClockFrequency: 100.000 MHz
  Register Stride: 256 bytes
  Instance Stride: 4 bytes

  Module: PktUARTTX
  There are 1 of PktUARTTX in configuration
  Version: 2
  Registers: 4
  BaseAddress: 6100
  ClockFrequency: 100.000 MHz
  Register Stride: 256 bytes
  Instance Stride: 4 bytes

  Module: PktUARTRX
  There are 1 of PktUARTRX in configuration
  Version: 2
  Registers: 4
  BaseAddress: 6500
  ClockFrequency: 100.000 MHz
  Register Stride: 256 bytes
  Instance Stride: 4 bytes

Configuration pin-out:

IO Connections for TB3 -> 7I96_0
Pin#                  I/O   Pri. func    Sec. func        Chan     Sec. Pin func   Sec. Pin Dir

TB3-1                   0   IOPort       InM              0        Input0_EncA0    (In)
TB3-2                   1   IOPort       InM              0        Input1_EncB0    (In)
TB3-3                   2   IOPort       InM              0        Input2_EncA1    (In)
TB3-4                   3   IOPort       InM              0        Input3_EncB1    (In)
TB3-5                   4   IOPort       InM              0        Input4_EncA2    (In)
TB3-6                   5   IOPort       InM              0        Input5_EncB2    (In)
TB3-7                   6   IOPort       InM              0        Input6_EncA3    (In)
TB3-8                   7   IOPort       InM              0        Input7_EncB3    (In)
TB3-9                   8   IOPort       InM              0        Input8          (In)
TB3-10                  9   IOPort       InM              0        Input9          (In)
TB3-11                 10   IOPort       InM              0        Input10         (In)
TB3-13,14              11   IOPort       SSR              0        Out-00          (Out)
TB3-15,16              12   IOPort       SSR              0        Out-01          (Out)
TB3-17,18              13   IOPort       SSR              0        Out-02          (Out)
TB3-19,20              14   IOPort       SSR              0        Out-03          (Out)
TB3-21,22              15   IOPort       OutM             0        Output4         (Out)
TB3-23,24              16   IOPort       OutM             0        Output5         (Out)

IO Connections for TB1/TB2 -> 7I96_1
Pin#                  I/O   Pri. func    Sec. func        Chan     Sec. Pin func   Sec. Pin Dir

TB1-2,3                17   IOPort       StepGen          0        Step/Table1     (Out)
TB1-4,5                18   IOPort       StepGen          0        Dir/Table2      (Out)
TB1-8,9                19   IOPort       StepGen          1        Step/Table1     (Out)
TB1-10,11              20   IOPort       StepGen          1        Dir/Table2      (Out)
TB1-14,15              21   IOPort       StepGen          2        Step/Table1     (Out)
TB1-16,17              22   IOPort       StepGen          2        Dir/Table2      (Out)
TB1-20,21              23   IOPort       StepGen          3        Step/Table1     (Out)
TB1-22,23              24   IOPort       StepGen          3        Dir/Table2      (Out)
TB2-2,3                25   IOPort       StepGen          4        Step/Table1     (Out)
TB2-4,5                26   IOPort       StepGen          4        Dir/Table2      (Out)
TB2-7,8                27   IOPort       QCount           0        Quad-A          (In)
TB2-10,11              28   IOPort       QCount           0        Quad-B          (In)
TB2-13,14              29   IOPort       QCount           0        Quad-IDX        (In)
TB2-16,17              30   IOPort       SSerial          0        RXData0         (In)
TB2-18,19              31   IOPort       SSerial          0        TXData0         (Out)
Internal-TXEn          32   IOPort       SSerial          0        TXEn0           (Out)
Internal               33   IOPort       SSR              0        AC Ref          (Out)

IO Connections for P1 -> 7I96_2
Pin#                  I/O   Pri. func    Sec. func        Chan     Sec. Pin func   Sec. Pin Dir

P1-01/DB25-01          34   IOPort       QCount           1        Quad-A          (In)
P1-02/DB25-14          35   IOPort       QCount           1        Quad-B          (In)
P1-03/DB25-02          36   IOPort       QCount           2        Quad-A          (In)
P1-04/DB25-15          37   IOPort       QCount           2        Quad-B          (In)
P1-05/DB25-03          38   IOPort       QCount           3        Quad-A          (In)
P1-06/DB25-16          39   IOPort       QCount           3        Quad-B          (In)
P1-07/DB25-04          40   IOPort       QCount           4        Quad-A          (In)
P1-08/DB25-17          41   IOPort       QCount           4        Quad-B          (In)
P1-09/DB25-05          42   IOPort       QCount           5        Quad-A          (In)
P1-11/DB25-06          43   IOPort       QCount           5        Quad-B          (In)
P1-13/DB25-07          44   IOPort       PktUARTTX        0        TXData          (Out)
P1-15/DB25-08          45   IOPort       PktUARTRX        0        RXData          (In)
P1-17/DB25-09          46   IOPort       None           
P1-19/DB25-10          47   IOPort       None           
P1-21/DB25-11          48   IOPort       None           
P1-23/DB25-12          49   IOPort       None           
P1-25/DB25-13          50   IOPort       None           

then i hooked my osciloscope between ch1 gnd - pin7 / ch2  gnd - pin8 

and tried Andy Pugh's bash script found in HM2_PKTUART after adding the s for the 7I96s


# First setup the DDR and Alt Source regs for the 7I96
mesaflash --device 7i96 --addr 10.10.10.10 --wpo 0x1100=0x1F800
mesaflash --device 7i96 --addr 10.10.10.10 --wpo 0x1104=0x1C3FF
mesaflash --device 7i96 --addr 10.10.10.10 --wpo 0x1200=0x1F800
mesaflash --device 7i96 --addr 10.10.10.10 --wpo 0x1204=0x1C3FF
# Next set the baud rate DDS's for 9600 baud
mesaflash --device 7i96 --addr 10.10.10.10 --wpo 0x6300=0x65
mesaflash --device 7i96 --addr 10.10.10.10 --wpo 0x6700=0x65
# setup the TX and RX mode registers
mesaflash --device 7i96 --addr 10.10.10.10 --wpo 0x6400=0x00062840
mesaflash --device 7i96 --addr 10.10.10.10 --wpo 0x6800=0x3FC61408
# Reset the TX and RX UARTS
mesaflash --device 7i96 --addr 10.10.10.10 --wpo 0x6400=0x80010000
mesaflash --device 7i96 --addr 10.10.10.10 --wpo 0x6800=0x80010000
# load 7 bytes of data into the TX UART
mesaflash --device 7i96 --addr 10.10.10.10 --wpo 0x6100=0x54535251
mesaflash --device 7i96 --addr 10.10.10.10 --wpo 0x6100=0x58575655
mesaflash --device 7i96 --addr 10.10.10.10 --wpo 0x6100=0x64636261
mesaflash --device 7i96 --addr 10.10.10.10 --wpo 0x6100=0x68676665
# Command the TX UART to send 8 bytes twice
mesaflash --device 7i96 --addr 10.10.10.10 --wpo 0x6200=0x08
mesaflash --device 7i96 --addr 10.10.10.10 --wpo 0x6200=0x08
sleep .1
# display the RX mode reg, RX count, and the data
mesaflash --device 7i96 --addr 10.10.10.10 --rpo 0x6800
mesaflash --device 7i96 --addr 10.10.10.10 --rpo 0x6600
mesaflash --device 7i96 --addr 10.10.10.10 --rpo 0x6500
mesaflash --device 7i96 --addr 10.10.10.10 --rpo 0x6500
mesaflash --device 7i96 --addr 10.10.10.10 --rpo 0x6800
mesaflash --device 7i96 --addr 10.10.10.10 --rpo 0x6600
mesaflash --device 7i96 --addr 10.10.10.10 --rpo 0x6500
mesaflash --device 7i96 --addr 10.10.10.10 --rpo 0x6500

Nothing -- constant 5V on both channels

pls advice


 
Attachments:

Please Log in or Create an account to join the conversation.

More
24 Sep 2024 14:48 #310714 by PCW
Replied by PCW on topic Mesa 7i96s with 5 encoders and Modbus
I would try creating a .mod file and doing an actual test

Please Log in or Create an account to join the conversation.

More
24 Sep 2024 16:35 #310718 by nartburg
Replied by nartburg on topic Mesa 7i96s with 5 encoders and Modbus
Created .mod file

#define MAX_MSG_LEN 16
#define DEBUG 3

static const hm2_modbus_chan_descriptor_t channels[] = {
    {HAL_S32,     6,   0x000,  1,"write"},
    {HAL_S32,     3,   0x100,  1,"read"},
};

loading in .hal file:
.
.
.

addf pid.z.do-pid-calcs       servo-thread
addf pid.s.do-pid-calcs       servo-thread
addf [HMOT](CARD0).write         servo-thread
setp [HMOT](CARD0).dpll.01.timer-us -50
setp [HMOT](CARD0).stepgen.timer-number 1

loadrt my-vfd ports=hm2_7i96s.0.pktuart.0
addf my-vfd.00 servo-thread

# external output signals


# external input signals

# --- MAX-HOME-Z ---
net max-home-z     <=  [HMOT](CARD0).inm.00.input-00-not
.
.
.
Output:
.
.


WAIT_FOR_DATA_FRAME - rxmode = 16000F0C
 1002 TIMEOUT_RESET 3
START txstaus = 00001460 rxstatus = 16000F0C
building packet 6 0 start pin 0
building packet 3 100 start pin 1
Sending to hm2_7i96s.0.pktuart.0 8 bytes 01 03 01 0000 01 85 F6
WAIT_FOR_SENDBEGIN RX 1460 TX 16000F0C
WAIT_FOR_SEND_COMPLETE RX 16000F0C TX 2014E0
.
.
.
While the oszi is still showing a constant 5Volts





 

Please Log in or Create an account to join the conversation.

More
24 Sep 2024 16:52 #310720 by PCW
Replied by PCW on topic Mesa 7i96s with 5 encoders and Modbus
I would try standard 7I96S+PktUART firmware (using
the TB2 RS-485 interface) and then work backwards to
find out where the issue is.

Please Log in or Create an account to join the conversation.

More
25 Sep 2024 12:07 #310765 by nartburg
Replied by nartburg on topic Mesa 7i96s with 5 encoders and Modbus
So tried tb2 Rs-485 interface with PIN_7I96SD_PKT.vhd and

1 GND
2 RX+,TX+ 390 Ohm pulldown to GND (1)
3 RX-,TX- 
4 RX+,TX+
5 RX-,TX1-   390 Ohm pullup to 5V (6)
6 +5V

same,same but different:

NO signal on the bus;
but rxmode changed from 16000F0c to 1600F8E




 

Please Log in or Create an account to join the conversation.

More
25 Sep 2024 13:44 #310770 by PCW
Replied by PCW on topic Mesa 7i96s with 5 encoders and Modbus
I would try the standard firmware with the sample relay .mod file since that is known to work
I would also use 7i96sd_pktv2.bin since its the latest (though both have been tested)
 

Please Log in or Create an account to join the conversation.

More
25 Sep 2024 15:25 #310779 by nartburg
Replied by nartburg on topic Mesa 7i96s with 5 encoders and Modbus
where to find relay.mod?

Please Log in or Create an account to join the conversation.

More
25 Sep 2024 15:29 #310780 by PCW
Replied by PCW on topic Mesa 7i96s with 5 encoders and Modbus
Not sure where is in in a normal install but in the source it's:

src/hal/drivers/mesa-hostmot2/modbus/relayboard.mod
 

Please Log in or Create an account to join the conversation.

Moderators: PCWjmelson
Time to create page: 0.070 seconds
Powered by Kunena Forum