Suppression d'un message périodique
Dernière modification :
Arrête la transmission d'un message périodique et libère les ressources qui lui sont associées. Après l'appel, l'identifiant MsgID cesse d'être valide.
long PassThruStopPeriodicMsg(unsigned long ChannelID, unsigned long MsgID)
PassThruStartPeriodicMsg.| Code | Description | Causes possibles et solutions |
|---|---|---|
| STATUS_NOERROR | La fonction s'est exécutée correctement | — |
| ERR_INVALID_CHANNEL_ID | Identifiant de canal non valide |
|
| ERR_DEVICE_NOT_CONNECTED | Aucune connexion avec l'adaptateur |
|
| ERR_INVALID_DEVICE_ID | Identifiant de périphérique non valide |
|
| ERR_INVALID_MSG_ID | Identifiant de message non valide |
|
| ERR_FAILED | Erreur interne |
|
#include "j2534_lib.hpp"
unsigned long ChannelID; // ID du canal
unsigned long MsgID; // ID du message obtenu de PassThruStartPeriodicMsg
long Ret;
Ret = PassThruStopPeriodicMsg(ChannelID, MsgID);
if (Ret != STATUS_NOERROR)
{
// Gestion de l'erreur
}
// channelID et msgID obtenus précédemment
val result = j2534.ptStopPeriodicMsg(channelID, msgID)
if (result.status == STATUS_NOERROR) {
// Message périodique arrêté avec succès
Log.i("J2534", "Message périodique arrêté, MsgID: $msgID")
} else {
// Gestion de l'erreur
Log.e("J2534", "Erreur lors de l'arrêt du message périodique: ${result.status}")
}
import ctypes
# Chargement de la bibliothèque
j2534 = ctypes.CDLL("libj2534_v04_04.so") # Linux
# j2534 = ctypes.WinDLL("j2534sd_v04_04_x64.dll") # Windows
# channel_id et msg_id obtenus précédemment
ret = j2534.PassThruStopPeriodicMsg(channel_id, msg_id)
if ret == 0: # STATUS_NOERROR
print(f"Message périodique arrêté, MsgID: {msg_id}")
using System;
using System.Runtime.InteropServices;
// channelId et msgId obtenus précédemment
int ret = J2534.PassThruStopPeriodicMsg(channelId, msgId);
if (ret == 0) // STATUS_NOERROR
{
Console.WriteLine($"Message périodique arrêté, MsgID: {msgId}");
}