fix
zhangqian
2023-12-01 8324f872ef3a4d0c978a9b1d062800c6a1701c12
pkg/plc/apacheplc4x/modbus.go
@@ -10,35 +10,40 @@
   "github.com/apache/plc4x/plc4go/pkg/api/drivers"
   apiModel "github.com/apache/plc4x/plc4go/pkg/api/model"
   "github.com/apache/plc4x/plc4go/pkg/api/transports"
   "github.com/spf13/cast"
   "sync/atomic"
   "time"
)
var driverManager plc4go.PlcDriverManager
func init() {
   // 创建驱动管理器
   driverManager = plc4go.NewPlcDriverManager()
   // 注册TCP传输
   transports.RegisterTcpTransport(driverManager)
   // 注册串口传输
   transports.RegisterSerialTransport(driverManager)
   // 注册驱动
   drivers.RegisterModbusTcpDriver(driverManager)
   drivers.RegisterModbusRtuDriver(driverManager)
}
func GetModbusConnection(ipAddr string) (plc4go.PlcConnection, error) {
   // 创建一个上下文,并设置 3 秒超时
   ctx, cancel := context.WithTimeout(context.Background(), 30*time.Second)
   defer cancel()
   conn, err := newGetModbusConnection(ctx, ipAddr)
   conn, err := newModbusTCPConnection(ctx, ipAddr)
   if err != nil {
      logx.Errorf("new modbus connection err: %v", err.Error())
      return nil, err
   }
   return conn, nil
}
func newGetModbusConnection(ctx context.Context, ipAddr string) (plc4go.PlcConnection, error) {
   // 创建驱动管理器
   driverManager := plc4go.NewPlcDriverManager()
   // 注册TCP传输
   transports.RegisterTcpTransport(driverManager)
   // 注册驱动
   //drivers.RegisterKnxDriver(driverManager)
   drivers.RegisterModbusTcpDriver(driverManager)
func newModbusTCPConnection(ctx context.Context, ipAddr string) (plc4go.PlcConnection, error) {
   // 通过TCP连接PLC设备
   connectionString := fmt.Sprintf("modbus-tcp://%s", ipAddr)
   connectionRequestChanel := driverManager.GetConnection(connectionString)
   // 等待连接响应,同时考虑上下文的超时
   select {
   case connectionResult := <-connectionRequestChanel:
@@ -53,7 +58,7 @@
func readHoldingRegisterSingle(connection plc4go.PlcConnection, address int) ([]byte, error) {
   tag := fmt.Sprintf("tag:%v", address)
   tagAddress := getTagAddress(address)
   tagAddress := getTagAddress(address, 1)
   // 读模式
   readRequest, err := connection.ReadRequestBuilder().AddTagAddress(tag, tagAddress).Build()
@@ -83,7 +88,7 @@
func readHoldingRegisterList(connection plc4go.PlcConnection, address, length int) ([]byte, error) {
   tag := fmt.Sprintf("tag:%v:%v", address, length)
   tagAddress := getTagAddress(address)
   tagAddress := getTagAddress(address, length)
   // 读模式
   readRequest, err := connection.ReadRequestBuilder().AddTagAddress(tag, tagAddress).Build()
@@ -130,12 +135,16 @@
   return readHoldingRegisterSingle(connection, address)
}
func getTagAddress(address int) string {
func getTagAddress(address int, length int) string {
   intType := conf.Conf.PLC.ModbusIntType
   if intType == "" {
      intType = "DINT"
   }
   return fmt.Sprintf("holding-register:%d:%v", address, intType)
   if length == 1 {
      return fmt.Sprintf("holding-register:%d:%v", address, intType)
   } else {
      return fmt.Sprintf("holding-register:%d:%v[%d]", address, intType, length)
   }
}
func WriteHoldingRegister(ipAddr string, address int, value any) (string, error) {
@@ -146,7 +155,12 @@
   }
   defer connection.Close()
   tag := fmt.Sprintf("tag:%v:w", address)
   tagAddress := getTagAddress(address)
   var tagAddress string
   if cast.ToInt32(value) > 2<<16 {
      tagAddress = getTagAddress(address, 2)
   } else {
      tagAddress = getTagAddress(address, 1)
   }
   // 写模式
   writeRequest, err := connection.WriteRequestBuilder().AddTagAddress(tag, tagAddress, value).Build()