قدردانی

برخی از کدهای پیام به تأیید گیرنده نیاز دارند. در این حالت، گیرنده باید یک تأییدیه (ACK) یا تأیید منفی (NAK) را ظرف 1 ثانیه پس از دریافت پیام ارسال کند.

نام گروه پیام ارزش
تصدیق 0xFF
نام کد تصدیق ارزش
ACK 0x01
NAK 0x02

قدردانی ها باید مستقیماً پس از دریافت پیام ارسال شوند تا فرستنده بتواند مطابق آن عمل کند. یک تأییدیه باید حاوی گروه پیام، کد و وضعیت فعلی پیامی باشد که به آن ارجاع می دهد. برای مثال، اگر ارائه‌دهنده پیامی حاوی عمل حلقه ( 0x04010002013C ) دریافت کند، باید با ارسال 0xFF0100040401013C ، این عمل را تأیید کند:

  • 0xFF: رویداد ACK
  • 0x01: کد ACK
  • 0x0004: طول داده های اضافی
  • 0x0401: گروه و کد پیام اقدام
  • 0x013C: وضعیت فعلی گروه و کد پیام اقدام، زنگ به سمت راست و وقفه 60 ثانیه ای

برای یک NAK، دلیل نیز باید به عنوان اولین بایت داده اضافی درج شود. دلایل عبارتند از:

  • 0x00: پشتیبانی نمی شود
  • 0x01: دستگاه مشغول است
  • 0x02: به دلیل وضعیت فعلی مجاز نیست
  • 0x03: به دلیل کد احراز هویت اشتباه پیام مجاز نیست
  • 0x04: عملکرد دستگاه اضافی

از مثال قبلی، اگر قرار بود حلقه به جای آن به دلیل مشغول بودن ارائه دهنده با کار دیگری NAK شود، بسته برگشتی باید روی 0xFF02000401040100 تنظیم شود.

  • 0xFF: رویداد ACK
  • 0x02: کد NAK
  • 0x0004: طول داده های اضافی
  • 0x01: دلیل NAK، دستگاه مشغول است
  • 0x0401: گروه و کد پیام اقدام
  • 0x00: وضعیت فعلی گروه و کد پیام اقدام، زنگ زدن تمام اجزا متوقف می شود

مثال:

#define FP_MSG_ACK                                  0x01
#define FP_MSG_NAK                                  0x02
#define FP_MSG_GROUP_ACK                            0xFF


static void fp_msg_send_ack(uint8_t msgGroup, uint8_t msgCode)
{
    FP_MESSAGE_STREAM  req = {FP_MSG_GROUP_ACK, FP_MSG_ACK, 0, 2};

    req.data[0] = msgGroup;
    req.data[1] = msgCode;

   fp_send((uint8_t *)&req);
}

static void fp_msg_send_nak(uint8_t reason, uint8_t msgGroup, uint8_t msgCode)
{
//reason= 0x00: Not supported, 0x01: Device busy, or 0x02: Not allowed due to current state
    FP_MESSAGE_STREAM  req = {FP_MSG_GROUP_ACK, FP_MSG_NAK, 0, 3};

    req.data[0] = reason;
    req.data[1] = msgGroup;
    req.data[2] = msgCode;

   fp_send((uint8_t *)&req);
}