Eliminación de un mensaje periódico
Última modificación:
Detiene la transmisión de un mensaje periódico y libera los recursos asociados a él. Tras la llamada, el identificador MsgID deja de ser válido.
long PassThruStopPeriodicMsg(unsigned long ChannelID, unsigned long MsgID)
PassThruStartPeriodicMsg.| Código | Descripción | Posibles causas y soluciones |
|---|---|---|
| STATUS_NOERROR | La función se ejecutó correctamente | — |
| ERR_INVALID_CHANNEL_ID | Identificador de canal no válido |
|
| ERR_DEVICE_NOT_CONNECTED | Sin conexión con el adaptador |
|
| ERR_INVALID_DEVICE_ID | Identificador de dispositivo no válido |
|
| ERR_INVALID_MSG_ID | Identificador de mensaje no válido |
|
| ERR_FAILED | Error interno |
|
#include "j2534_lib.hpp"
unsigned long ChannelID; // ID del canal
unsigned long MsgID; // ID del mensaje obtenido de PassThruStartPeriodicMsg
long Ret;
Ret = PassThruStopPeriodicMsg(ChannelID, MsgID);
if (Ret != STATUS_NOERROR)
{
// Manejo del error
}
// channelID y msgID obtenidos previamente
val result = j2534.ptStopPeriodicMsg(channelID, msgID)
if (result.status == STATUS_NOERROR) {
// Mensaje periódico detenido correctamente
Log.i("J2534", "Mensaje periódico detenido, MsgID: $msgID")
} else {
// Manejo del error
Log.e("J2534", "Error al detener el mensaje periódico: ${result.status}")
}
import ctypes
# Carga de la biblioteca
j2534 = ctypes.CDLL("libj2534_v04_04.so") # Linux
# j2534 = ctypes.WinDLL("j2534sd_v04_04_x64.dll") # Windows
# channel_id y msg_id obtenidos previamente
ret = j2534.PassThruStopPeriodicMsg(channel_id, msg_id)
if ret == 0: # STATUS_NOERROR
print(f"Mensaje periódico detenido, MsgID: {msg_id}")
using System;
using System.Runtime.InteropServices;
// channelId y msgId obtenidos previamente
int ret = J2534.PassThruStopPeriodicMsg(channelId, msgId);
if (ret == 0) // STATUS_NOERROR
{
Console.WriteLine($"Mensaje periódico detenido, MsgID: {msgId}");
}