在厨房拨开内裤进入毛片-欧美一区亚洲二区-www九九热com-亚洲午夜久久久精品一区二区三剧-国产91精品看黄网站在线观看动漫-heyzo朝桐光一区二区

moecmks
級別: 正式會員
精華主題: 0
發帖數量: 3 個
工控威望: 96 點
下載積分: 648 分
在線時間: 24(小時)
注冊時間: 2017-02-12
最后登錄: 2017-05-19
查看moecmks的 主題 / 回貼
樓主  發表于: 2017-04-24 19:39
先發 FX1S數據讀報文,PLC接受到信號準備數據放到緩沖區。然后在用ReadFile從緩沖區接受一次報文。。。 30 MS左右
這時間正常嗎?還是說我設置有問題?總感覺這樣時間有點長啊。【工控菜鳥一個,放下代碼求老鳥指點一二,有無能提升效率的地方。 ^_^】

復制代碼
  1. #include <Windows.h>
  2. #include "codecb.h"
  3. #include "invariant.h"
  4. #include <assert.h>
  5. #include <tchar.h>
  6. #include "timing.h"
  7. extern HANDLE commport;
  8. _CRT_ALIGN (32)
  9. char ASCII_tonums_RVlut[0xFFFF+1];
  10. void build_ASC_RVlut (void)
  11. {
  12.   uint32_t ii;
  13.   static BOOL __init = FALSE;
  14.   if ( __init == TRUE) return;
  15.        __init  = TRUE;
  16.   ZeroMemory (ASCII_tonums_RVlut, sizeof (ASCII_tonums_RVlut));
  17.   for (ii = 0; ii != 0x10000; ii++) {
  18.    uint16_t lo = ii & 0x00FF;
  19.    uint16_t hi = ii >> 8;
  20.    if ( (( lo >= '0' && lo <= '9') || ( lo >= 'A' && lo <= 'F'))
  21.     && (( hi >= '0' && hi <= '9') || ( hi >= 'A' && hi <= 'F')))
  22.    {
  23.     if ( ( hi >= '0' && hi <= '9'))
  24.       ASCII_tonums_RVlut[ii] = hi - '0';
  25.     else if ( ( hi >= 'A' && hi <= 'F'))
  26.       ASCII_tonums_RVlut[ii] = hi - 'A' + 10;
  27.     if ( ( lo >= '0' && lo <= '9'))
  28.       ASCII_tonums_RVlut[ii] |= ( ( (unsigned) (lo - '0')) << 4);
  29.     else if ( ( lo >= 'A' && lo <= 'F'))
  30.       ASCII_tonums_RVlut[ii] |= ( ( (unsigned) (lo - 'A' + 10)) << 4);
  31.    }
  32.   }
  33. }
  34. BOOL comm_init (int comm_index)
  35. {
  36.   DCB dcbs;
  37.   COMMTIMEOUTS ct;  
  38.   BOOL success_io_;
  39.   TCHAR comm_buf0[256];
  40.   _stprintf (& comm_buf0[0], _T ("//./COM%i"), comm_index);
  41.   comm_close ();
  42.   commport = CreateFile ( & comm_buf0[0], GENERIC_READ | GENERIC_WRITE, 0,
  43.               NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL );
  44.   success_io_ = GetCommState (commport, & dcbs);
  45.   assert (success_io_ != FALSE);
  46.   dcbs.BaudRate = CBR_9600;
  47.   dcbs.fParity  = TRUE;
  48.   dcbs.Parity   = EVENPARITY;
  49.   dcbs.StopBits = ONESTOPBIT;
  50.   dcbs.ByteSize = 7;
  51.   dcbs.fDtrControl = DTR_CONTROL_DISABLE;
  52.   dcbs.fRtsControl = RTS_CONTROL_DISABLE;
  53.     
  54.   success_io_ = SetupComm (commport, 2048, 2048);
  55.   assert (success_io_ != FALSE);
  56.   success_io_ = SetCommState (commport, & dcbs);
  57.   assert (success_io_ != FALSE);
  58.   // SetTimeOut.
  59.   ct.ReadIntervalTimeout = 0x0000FFFF;
  60.   ct.ReadTotalTimeoutMultiplier = 0x0000FFFF;
  61.   ct.ReadTotalTimeoutConstant = 0xFFFFFFFE;
  62.   ct.WriteTotalTimeoutMultiplier = 0x0000FFFF;
  63.   ct.WriteTotalTimeoutConstant =   0xFFFFFFFE;  
  64.   
  65.   success_io_ = SetCommTimeouts (commport, &ct);  
  66.   assert (success_io_ != FALSE);
  67.   success_io_ = SetupComm (commport, 2400, 2400);  
  68.   assert (success_io_ != FALSE);
  69.   success_io_ = PurgeComm (commport, PURGE_RXABORT | PURGE_TXCLEAR | PURGE_RXCLEAR | PURGE_TXABORT);
  70.   assert (success_io_ != FALSE);
  71.   build_ASC_RVlut ();
  72.   
  73.   timing_init48 ();
  74.   INIT_WSCCRSEC__;
  75. }
  76. void comm_close (void)
  77. {
  78.   if (commport != INVALID_HANDLE_VALUE)
  79.   {
  80.     PurgeComm (commport, PURGE_RXABORT | PURGE_TXCLEAR | PURGE_RXCLEAR | PURGE_TXABORT);
  81.     CloseHandle (commport);
  82.   }
  83.   commport = INVALID_HANDLE_VALUE;
  84. }
  85. int8_t readOYB (int16_t e_addr) {
  86.   struct read_section2 rdsec;
  87.   char varsbuf[128];
  88.   int isr = 0;
  89.   int tm_numbs = 0;
  90.   uint16_t rv_numbs = 0;
  91.   BOOL io_success_;
  92.   DWORD rv_numbs2 = 0;
  93.   /* prepare Output-register read_section. */
  94.   isr = fx1s_makersecb ( & rdsec, FX1S_REGISTER_FIELD_Y_OUT,
  95.         & rv_numbs, FX1S_VERSION_30MR, e_addr);
  96.   assert (isr == FX1S_OK);
  97.   /* write Output-register read-code. */
  98.   io_success_ = WriteFile (commport, & rdsec,
  99.      sizeof(struct read_section), & tm_numbs, NULL);
  100.   assert (io_success_ != FALSE);
  101.   assert (tm_numbs == sizeof(struct read_section));
  102.   io_success_ = ReadFile  (commport, & varsbuf[0], rv_numbs, & rv_numbs2, NULL);
  103.   assert (io_success_ != FALSE);
  104.   assert (rv_numbs2 == rv_numbs);
  105.   assert (varsbuf[0] == SECTION_LINK_STX);
  106.   return ASCII_tonums_RVlut[ *(uint16_t *)& varsbuf[1]];
  107. }
  108. void setOYB (int16_t e_addr, int8_t val) {
  109.   char varsbuf[128];
  110.   int isr = 0;
  111.   int tm_numbs = 0;
  112.   uint16_t rv_numbs = 0;
  113.   BOOL io_success_;
  114.   DWORD rv_numbs2 = 0;
  115.   /* prepare Output-register write_section. */
  116.   isr = fx1s_makewsecb (& varsbuf[0], & val, FX1S_REGISTER_FIELD_Y_OUT,
  117.               & rv_numbs, FX1S_VERSION_30MR, e_addr);
  118.   assert (isr == FX1S_OK);
  119.   /* write Output-register write-code. */
  120.   io_success_ = WriteFile (commport, & varsbuf[0],
  121.      rv_numbs, & tm_numbs, NULL);
  122.   assert (io_success_ != FALSE);
  123.   assert (rv_numbs == tm_numbs);
  124.   io_success_ = ReadFile  (commport, & varsbuf[0], 1, & rv_numbs2, NULL);
  125.   assert (io_success_ != FALSE);
  126.   assert (rv_numbs2 == 1);
  127.   assert (varsbuf[0] == SECTION_LINK_ACK);
  128. }
  129. static __forceinline
  130. int8_t readRELAY_M (int16_t addr) {
  131.   struct read_section2 rdsec;
  132.   char varsbuf[128];
  133.   int isr = 0;
  134.   int tm_numbs = 0;
  135.   uint16_t rv_numbs = 0;
  136.   BOOL io_success_;
  137.   DWORD rv_numbs2;
  138.   isr = fx1s_makersecb ( & rdsec, FX1S_REGISTER_FIELD_M,
  139.         & rv_numbs, FX1S_VERSION_14MR, addr);
  140.   assert (isr == FX1S_OK);
  141.   io_success_ = WriteFile (commport, & rdsec,
  142.      sizeof(struct read_section), & tm_numbs, NULL);
  143.   assert (io_success_ != FALSE);
  144.   assert (tm_numbs == sizeof(struct read_section));
  145.   io_success_ = ReadFile  (commport, & varsbuf[0], rv_numbs, & rv_numbs2, NULL);
  146.   assert (io_success_ != FALSE);
  147.   assert (rv_numbs2 == rv_numbs);
  148.   assert (varsbuf[0] == SECTION_LINK_STX);
  149.   return ASCII_tonums_RVlut[ *(uint16_t *)& varsbuf[1]];
  150. }
  151. static  __forceinline
  152. void writeRELAY_M (uint16_t addr, int8_t val) {
  153.   char varsbuf[128];
  154.   int isr = 0;
  155.   int tm_numbs = 0;
  156.   uint16_t rv_numbs = 0;
  157.   BOOL io_success_;
  158.   DWORD rv_numbs2;
  159.   /* prepare Output-register write_section. */
  160.   isr = fx1s_makewsecb (& varsbuf[0], & val, FX1S_REGISTER_FIELD_M,
  161.               & rv_numbs, FX1S_VERSION_14MR, addr);
  162.   assert (isr == FX1S_OK);
  163.   /* write Output-register write-code. */
  164.   io_success_ = WriteFile (commport, & varsbuf[0],
  165.      rv_numbs, & tm_numbs, NULL);
  166.   assert (io_success_ != FALSE);
  167.   assert (rv_numbs == tm_numbs);
  168.   io_success_ = ReadFile  (commport, & varsbuf[0], 1, & rv_numbs2, NULL);
  169.   assert (io_success_ != FALSE);
  170.   assert (rv_numbs2 == 1);
  171.   assert (varsbuf[0] == SECTION_LINK_ACK);
  172. }
  173. void plc_force_close_ (void) {
  174.   BYTE obt;
  175.     /* force close PLC [by M8037]  **/
  176.     obt = readRELAY_M (8037);
  177.     writeRELAY_M (8037, obt | 0x20);
  178. }
  179. void plc_force_open_ (void) {
  180.   BYTE obt;
  181.   /* force open PLC [by M8035/M8036/M8037]  **/
  182.   obt = readRELAY_M (8037);
  183.   obt &= ~(1 << (8037 & 7));
  184.   writeRELAY_M (8037, obt);
  185.   obt = readRELAY_M (8035);
  186.   obt |= (11 << (8035 & 7));
  187.   writeRELAY_M (8035, obt);
  188. }
  189. void plc_set_pulse235_ (uint32_t val) {
  190.   int isr = 0;
  191.   char varsbuf[128];
  192.   uint16_t rv_numbs = 0;
  193.   DWORD rv_numbs2 = 0;
  194.   DWORD rv_numbs3 = 0;
  195.   BOOL io_success_;
  196.   isr = fx1s_makewsecb (& varsbuf[0], & val, FX1S_REGISTER_FIELD_C32,
  197.               & rv_numbs, FX1S_VERSION_14MR, PULSE_ENCODER_ADDR);
  198.   assert (isr == FX1S_OK);
  199.   rv_numbs2 = rv_numbs;
  200.   io_success_ = WriteFile (commport, & varsbuf[0], rv_numbs, & rv_numbs3, NULL);
  201.   assert (io_success_ != FALSE);
  202.   assert (rv_numbs2 == rv_numbs3);
  203.   io_success_ = ReadFile  (commport, & varsbuf[0], 1, & rv_numbs2, NULL);
  204.   assert (io_success_ != FALSE);
  205.   assert (rv_numbs2 == 1);
  206.   assert (varsbuf[0] == SECTION_LINK_ACK);
  207. }
  208. uint32_t plc_get_pulse235_ (void) {
  209.   union {
  210.     char bgroup[4];
  211.     int32_t inter;
  212.   } cc_timing;
  213.   BOOL io_success_;
  214.   DWORD rv_numbs = 0;
  215.   BYTE varsbuf[128];
  216.   io_success_ = WriteFile (commport, & g_crs2_pulse235.rsc, sizeof (struct read_section), & rv_numbs, NULL);
  217.   assert (io_success_ != FALSE);
  218.   assert (rv_numbs == sizeof (struct read_section));
  219.   io_success_ = ReadFile  (commport, & varsbuf [0], g_crs2_pulse235.rsc_cnt, & rv_numbs, NULL);
  220.   assert (io_success_ != FALSE);
  221.   assert (rv_numbs == g_crs2_pulse235.rsc_cnt);
  222.   assert (varsbuf[0] == SECTION_LINK_STX);
  223.   assert (varsbuf[9] == SECTION_LINK_ETX);
  224.   cc_timing.bgroup[0] = ASCII_tonums_RVlut[ *(uint16_t *)& varsbuf[1]];
  225.   cc_timing.bgroup[1] = ASCII_tonums_RVlut[ *(uint16_t *)& varsbuf[3]];
  226.   cc_timing.bgroup[2] = ASCII_tonums_RVlut[ *(uint16_t *)& varsbuf[5]];
  227.   cc_timing.bgroup[3] = ASCII_tonums_RVlut[ *(uint16_t *)& varsbuf[7]];
  228.   return cc_timing.inter;
  229. }


moecmks
級別: 正式會員
精華主題: 0
發帖數量: 3 個
工控威望: 96 點
下載積分: 648 分
在線時間: 24(小時)
注冊時間: 2017-02-12
最后登錄: 2017-05-19
查看moecmks的 主題 / 回貼
1樓  發表于: 2017-04-24 19:48
FX1S 報文編解碼
復制代碼
  1. /*-
  2. * Copyright (c) 2017 moecmks
  3. * All rights reserved.
  4. *
  5. * Redistribution and use in source and binary forms, with or without
  6. * modification, are permitted provided that the following conditions
  7. * are met:
  8. * 1. Redistributions of source code must retain the above copyright
  9. *    notice, this list of conditions and the following disclaimer.
  10. * 2. Redistributions in binary form must reproduce the above copyright
  11. *    notice, this list of conditions and the following disclaimer in the
  12. *    documentation and/or other materials provided with the distribution.
  13. *
  14. * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
  15. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  16. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  17. * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
  18. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  19. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  20. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  21. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRCMD, STRICT
  22. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  23. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  24. * SUCH DAMAGE.
  25. *
  26. */
  27. #if !defined (codec_included_MOECMKS)
  28. #define codec_included_MOECMKS
  29. /*
  30. * fx1s read/write codec.
  31. * simple, each read a current register size unit memory
  32. * more information, please refer to the PLC manual and Internet resources.
  33. */
  34. #if defined (__cplusplus)  /** __cplusplus */
  35. extern "C" {
  36. #endif  /** __cplusplus */
  37. /* Portable fixed length ***/
  38. #include "stdint.h"
  39. /*
  40. * errror code
  41. */
  42. #define FX1S_RANGE 1
  43. #define FX1S_FAIL 2
  44. #define FX1S_KFAIL 3
  45. #define FX1S_UNKN 4
  46. #define FX1S_LIMIT 5
  47. #define FX1S_NAK 6
  48. #define FX1S_ACK 7
  49. #define FX1S_PARA 8
  50. #define FX1S_INCOP 9
  51. #define FX1S_OK 0
  52. /*
  53. * version control
  54. */
  55. enum FX1S_VERSION {
  56.   FX1S_VERSION_10MR = 0,
  57.   FX1S_VERSION_14MR,
  58.   FX1S_VERSION_20MR,
  59.   FX1S_VERSION_30MR,
  60.   FX1S_VERSION_OVERFLAGS
  61. };
  62. /*
  63. * register field.
  64. * Ignore T bit register and set register.
  65. * Ignore C bit register
  66. */
  67. enum FX1S_REGISTER_FIELD {
  68.   FX1S_REGISTER_FIELD_S = 0,
  69.   FX1S_REGISTER_FIELD_X,
  70.   FX1S_REGISTER_FIELD_Y_OUT,
  71.   FX1S_REGISTER_FIELD_Y_PLS,
  72.   FX1S_REGISTER_FIELD_D,
  73.   FX1S_REGISTER_FIELD_T,
  74.   FX1S_REGISTER_FIELD_M,
  75.   FX1S_REGISTER_FIELD_C16,
  76.   FX1S_REGISTER_FIELD_C32,
  77.   FX1S_REGISTER_FIELD_CRESET
  78. };
  79. /*
  80. * section .link code
  81. */
  82. #define SECTION_LINK_STX 0x02 /* PLC info-section begin flags. */
  83. #define SECTION_LINK_ETX 0x03 /* PLC info-section end flags .***/
  84. #define SECTION_LINK_EOT 0x03 /* .***/
  85. #define SECTION_LINK_ENQ 0x05 /* PLC only test enable */
  86. #define SECTION_LINK_ACK 0x06 /* PLC reply "can do" */
  87. #define SECTION_LINK_LF 0x0A /* .***/
  88. #define SECTION_LINK_CL 0x0C /* .***/
  89. #define SECTION_LINK_CR 0x0D /* .***/
  90. #define SECTION_LINK_NAK 0x15 /* PLC reply "bad things" */
  91. /*
  92. * section cmdion.
  93. */
  94. #define SECTION_CMD_READ      '0' /* .***/
  95. #define SECTION_CMD_WRITE     '1' /* .***/
  96. #define SECTION_CMD_FORCE_ON  '7' /* .***/
  97. #define SECTION_CMD_FORCE_OFF '8' /* .***/
  98. /*
  99. * read section
  100. */
  101. struct read_section {
  102.   uint8_t stx; /* read_section's stdhead. always SECTIOM_LINK_STX */
  103.   uint8_t cmd; /* read_section's cmd  always SECTIOM_CMD_READ  */
  104.   uint8_t unit_address[4];  /* read_section's address*/
  105.   uint8_t numb[2];          /* read's byte count. simple always one */
  106.   uint8_t etx;    /* read_section's stdend.   always SECTION_LINK_ETX  */
  107.   uint8_t crc[2]; /* correcting code*/
  108. };
  109. /*
  110. * read section2
  111. */
  112. struct read_section2 {
  113.   uint8_t stx; /* read_section's stdhead. always SECTIOM_LINK_STX */
  114.   uint8_t cmd; /* read_section's cmd  always SECTIOM_CMD_READ  */
  115.   uint8_t unit_address[4];  /* read_section's address*/
  116.   uint8_t numb[2];          /* read's byte count. simple always one */
  117.   uint8_t etx;    /* read_section's stdend.   always SECTION_LINK_ETX  */
  118.   uint8_t crc[2]; /* correcting code*/
  119.   uint8_t crce; /* easy to read..**/
  120.   uint16_t opbsize; /******/
  121.   uint8_t opboff; /* for bit register(X, Y, M.) **/
  122.   uint16_t opbaddr; /* easy to read. **/
  123. };
  124. /*
  125. * write section
  126. */
  127. struct write_section {
  128.   uint8_t stx; /* write_section's stdhead.  always SECTIOM_LINK_STX */
  129.   uint8_t cmd; /* write_section's cmd  always SECTIOM_CMD_WRITE   */
  130.   uint8_t unit_address[4]; /* write_section's address*/
  131.   uint8_t numb[2]; /* write's byte count.. must <= 64  */
  132.   uint8_t etx; /* write_section's stdend. */
  133.   uint8_t crc[2]; /* correcting code*/
  134.   uint8_t crce; /* easy to read..**/
  135.   uint8_t obpoff; /* for bit register(X, Y, M.) **/
  136.   uint16_t opbaddr; /* easy to read. **/
  137. };
  138. /*
  139. * force section
  140. */
  141. struct force_section {
  142.   uint8_t stx; /* force_section's stdhead.  always SECTIOM_LINK_STX */
  143.   uint8_t cmd; /* force_section's cmd  always SECTIOM_CMD_FORCE_OFF or SECTIOM_CMD_FORCE_ON   */
  144.   uint8_t unit_address[4]; /* force_section's address*/
  145.   uint8_t etx; /* force_section's stdend. */
  146.   uint8_t crc[2]; /* correcting code*/
  147. };
  148. /*
  149. * Accept the write section is very simple,
  150. * if successful send SECTION_LINK_ACK otherwise SECTION_LINK_NAK
  151. */
  152. int fx1s_makersecb (struct read_section2 *rsec, /* write to the serial port, use the size of the read_section */
  153.                          enum FX1S_REGISTER_FIELD rf, uint16_t  *rvap_size,
  154.                          enum FX1S_VERSION ver, uint16_t address);
  155. int fx1s_makewsecb (void *wsec, /* Variable size structure, so use void *, please understand **/
  156.                    void *spval,
  157.                          enum FX1S_REGISTER_FIELD rf, uint16_t  *wsec_size,
  158.                          enum FX1S_VERSION ver, uint16_t address);
  159. int fx1s_makefsecb (struct force_section *fsec,
  160.                          enum FX1S_REGISTER_FIELD rf,
  161.                          enum FX1S_VERSION ver, uint16_t address);            
  162. #if defined (__cplusplus)  /** __cplusplus */
  163. }
  164. #endif  /** __cplusplus */
  165. #endif /* codec_included_MOECMKS */
moecmks
級別: 正式會員
精華主題: 0
發帖數量: 3 個
工控威望: 96 點
下載積分: 648 分
在線時間: 24(小時)
注冊時間: 2017-02-12
最后登錄: 2017-05-19
查看moecmks的 主題 / 回貼
2樓  發表于: 2017-04-24 19:52
復制代碼
  1. /*-
  2. * Copyright (c) 2017 moecmks
  3. * All rights reserved.
  4. *
  5. * Redistribution and use in source and binary forms, with or without
  6. * modification, are permitted provided that the following conditions
  7. * are met:
  8. * 1. Redistributions of source code must retain the above copyright
  9. *    notice, this list of conditions and the following disclaimer.
  10. * 2. Redistributions in binary form must reproduce the above copyright
  11. *    notice, this list of conditions and the following disclaimer in the
  12. *    documentation and/or other materials provided with the distribution.
  13. *
  14. * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
  15. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  16. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  17. * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
  18. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  19. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  20. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  21. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  22. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  23. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  24. * SUCH DAMAGE.
  25. *
  26. */
  27. #include <assert.h>
  28. #include <string.h>
  29. #include "codecb.h"
  30. /* Convert characters to specific number - noexport */
  31. static
  32. char ascii_to_num (char ch) {
  33.   /* e.g.
  34.    *  source '9' -> target 9
  35.    *  source 'A' -> target 10
  36.    *  source '1' -> target 1
  37.    *  source 'a' -> (nondone, Don't use lowercase letters in fx1s-14mr-001).
  38.    */
  39.   if (ch >= '0' && ch <= '9')
  40.     return (ch - '0');
  41.   if (ch >= 'A' && ch <= 'F')
  42.     return (ch - ('A' - 10));
  43.   else
  44.     assert (0);
  45.   return ch;
  46. }
  47. /* Convert number to specific characters - noexport */
  48. static
  49. char num_to_ascii (char ch) {
  50.   /* e.g.
  51.    *  source 9 -> target '9'
  52.    *  source A -> target '0'
  53.    *  source 1 -> target '1'
  54.    *  source a -> (nondone, Don't use lowercase letters in fx1s-14mr-001).
  55.    */
  56.   if (ch >= 0x00 && ch <= 0x09)
  57.     return (ch + '0');
  58.   if (ch >= 0x0A && ch <= 0x0F)
  59.     return (ch + ('A' - 10));
  60.   else
  61.     assert (0);
  62.   return ch;
  63. }
  64. /* XXX:L-endian.
  65. */
  66. static
  67. uint16_t vailed8 (uint16_t nums) {
  68.   
  69.   /* e.g.
  70.    * 1234 vailed.
  71.    * 9000 invailed.
  72.    * 1007 vailed.
  73.    * 1811 invailed.
  74.    * 0 ~ 65535
  75.    */
  76.    uint16_t d0 = nums % 10 >> 0;
  77.    uint16_t d1 = nums % 100 / 10;
  78.    uint16_t d2 = nums % 1000 / 100;
  79.    uint16_t d3 = nums % 10000 / 1000;
  80.   
  81.    if ( d0 > 7 || d1 > 7)
  82.      return -1;
  83.    if ( d2 > 7)
  84.      return -1;
  85.    return d0 + d1 * 8 + d2 * 8 * 8 + d3 * 8 * 8 * 8;
  86. }
  87. static
  88. uint8_t fxcrc_adjust (unsigned char *crcbuf, uint32_t num) {
  89.   
  90.   uint32_t s= 0;
  91.   uint32_t st = 0;
  92.   
  93.   for (; s != num; s++)
  94.     st += crcbuf[s];
  95.   /* we only save lowest bit's byte **/
  96.   return st & 0xFF;
  97. }
  98. static /* we not check numb cross register **.**/
  99. uint32_t fxcalc_addru (enum FXREGS_FIELD reg, uint16_t addr,
  100.                            enum FX1S_VERSION ver,
  101.                            uint16_t  *opbsize,
  102.                                 uint16_t *raddr, unsigned char *dboff) {
  103.   
  104.   static const /* XXX:enum constant dependence **/
  105.                    uint16_t xmax_tab[4] = { 6, 8, 12, 16 };
  106.   static const /* XXX:enum constant dependence **/
  107.                    uint16_t ymax_tab[4] = { 4, 6, 8, 14 };
  108.   uint16_t addr0 = 0x00A0;
  109.   uint16_t eig = vailed8 (addr);
  110.   uint8_t off = -1;
  111.   uint32_t opbsize0 = 2;
  112.   switch (reg) {
  113.     
  114.   case FX1S_REGISTER_FIELD_D:
  115.   
  116.     if (addr <= 127 && addr == addr) /* numbers: 128, normal use */
  117.       addr0 = 0x1000 + addr * 2;
  118.     else if (addr <= 255) /* numbers: 128, save use */
  119.       addr0 = 0x1000 + addr * 2;
  120.     else if (addr >= 1000 && addr <= 2499)  /* numbers: 1500, file register */
  121.       addr0 = 0x1000 + addr * 2;
  122.     else if (addr >= 8000 && addr <= 8255) /* numbers: 256, special IO port */
  123.       addr0 = 0x0E00 + (addr - 8000) * 2;
  124.     else  /* Illegal access */
  125.       return FX1S_RANGE;
  126.     break;
  127.   case FX1S_REGISTER_FIELD_X:
  128.     /*
  129.      * Check the number of available X-coils according to the PLC version
  130.      */
  131.     if ((eig = vailed8 (addr)) == -1
  132.      || (eig >= xmax_tab[ver]) )
  133.       return FX1S_PARA;
  134.       
  135.     addr0 = 0x0080 + eig / 8;
  136.     off = eig & 7;
  137.     
  138.     opbsize0 = 1;
  139.     break;
  140.     
  141.   case FX1S_REGISTER_FIELD_Y_PLS:
  142.     addr0 += 0x0200;
  143.   case FX1S_REGISTER_FIELD_Y_OUT:
  144.   
  145.     /*
  146.      * Check the number of available Y-coils according to the PLC version
  147.      */
  148.     if ((eig = vailed8 (addr)) == -1)
  149.       return FX1S_PARA;
  150.     
  151.     addr0 += eig / 8;
  152.     off = eig & 7;
  153.     
  154.     opbsize0 = 1;
  155.     break;
  156.   case FX1S_REGISTER_FIELD_S:
  157.   
  158.     if ((addr >=  128)) /* numbers:128, status register **/
  159.       return FX1S_RANGE;
  160.     addr0 = addr / 8;
  161.     off = addr & 7;
  162.     
  163.     opbsize0 = 1;
  164.     break;
  165.   
  166.   case FX1S_REGISTER_FIELD_T:
  167.   
  168.     if ( (addr <=  63)) /* numbers:64, 100ms or 10ms M8028/D8030/D8031 **/
  169.       addr0 = 0x0800 + addr * 2;
  170.     else    
  171.       return FX1S_RANGE;
  172.     break;
  173.     
  174.   case FX1S_REGISTER_FIELD_M:
  175.   
  176.     if (addr < 384) /* numbers: 384, normal use */
  177.       addr0 = 0x0100 + addr / 8;
  178.     else if (addr < 512) /* numbers: 512, save use */
  179.       addr0 = 0x0100 + addr / 8;
  180.     else if (addr >= 8000 && addr < 8256) /* numbers: 256, special IO port */
  181.       addr0 = 0x01E0 + (addr - 8000) / 8;
  182.     else /* Illegal access */
  183.       return FX1S_RANGE;
  184.     
  185.     off = addr & 7;
  186.     opbsize0 = 1;
  187.     break;
  188.   
  189.   case FX1S_REGISTER_FIELD_C16:
  190.   
  191.     if (addr < 16) /* numbers: 16, normal use */
  192.       addr0 = 0x0A00 + addr * 2;
  193.     else if (addr < 32) /* numbers: 16, save use */
  194.       addr0 = 0x0A00 + addr * 2;
  195.     else /* Illegal access */
  196.       return FX1S_RANGE;
  197.     break;
  198.     
  199.   case FX1S_REGISTER_FIELD_C32:
  200.   
  201.    /* for C32 high speed registers,
  202.     * we only perform some basic checks, please note
  203.     **/
  204.     if (addr > 200 && addr <= 255)
  205.       addr0 = 0x0C00 + (addr - 200) * 4;
  206.     else /* Illegal access */
  207.       return FX1S_RANGE;
  208.       
  209.     opbsize0 = 4;
  210.     break;
  211.   
  212.   case FX1S_REGISTER_FIELD_CRESET:
  213.   
  214.     if (addr <= 255)
  215.       addr0 = 0x03C0 + addr / 8;
  216.     else /* Illegal access */
  217.       return FX1S_RANGE;
  218.       
  219.     opbsize0 = 1;
  220.     break;
  221.     
  222.   default:
  223.       return FX1S_PARA;
  224.   }
  225.   
  226.   *raddr = addr0;
  227.   *dboff = off;
  228.   *opbsize = opbsize0;
  229.   return FX1S_OK;
  230. }
  231. int fx1s_makersecb (struct read_section2 *rsec, /* write to the serial port, use the size of the read_section */
  232.                          enum FX1S_REGISTER_FIELD rf, uint16_t  *rvap_size,
  233.                          enum FX1S_VERSION ver, uint16_t address)
  234. {
  235.   struct read_section2 sec;
  236.   uint32_t e;
  237.   
  238.   /** phase 1:fill stdhead/stdend flags and cmd, rread count,s */
  239.   sec.stx = SECTION_LINK_STX;
  240.   sec.etx = SECTION_LINK_ETX;
  241.   sec.cmd = SECTION_CMD_READ;
  242.   /** phase 2:calc address for register and current PLC version */
  243.   e = fxcalc_addru (rf, address, ver, & sec.opbsize, & sec.opbaddr, & sec.opboff);
  244.   if (e != FX1S_OK)
  245.     return e;
  246.   else
  247.    *rvap_size = sizeof (sec.stx) +
  248.                 sizeof (sec.crc)+ sizeof (sec.etx) + sec.opbsize * 2;
  249.   /** phase 3:fill numb ascii, * */
  250.   sec.numb[0] = num_to_ascii ( (sec.opbsize  & 0xF0) >>4);
  251.   sec.numb[1] = num_to_ascii ( (sec.opbsize  & 0x0F) >>0);
  252.   
  253.   /** phase 4:fill address ascii, * */
  254.   sec.unit_address[0] = num_to_ascii ( (sec.opbaddr  & 0xF000) >>12);
  255.   sec.unit_address[1] = num_to_ascii ( (sec.opbaddr  & 0x0F00) >> 8);
  256.   sec.unit_address[2] = num_to_ascii ( (sec.opbaddr  & 0x00F0) >> 4);
  257.   sec.unit_address[3] = num_to_ascii ( (sec.opbaddr  & 0x000F) >> 0);
  258.   
  259.   /** phase 5:crc adjust, fill ascii buf * */
  260.   sec.crce = fxcrc_adjust (& sec.cmd, sizeof (sec.cmd) + sizeof (sec.unit_address)
  261.                                         + sizeof (sec.numb)
  262.                                         + sizeof (sec.etx));
  263.   sec.crc[0] = num_to_ascii ( (sec.crce  & 0xF0) >> 4);
  264.   sec.crc[1] = num_to_ascii ( (sec.crce  & 0x0F) >> 0);
  265.   
  266.   memcpy (rsec, & sec, sizeof (sec));
  267.   return FX1S_OK;  
  268. }
  269. int fx1s_makewsecb (void *wsec, /* Variable size structure, so use void *, please understand **/
  270.                    void *buf, /* wsec size == sizeof(wc) * 2  **/
  271.                          enum FX1S_REGISTER_FIELD rf, uint16_t *wsec_size,
  272.                          enum FX1S_VERSION ver, uint16_t address)
  273. {
  274.   uint16_t opbsize, opbaddr;
  275.   char obpoff;
  276.   char varsbuf[256];
  277.   char *as = buf, cs;
  278.   uint32_t e;
  279.   uint32_t s = 0;
  280.   struct write_section *secp = wsec;
  281.   struct write_section *secdp = (void *)varsbuf;
  282.   /** phase 1:fill stdhead flags and cmd */
  283.   secdp->stx = SECTION_LINK_STX;
  284.   secdp->cmd = SECTION_CMD_WRITE;
  285.   /** phase 2:calc address for register and current PLC version */
  286.   e = fxcalc_addru (rf, address, ver, & opbsize, & opbaddr, & obpoff);
  287.   if (e != FX1S_OK)
  288.     return e;
  289.   else
  290.     *wsec_size = sizeof (struct write_section) + opbsize * 2;
  291.   /** phase 3:fill numb ascii, * */
  292.   secdp->numb[0] = num_to_ascii ( (opbsize  & 0xF0) >>4);
  293.   secdp->numb[1] = num_to_ascii ( (opbsize  & 0x0F) >>0);
  294.   
  295.   /** phase 4:fill address ascii, * */
  296.   secdp->unit_address[0] = num_to_ascii ( (opbaddr  & 0xF000) >>12);
  297.   secdp->unit_address[1] = num_to_ascii ( (opbaddr  & 0x0F00) >> 8);
  298.   secdp->unit_address[2] = num_to_ascii ( (opbaddr  & 0x00F0) >> 4);
  299.   secdp->unit_address[3] = num_to_ascii ( (opbaddr  & 0x000F) >> 0);
  300.   
  301.   /** phase 5:fill variable buffer, * */
  302.   for ( ; s != opbsize; s++) {
  303.     unsigned char  temp = as[s];
  304.     char  tmphi = num_to_ascii (temp >> 4);
  305.     char  tmplo = num_to_ascii (temp & 15);
  306.     
  307.     secdp->numb[2+s*2+0] = tmphi;
  308.     secdp->numb[2+s*2+1] = tmplo;
  309.   }
  310.   /** phase 6:crc adjust, fill ascii buf * */
  311.   secdp->numb[2+opbsize*2] = SECTION_LINK_ETX;
  312.   
  313.   cs = fxcrc_adjust (& secdp->cmd, opbsize * 2 + sizeof (secp->cmd) + sizeof (secp->unit_address)
  314.                                         + sizeof (secp->numb)
  315.                                         + sizeof (secp->etx));
  316.   secdp->numb[2+opbsize*2+1] = num_to_ascii ( (cs  & 0xF0) >> 4);
  317.   secdp->numb[2+opbsize*2+2] = num_to_ascii ( (cs  & 0x0F) >> 0);
  318.   
  319.   memcpy (wsec, & varsbuf, *wsec_size);
  320.   return FX1S_OK;
  321. }
  322. uint32_t fx1s_cmprvpack (void *raccbuf, /* Variable size structure, so use void *, please understand **/
  323.                          uint16_t rc, void **ascii_buf, uint16_t *opbsize
  324.                          , uint16_t *stdpos)
  325. {
  326.   char *varsbuf = raccbuf;
  327.   uint16_t c = 0;
  328.   char stx_find = 0;
  329.   uint16_t stdpos0 = -1;
  330.   
  331.   /* we find SECTION_LINK_NAK or SECTION_LINK_STX at first **/
  332.   for (; c != rc; c++)
  333.    {
  334.      if (varsbuf[c] == SECTION_LINK_NAK)
  335.        return FX1S_NAK;
  336.      if (varsbuf[c] == SECTION_LINK_STX)
  337.       {
  338.         /* second, we check SECTION_LINK_ETX in buffer **/
  339.         stx_find = 1;
  340.         stdpos0 = c + 1;
  341.       }  
  342.      if (varsbuf[c] == SECTION_LINK_ETX && stx_find == 1)
  343.       {
  344.         /* exist CRC byte ??**/
  345.         if ((c + 2) >= rc)
  346.           return FX1S_INCOP;
  347.         /* calculate, compare the CRC code **/
  348.         {
  349.       # if 0
  350.       # else
  351.           *ascii_buf = & varsbuf[stdpos0];
  352.           *opbsize = c - stdpos0;
  353.           *stdpos = stdpos0;
  354.           return FX1S_OK;
  355.       # endif    
  356.         }
  357.       }
  358.    }
  359.   
  360.    return FX1S_INCOP;
  361. }                    
  362. uint32_t fx1s_decrvsec (void *raccbuf, void *sbuf, uint16_t opbasize) {
  363.   
  364.   char *varsbuf = raccbuf;
  365.   char *ssbuf = sbuf;
  366.   uint16_t c = 0;
  367.   
  368.   if (opbasize % 2 == 1)
  369.     return FX1S_INCOP;
  370.   if (opbasize == 0)
  371.     return FX1S_PARA;
  372.   
  373.   for ( ; c != opbasize; c += 2)
  374.     {
  375.       char tmphi = ascii_to_num (varsbuf[c]) << 4;
  376.       char tmplo = ascii_to_num (varsbuf[c+1]);  
  377.       char temp  =   (tmphi & 0xF0) |    (tmplo & 0x0F);
  378.       
  379.       ssbuf[c>>1] = temp;
  380.     }
  381.     
  382.     return FX1S_OK;
  383. }

主站蜘蛛池模板: 中文字幕被公侵犯的漂亮人妻 | 伊人色在线 | 69xxx中国| 超碰网站在线观看 | 国产精品久久久久久久久久久久午夜 | 国产亚洲精品久久久久久国模美 | 国产美女一区二区三区 | 日日噜噜夜夜狠狠久久av小说 | 精品国产乱码久久久久久88av | 美女被张开双腿日出白浆 | 波多野结衣视频在线 | 天天躁夜夜躁狠狠躁2020色戒 | 欧美在线brazzers免费视频 | 国产高潮久久久 | 麻豆日产六区 | 影音先锋亚洲天堂 | 国产网站黄色 | 国产美女极度色诱视频www | 粉嫩91精品久久久久久久99蜜桃 | 亚洲线精品一区二区三区影音先锋 | 9l视频自拍蝌蚪9l视频成人 | 欧美在线成人免费 | 日韩午夜一区 | 免费av高清| 久久国产精品无码网站 | 欧美黑大粗 | 免费成人用春色 | 欧美日韩在线观看一区二区 | 无码人妻一区二区三区免费 | 国产成人亚洲综合a∨婷婷 国产成人艳妇aa视频在线 | 国产chinesehd精品露脸 | 天天久久 | 在线日本看片免费人成视久网 | 亚洲国产丝袜在线观看 | 欧美一级做a爰片久久高潮 欧美一级做a爰片免费视频 | 日本三级吃奶头添泬 | www色| 日韩黄色三级 | 欧美日韩精品中文字幕 | 久久久经典 | av激情在线| 91精品无人区卡一卡二卡三 | 成人激情视频在线观看 | 国模私拍一区二区三区 | 亚洲欧美在线精品 | 国产精品永久久久 | 无码高潮少妇毛多水多水免费 | 就要干就要操 | 美女内射视频www网站午夜 | 日韩中文字幕观看 | 中文字幕播放 | 中文字幕91在线 | 美女脱免费看网站女同 | 精品美女久久久 | 亚洲人ⅴsaⅴ国产精品 | 亚洲人午夜精品 | 人妻熟妇乱又伦精品视频app | 亚洲国产精品无码久久一区二区 | 日日碰狠狠丁香久燥 | 中出在线视频 | 亚洲 综合 欧美 动漫 丝袜图 | 青青青网| 亚洲鲁鲁 | 熟女毛毛多熟妇人妻aⅴ在线毛片 | 成人性视频欧美一区二区三区 | 亚洲综合天堂 | 国产精品无码成人午夜电影 | 少妇高潮无套无遮挡内谢小说 | 国产h视频在线观看 | 少妇特黄a一区二区三区 | 日日摸夜夜骑 | 少妇特黄a一区二区三区 | 成年午夜视频 | 正在播放adn156松下纱荣子 | 亚洲国产精品人人做人人爱 | 97在线免费视频观看 | 日本三级aaa| www色91| 亚洲一区 欧美 | 男人的天堂中文字幕 | 精品自拍一区 | 97视频在线看 | 国产精品无码永久免费不卡 | 新版天堂资源中文8在线 | 91丨porny丨对白| 国产女人与zoxxxx另类 | 色综合av在线 | 日韩一区二区免费看 | 中国东北少妇bbb真爽 | 国产丰满美女做爰 | 亚洲综合在线第一页 | 欧美 另类 交 | 国产全肉乱妇杂乱视频1 | 亚洲精品无码一区二区三区久久久 | 亚洲图色av | 欧美在线三级 | 新婚夫妇白天啪啪自拍 | 国产成人艳妇aa视频在线 | 久久综合日本 | 日本熟妇乱子伦xxxx | aa一级片 | 男女日批| www黄av| 国产男女猛烈无遮挡免费视频 | 欧美巨鞭大战丰满少妇 | 非洲人成免费视频 | 国产精品高潮呻吟av久久动漫 | 欧美日免费 | 国产亚洲精品久久久久5区 国产亚洲精品久久久久久 国产亚洲精品久久久久久国模美 | 国产乱人乱精一区二视频国产精品 | 亚洲成av人片在线观看天堂无码 | 哭悲在线观看免费高清恐怖片段 | 无套内谢的新婚少妇国语播放 | 女同性69囗交 | 五月激情日韩欧美啪啪婷婷 | 又黄又爽又色的免费网站 | 人人揉人人捏人人添 | 亚洲欧洲自拍 | 国产无套粉嫩白浆在线 | 综合在线播放 | 日韩欧美中文在线观看 | 日韩精品av久久有码一区浪潮 | 国产三级视频网站 | 老局长的粗大高h | 国产自产自拍 | 国产亚洲高潮精品av久久a | 亚洲色图欧美日韩 | 青青艹av| 高清欧美精品xxxxx在线看 | 久操青青| 九九久久视频 | 一级黄片一级毛片 | 成人短视频在线 | 一本到在线观看视频 | 天堂va在我观看 | 一级黄色毛片子 | 久久精品在线视频 | 好吊妞国产欧美日韩免费观看网站 | 性欧美精品高清 | 一本在线免费视频 | 欧美日韩免费观看一区=区三区 | 久久两性视频 | 免费视频成人 | 亚洲精品午夜国产va久久成人 | 在线免费观看的av | 欧美情侣性视频 | а√最新版在线天堂8 | 天堂综合网 | 亚洲综合无码一区二区三区不卡 | 好吊妞视频这里有精品 | 欧美久操 | 欧美一级片播放 | 特黄三级男人添女人下面 | 五月婷婷六月天 | 国产chinesehdxxxx麻豆网 | 操欧美美女| 欧美 日韩 国产 成人 在线 | 国产成人秘密网站视频999 | 最近中文字幕在线中文视频 | 黄色片子一级 | 欧美 国产 日本 | 国产精品久久久久久亚瑟影院 | 一级全黄色片 | 奇米影视亚洲精品一区 | √天堂资源地址在线官网 | 久久精品国产精品青草 | 欧美黄频| 明星性猛交ⅹxxx乱大交 | 狠狠精品久久久无码中文字幕 | 国产99久久久国产精品~~牛 | 国产精品一区二 | 一区二区三区四区在线观看视频 | 亚洲欧美另类久久久精品 | 中文字幕日韩国产 | 国产成人jvid在线播放 | 凸凹人妻人人澡人人添 | 成人天堂婷婷青青视频在线观看 | 欧美白丰满老太aaa片 | 国产成人精品一区二区三区福利 | 尤物久久 | 99精品视频免费 | 国产精品色哟哟 | 亚洲视频精品在线 | 欧美午夜精品久久久久久孕妇 | 国产高清黄色片 | 欧美日韩精品一区二区在线播放 | 成人一级免费视频 | 神马午夜我不卡 | 亚洲一区二区三区不卡视频 | 国产精品久久久国产盗摄 | 强壮公侵犯使我夜夜高潮 | 欧美国产激情18 | 久久精品女人天堂av麻 | 精品视频不卡 | 毛片看看 | 亚洲精品成人无码中文毛片不卡 | 91精品国产成人www | 欧美日韩一区二区三区视频播放 | 日本男女啪啪 | 久久国产精品-国产精品 | 啪啪导航 | 国产九九久久 | jizz免费在线观看 | 天天曰天天射 | 狠狠爱综合 | 国产精品大全 | tushy欧美激情在线观看 | 久久精品无码精品免费专区 | 81精品久久久久久久婷婷 | 麻豆资源| 成人福利视频网 | 久久久久久久久久久大尺度免费视频 | 欧美aa级| 欧美日韩激情在线 | 亚洲aⅴ精品一区二区三区91 | 青青草无码精品伊人久久 | 四库影院永久国产精品 | 国产亚洲成av人片在线观黄桃 | 草草视频网站 | 97综合| 久久丫精品忘忧草西安产品 | 狠狠躁夜夜躁人人躁婷婷视频 | 深夜av在线 | 久久国产这里只有精品 | 国产精品一区二区三区四 | 日韩在线中文 | 日本免费在线视频 | 无码aⅴ在线观看 | 国产又爽又猛又粗的视频a片 | 私人毛片免费高清影视院 | 欧美一级免费片 | 国产日本一级二级三级 | 美国三级日本三级久久99 | 天海翼精品久久中文字幕 | 成人久草 | 国产精品一区二区免费看 | 久久久久人妻精品一区二区三区 | 国产乱码日产乱码精品精 | 干美女少妇 | 污网站免费看 | 中国老妇荡对白正在播放 | 国产69精品久久久久999天美 | 久久伊人蜜桃av一区二区 | 国产顶级熟妇高潮xxxxx | 国产传媒一级片 | 日本熟妇乱子伦xxxx | 超碰在线观看99 | 一级大黄色片 | 少妇羞涩呻吟乳沟偷拍视频 | 国产欧美久久久精品免费 | 亚洲一线在线观看 | www国产一区二区 | 亚洲国产日韩在线视频 | 69av在线播放 | 精品久久久久久亚洲综合网 | 夜夜夜夜操 | 日本裸体丰满少妇一丝不丝 | caoporn国产免费人人 | 91av观看| 女女女女女裸体处开bbb | 全肉乱妇杂乱视频在线观看 | 九九热在线视频观看 | re久久 | 69性影院 | 青青草华人在线视频 | 99久久99久久精品免费看蜜桃 | 亚洲国产三级 | 欧美成人极品 | 国产嫖妓一区二区三区无码 | 亚洲色欲久久久综合网东京热 | 天堂网2021最新天堂手机版 | 国产亚洲精品成人av久久ww | 高清国产午夜精品久久久久久 | 久久天堂国产香蕉三区 | 欧美性色黄大片www喷水 | 久草在线成人 | 一本一道久久a久久精品 | 亚洲精品成 | 黑丝一区二区三区 | 亚洲精品色在线网站 | 四川一级毛毛片 | 国产伦子沙发午休系列资源曝光 | 激情涩涩 | 老汉老妇姓交视频 | 亚洲成人福利 | 夜夜春很很躁夜夜躁 | 青青草好吊色 | 99久久精品国产一区二区蜜芽 | 玩弄人妻少妇500系列视频 | 99久久无码一区人妻 | 成人精品一区二区三区电影 | 欧美黑人性暴力猛交喷水 | 午夜看看| 国产精品国产精品国产专区不片 | 在线视频日韩精品 | 夜夜嗨视频 | 成人亚洲一区 | 日日摸日日碰人妻无码 | 成人免费精品网站 | 狼人伊人久久 | 欧美一级爱爱 | 一本au道大尺码高清专区 | 国产福利一区二区三区视频 | 国产欧美一区二区白浆黑人 | 国产一二区在线 | 视频一二三区 | 九九精品网 | 精品久久久久久久久久中文字幕 | 国产第五页 | 欧美高潮在线 | 国产裸体歌舞一区二区 | 24小时日本在线www免费的 | 国产精品久久久久久久久久免费 | 中文资源在线播放 | 岛国大片在线免费观看 | 中国大陆毛片 | 欧美一区二区三区激情 | 毛片一毛片二毛片三国产片 | 国产亚洲天堂 | 在线日韩视频 | 成a人片亚洲日本久久 | 色性网| 好吊日免费视频 | 国产在线 | 中文 | 久久久久久99精品 | 免费观看成人羞羞视频网站观看 | 日xxxx| 一本之道高清无码视频 | 青青伊人影院 | 色哟哟精品一区二区 | 日本脱内衣全部视频 | 久久久国产精品一区二区三区 | 日本毛片在线观看 | 亚洲精品午夜无码电影网 | 夜夜欢性恔免费视频 | 怡红院a∨人人爰人人爽 | 野外性满足hd | 国产91成人 | 综合成人在线 | 强行处破女系列中文字幕 | 欧美大浪妇猛交饥渴大叫 | 青青草超碰在线 | 老女人乱淫 | 久久尤物免费一区二区三区 | 色插综合 | 高清国产午夜精品久久久久久 | 播放男人添女人下边视频 | 一本精品中文字幕在线 | 福利视频h | 又色又爽又高潮免费视频观看酒店 | 性史性dvd影片农村毛片 | xxx毛片| 精品熟女少妇av免费观看 | 亚洲综合中文 | 成人在线观 | 国产一二区三区 | 国产成a人亚洲精v品无码 | 午夜欧美激情 | 操极品少妇 | 日韩精品久久久久久久电影蜜臀 | 日本激情网址 | 好爽好黄的视频 | 无码人妻精品一区二区三18禁 | 久久精品日产第一区二区 | 中文无码精品a∨在线观看不卡 | 噼里啪啦免费观看 | yp在线观看视频网址入口 | 91精品国产综合久久婷婷香 | 九九热国产视频 | 91风间由美一区二区三区四区 | 天堂一区二区三区 | 国产夜夜爽| 久久r精品国产99久久6不卡 | 欧美国产日韩一区二区 | 欧美亚洲亚洲日韩在线影院 | 免费观看羞羞视频网站 | 免费黄色av网址 | 午夜伦理久久 | 深夜免费福利视频 | 精品久久久久久一区二区里番 | 图片区小说区另类春色 | 久草国产在线观看 | 最近中文字幕 | 久久久久久久久久一区二区三区 | 国产精品成人一区二区三区 | 成熟女人牲交片免费观看视频 | 国产精品久久久久久久影院 | 天堂综合网 | 羞羞视频在线观看 | 日韩在线免费视频观看 | 久久久久久国产精品美女 | 日本三级吃奶头添泬 | a三级黄色片 | 成人区人妻精品一区二区不卡视频 | 成人亚洲综合av天堂 | 欧洲高潮视频在线看 | 在线观看成人动漫 | 二男一女一级一片 | 国产毛片久久久久久美女视频 | 国产又粗又猛又大爽又黄 | 亚洲欧洲综合 | 麻豆一区二区三区在线观看 | 亚洲国产中文字幕在线视频综合 | 欧美精品亚洲精品日韩传电影 | 国产男女免费完整视频 | 日韩 高清 无码 人妻 | 成年人免费在线观看视频网站 | 91九色蝌蚪91por成人 | 丰满熟女人妻中文字幕免费 | 91九色porny首页最多播放 | 亚洲wwwwww| 啪啪五月天 | 亚洲女同视频 | 日日躁夜夜躁人人揉av五月天 | 亚洲天堂av片 | 亚洲精品成a人ⅴ香蕉片 | 精品人妻一区二区三区四区在线 | 人妖天堂狠狠ts人妖天堂狠狠 | 免费看片黄色 | 狠狠狠色丁香婷婷综合久久88 | 可以在线观看的av | 意大利性荡欲xxxxxx | 又大又粗又爽18禁免费看 | 91亚洲视频 | 思九九爱九九 | 亚洲精品网站在线播放gif | 色小说香蕉 | 日韩毛片免费观看 | 少妇又色又紧又大爽又刺激 | 88国产精品欧美一区二区三区 | 午夜寂寞影院在线观看 | 日本三级吃奶头添泬无码苍井空 | 欧美高清黄 | 18岁日韩内射颜射午夜久久成人 | 蜜乳av懂色av粉嫩av | 国产成人a在线观看网站站 又大又粗又爽免费视频a片 | 成人免费午夜视频69影院 | 91丨porny丨九色 | 国产午夜精品久久久久久 | www亚洲精品少妇裸乳一区二区 | 亚洲综合无码明星蕉在线视频 | 国产美女视频国产视视频 | 国产精品乱码一区二区三区 | 色情无码www视频无码区小黄鸭 | 欧美裸体按摩 | 做爰xxxⅹ性69免费视频 | 影音先锋成人网 | 亚洲精品乱码久久久久 | 911色| 欧美成人a∨高清免费观看 欧美成人aa | 丁香八月婷婷 | 91理论片 | 国产精品揄拍一区二区 | 国产又黄又爽又刺激的免费网址 | 久久综合一区二区 | 亚洲影院一区二区三区 | 久久网中文字幕日韩精品专区四季 | 狠狠干欧美 | 六月婷婷综合 | 中文字幕一级 | 成人午夜视频在线 | www色日本 | 毛片网站免费观看 | 50部乳奶水在线播放 | 天天色播 | 大乳丰满人妻中文字幕日本 | 清清草视频 | 亚洲成人黄色 | 成人免费看片网站 | 北条麻妃二三区 | 亚洲一区 国产 | 香蕉视频在线免费播放 | 国产在线你懂得 | www中文字幕在线观看 | 户外露出一区二区三区 | 久久国产精品99久久久久久老狼 | 国产精品久久久久久模特 | 国产对白叫床清晰在线播放 | 少妇太爽了太深了太硬了 | 国产精品1234| 亚洲一区二区三区写真 | a级毛片国产 | 特黄视频在线观看 | 成人av免费在线看 | 国产在线精品一区二区三区 | 国产成人小视频 | 亚洲男女 | 亚洲已满18点击进入在线看片 | 夜夜精品浪潮av一区二区三区 | 丰满多毛的大隂户毛茸茸 | 性高湖久久久久久久久aaaaa | 337p亚洲欧洲色噜噜噜 | 免费网站在线高清观看 | 精品国产一区av天美传媒 | 国产成人av大片大片在线播放 | 大地资源影视在线播放观看高清视频 | 久久尤物免费一区二区三区 | 国产人妖cd在线看网站 | 精品国产一区二区三区四区vr | 鲁鲁鲁爽爽爽在线视频观看 | 中文字幕丰满孑伦无码精品 | 欧美性生活网址 | 捏胸吃奶吻胸免费视频大软件 | 国产精品第69页 | 色哟哟国产精品 | 天天弄天天模 | 成人依人| 国精产品一区二区三区 | 国产乱子伦视频一区二区三区 | 一级做a爰黑人又硬又粗 | 国产一级视频在线播放 | 精品国产偷窥一区二区 | 日本少妇激情舌吻 | 精品黑人一区二区三区 | 在线天堂中文字幕 | 国产美女无遮挡永久免费 | 久久9国产偷伦 | 亚洲精品乱码久久久久久麻豆不卡 | 国产女人18毛片水真多 | 拍拍拍产国影院在线观看 | 亚洲国产成人一区二区精品区 | 久久依人 | 天堂av手机在线 | 关之琳三级全黄做爰在线观看 | 亚洲日韩国产成网在线观看 | 亚洲天堂网站在线 | 爱爱视频网站 | 综合久久久 | 欧美日韩欧美日韩在线观看视频 | 国产精品系列在线 | 活大器粗np高h一女多夫 | 91久久久久久久久 | 欧美性生活网址 | 波多野结衣视频免费 | 国产黄色特级片 | 热99在线视频 | chinese少妇国语对白 | 韩国精品视频在线观看 | 爱av免费| 欧美性大战xxxxx久久久 | 亚洲 另类 在线 欧美 制服 | 国产亚洲日韩av在线播放不卡 | 欧美日韩在线观看一区 | 91麻豆产精品久久久久久夏晴子 | 6080亚洲精品一区二区 | 亚洲美女黄色片 | 久久久五月天 | 国产色91| 国产农村乱对白刺激视频 | 国产正在播放 | 久久99精品国产99久久6尤物 | 国产人成 | 亚洲处破女av一区二区中文 | 国产一级精品绿帽视频 | www日韩在线 | 无码一区二区三区av免费 | 成 年 人 黄 色 大 片大 全 | 国产八十老太另类视频 | 毛片在线观看视频 | 忘忧草日本在线播放www | 国产精品88久久久久久妇女 | 亚洲一本之道高清乱码 | 国产a∨精品一区二区三区不卡 | 老熟女重囗味hdxx69 | 亚洲精品你懂的 | 最新国产精品久久精品 | 欧美日本国产欧美日本韩国99 | 国产精品久久久影视青草 | av免费网站在线观看 | 免费无码又爽又刺激高潮的视频 | 精品久久久久久久久久久久包黑料 | 亚洲h在线播放在线观看h | 中国免费毛片 | 日本成a人片在线播放 | 日韩精品高清在线 | 国产资源无限好片 | 久久久久噜噜噜亚洲熟女综合 | 无码人妻精品一区二区三区在线 | 国产熟妇勾子乱视频 | av色欲无码人妻中文字幕 | 久久人人爽人人爽人人片 | 久久成人 久久鬼色 | 五月婷影院 | 奇米影视第四狠狠777 | 欧美三根一起进三p | 色www永久免费视频 亚洲成av人在线观看天堂无码 | 无码手机线免费观看 | 欧美白人最猛性xxxxx | 久草综合在线观看 | 狠狠色综合7777久夜色撩人ⅰ | 亚洲精品乱码久久久久久久久久 | 99久久久无码国产精品6 | 中文字幕在线观看一区二区 | 国内自拍xxxx18 | 四虎网址大全 | 日韩av在线一区 | 日日噜噜夜夜狠狠久久无码区 | 国产欧美激情视频 | 韩国三级久久 | 啪啪网免费 | 成人免费黄色小视频 | 日韩欧美在线观看 | 精品国产乱码久久久久久虫虫 | 亚州中文字幕 | 国产又黄又猛又粗又爽视频 | 国产97在线视频 | 国产一区xxx | 亚洲综合成人网 | 亚洲一区 视频 | 91禁外国网站 | 国产chinesehd天美传媒 | 男人解开女人乳罩吃奶 | 日韩一级色片 | 久久久久成人精品免费播放动漫 | 曰韩人妻无码一区二区三区综合部 |