Zynq.TestEnetMT.Mod 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373
  1. MODULE Test;
  2. IMPORT
  3. SYSTEM, Trace := EnetTrace, Platform, Kernel, Machine, EnetTiming, EnetBase, Enet, EmacPs7 := EnetEmacPs7, Objects, EnetArp, EnetIcmp, EnetUdp, Commands, EnetUtils, Interfaces := EnetInterfaces;
  4. TYPE
  5. Int16 = EnetBase.Int16;
  6. Int32 = EnetBase.Int32;
  7. Int = EnetBase.Int;
  8. UnalignedInt32 = EnetUtils.UnalignedInt32;
  9. CONST
  10. IntfMacAddr = "00:0A:35:00:01:02";
  11. IntfIpAddr = "10.3.34.8";
  12. IntfGateway = "0.0.0.0";
  13. IntfSubnetMask = "255.255.255.0";
  14. LocalUdpPort = 65534;
  15. VAR
  16. intf: Enet.Interface;
  17. udpSocket: EnetUdp.Socket;
  18. recvCounter: Int;
  19. data: ARRAY 1470 OF CHAR;
  20. lockIntfs: BOOLEAN;
  21. PROCEDURE Start*;
  22. VAR res: Int;
  23. BEGIN
  24. recvCounter := 0;
  25. ASSERT(Interfaces.Start(intf,res));
  26. END Start;
  27. PROCEDURE Stop*;
  28. VAR res: Int;
  29. BEGIN
  30. ASSERT(Interfaces.Stop(intf,res));
  31. END Stop;
  32. PROCEDURE Reset*;
  33. VAR res: Int;
  34. BEGIN
  35. ASSERT(Interfaces.Reset(intf,res));
  36. END Reset;
  37. PROCEDURE ShowArpCache*;
  38. BEGIN
  39. EnetArp.ShowArpCache(intf.ipv4AddrCache(EnetArp.ArpCache));
  40. END ShowArpCache;
  41. PROCEDURE ShowRecvCounter*;
  42. BEGIN
  43. Trace.StringLn("recvCounter=" & recvCounter);
  44. END ShowRecvCounter;
  45. PROCEDURE SendPackets1*(context: Commands.Context);
  46. VAR
  47. i, n: LONGINT;
  48. ipAddr: EnetBase.IpAddr;
  49. res: Int;
  50. t: EnetTiming.Time;
  51. BEGIN
  52. ASSERT(context.arg.GetInteger(n,FALSE));
  53. FOR i := 0 TO LEN(data)-1 DO
  54. data[i] := CHR(i+1);
  55. END;
  56. Trace.StringLn("sending " & n & " UDP datagrams...");
  57. Trace.RefTimestamp(0);
  58. WHILE (n > 0) & EnetUdp.Send(udpSocket,data,0,LEN(data),{},NIL,res) DO
  59. DEC(n);
  60. END;
  61. Trace.Timestamp(0,"sending time: ");
  62. IF n = 0 THEN
  63. Trace.StringLn("all UDP datagrams have been sent");
  64. ELSE
  65. Trace.StringLn("a failure to send UDP datagram, res=" & res & ", number of remained datagrams to send is" & n);
  66. END;
  67. END SendPackets1;
  68. PROCEDURE SendPackets2*(context: Commands.Context);
  69. VAR
  70. i, n: LONGINT;
  71. ipAddr: EnetBase.IpAddr;
  72. res: Int;
  73. t: EnetTiming.Time;
  74. BEGIN
  75. ASSERT(context.arg.GetInteger(n,FALSE));
  76. FOR i := 0 TO LEN(data)-1 DO
  77. data[i] := CHR(i+1);
  78. END;
  79. Trace.StringLn("sending " & n & " UDP datagrams...");
  80. Trace.RefTimestamp(0);
  81. WHILE (n > 0) & EnetUdp.Send(udpSocket,data,0,LEN(data),{EnetBase.FlagNoDataCopy},NIL,res) DO
  82. DEC(n);
  83. END;
  84. Trace.Timestamp(0,"sending time: ");
  85. IF n = 0 THEN
  86. Trace.StringLn("all UDP datagrams have been sent");
  87. ELSE
  88. Trace.StringLn("a failure to send UDP datagram, res=" & res & ", number of remained datagrams to send is" & n);
  89. END;
  90. END SendPackets2;
  91. PROCEDURE SendPackets3*(context: Commands.Context);
  92. VAR
  93. i, n: LONGINT;
  94. ipAddr: EnetBase.IpAddr;
  95. res: Int;
  96. t: EnetTiming.Time;
  97. BEGIN
  98. ASSERT(context.arg.GetInteger(n,FALSE));
  99. FOR i := 0 TO LEN(data)-1 DO
  100. data[i] := CHR(i+1);
  101. END;
  102. Trace.StringLn("sending " & n & " UDP datagrams...");
  103. Trace.RefTimestamp(0);
  104. WHILE (n > 0) & EnetUdp.Send(udpSocket,data,0,LEN(data),{EnetBase.FlagNoDataCopy,EnetBase.FlagNoFlushDCache},NIL,res) DO
  105. DEC(n);
  106. END;
  107. Trace.Timestamp(0,"sending time: ");
  108. IF n = 0 THEN
  109. Trace.StringLn("all UDP datagrams have been sent");
  110. ELSE
  111. Trace.StringLn("a failure to send UDP datagram, res=" & res & ", number of remained datagrams to send is" & n);
  112. END;
  113. END SendPackets3;
  114. VAR
  115. setUdpDestTaskCompleted: BOOLEAN;
  116. PROCEDURE SetUdpDestTaskHandler(completionHandler: EnetBase.TaskHandler);
  117. BEGIN{EXCLUSIVE}
  118. setUdpDestTaskCompleted := TRUE;
  119. END SetUdpDestTaskHandler;
  120. (**
  121. Setup UDP socket destination
  122. Syntax:
  123. SetUdpDest dstIpAddr dstPort ~
  124. *)
  125. PROCEDURE SetUdpDest*(context: Commands.Context);
  126. VAR
  127. strDstIpAddr: ARRAY 16 OF CHAR;
  128. dstPort: Int;
  129. dstIpAddr: EnetBase.IpAddr;
  130. completionHandler: EnetBase.TaskHandler;
  131. res: Int;
  132. BEGIN
  133. IF ~context.arg.GetString(strDstIpAddr) OR ~context.arg.GetInteger(dstPort,FALSE) THEN
  134. context.result := 1;
  135. context.error.String("destination IP address and destination port number are expected!"); context.error.Ln;
  136. RETURN;
  137. END;
  138. IF ~EnetBase.StrToIpAddr(strDstIpAddr,dstIpAddr) THEN
  139. context.result := 1;
  140. context.error.String("destination IP address string has invalid format!"); context.error.Ln;
  141. RETURN;
  142. END;
  143. NEW(completionHandler);
  144. completionHandler.handle := SetUdpDestTaskHandler;
  145. setUdpDestTaskCompleted := FALSE;
  146. IF ~EnetUdp.SetDestination(udpSocket,dstIpAddr,dstPort,completionHandler,res) THEN
  147. context.result := res;
  148. context.error.String("failed to setup image streaming destination!"); context.error.Ln;
  149. RETURN;
  150. END;
  151. IF res = EnetBase.OpInProgress THEN
  152. BEGIN{EXCLUSIVE}
  153. AWAIT(setUdpDestTaskCompleted);
  154. END;
  155. IF completionHandler.res # 0 THEN
  156. context.result := completionHandler.res;
  157. context.error.String("failed to setup image streaming destination!"); context.error.Ln;
  158. RETURN;
  159. END;
  160. ELSIF res # 0 THEN
  161. context.result := res;
  162. context.error.String("failed to setup image streaming destination!"); context.error.Ln;
  163. END;
  164. context.result := 0;
  165. context.out.String("Ok"); context.out.Ln;
  166. END SetUdpDest;
  167. PROCEDURE Test*;
  168. VAR
  169. t: EnetTiming.Time;
  170. x16, y16: Int16;
  171. x32, y32: Int32;
  172. u32: EnetUtils.UnalignedInt32;
  173. BEGIN
  174. x16 := Int16(0x1234);
  175. t := EnetTiming.getTimeCounter();
  176. y16 := EnetUtils.SwitchEndianness16(x16);
  177. t := EnetTiming.getTimeCounter() - t;
  178. Trace.StringLn("SwitchEndianness16: " & t);
  179. Trace.StringLn("y16=0x" & Trace.Hx(y16,4));
  180. x32 := Int32(0x12345678);
  181. t := EnetTiming.getTimeCounter();
  182. y32 := EnetUtils.SwitchEndianness32(x32);
  183. t := EnetTiming.getTimeCounter() - t;
  184. Trace.StringLn("SwitchEndianness32: " & t);
  185. Trace.StringLn("y32=0x" & Trace.Hx(y32,8));
  186. t := EnetTiming.getTimeCounter();
  187. u32 := x32;
  188. t := EnetTiming.getTimeCounter() - t;
  189. Trace.StringLn("u32 := x32: " & t);
  190. Trace.StringLn("u32=0x" & Trace.Hx(u32[3],2) & Trace.Hx(u32[2],2) & Trace.Hx(u32[1],2) & Trace.Hx(u32[0],2));
  191. x32 := 0;
  192. t := EnetTiming.getTimeCounter();
  193. x32 := u32;
  194. t := EnetTiming.getTimeCounter() - t;
  195. Trace.StringLn("x32 := u32: " & t);
  196. Trace.StringLn("x32=0x" & Trace.Hx(x32,8));
  197. END Test;
  198. PROCEDURE Print *;
  199. VAR
  200. str: ARRAY 128 OF CHAR;
  201. BEGIN
  202. IF EnetBase.IpAddrToStr(intf.ipv4Addr, str) THEN
  203. Trace.StringLn(str)
  204. ELSE
  205. Trace.StringLn("ERROR: could not translate IP address")
  206. END
  207. END Print;
  208. PROCEDURE UdpRecvHandler(
  209. socket: EnetUdp.Socket;
  210. CONST srcAddr: EnetBase.IpAddr;
  211. srcPort: EnetBase.Int;
  212. VAR data: ARRAY OF CHAR;
  213. dataOffs, dataLen: EnetBase.Int;
  214. packet: EnetBase.Packet
  215. );
  216. VAR res: Int;
  217. BEGIN
  218. INC(recvCounter);
  219. (*
  220. socket.sendToIpAddr := srcAddr;
  221. socket.sendToPort := srcPort;
  222. socket.sendToMacAddr := packet.ethFrameHdr.srcMacAddr;
  223. socket.intf := packet.intf;
  224. IF ~EnetUdp.Send(socket,data,dataOffs,dataLen,{},opRes) THEN
  225. Trace.StringLn("failed to send a UDP datagram, res=" & opRes.res);
  226. END;
  227. *)
  228. (*
  229. IF ~EnetBase.ReplyUdp(packet.intf,packet,{},NIL,res) THEN
  230. Trace.StringLn("failed to reply to a UDP datagram, res=" & res);
  231. END;
  232. *)
  233. (*
  234. Trace.StringLn("received a datagram, srcIpAddr=0x" & Trace.Hx(srcAddr.addr[0],8) & ", srcPort=0x" & Trace.Hx(srcPort,4) & ", dataLen=" & dataLen);
  235. WHILE dataLen > 0 DO
  236. Trace.String(Trace.Hx(ORD(data[dataOffs]),2) & " ");
  237. i := (i+1) MOD 8;
  238. IF i = 0 THEN Trace.StringLn(""); END;
  239. INC(dataOffs);
  240. DEC(dataLen);
  241. END;
  242. Trace.StringLn("");
  243. (*
  244. runner.socket.sendToIpAddr.addr[0] := packet.ipv4Hdr.srcIpAddr;
  245. runner.socket.sendToIpAddr.isIpv4 := TRUE;
  246. runner.socket.sendToMacAddr := packet.ethFrameHdr.srcMacAddr;
  247. runner.socket.sendToPort := EnetBase.SwitchEndianness16(packet.udpHdr.srcPort);
  248. *)
  249. *)
  250. END UdpRecvHandler;
  251. PROCEDURE InitMod;
  252. VAR
  253. res: LONGINT;
  254. dev: EnetBase.LinkDevice;
  255. macAddr: EnetBase.MacAddr;
  256. ipAddr, gateway, subnetMask: EnetBase.IpAddr;
  257. BEGIN
  258. (* initialize the interface *)
  259. ASSERT(EmacPs7.GetDevice(0,2048,2048,8192,8192,dev,res));
  260. NEW(intf,dev,res); ASSERT(res = 0);
  261. (* setup link layer of the interface *)
  262. ASSERT(EnetBase.StrToMacAddr(IntfMacAddr,macAddr));
  263. ASSERT(Interfaces.SetMacAddr(intf,macAddr,res));
  264. ASSERT(Interfaces.SetLinkSpeed(intf,"Auto",TRUE,res));
  265. (* setup IP configuration of the interface *)
  266. ASSERT(EnetBase.StrToIpAddr(IntfIpAddr,ipAddr));
  267. ASSERT(EnetBase.StrToIpAddr(IntfSubnetMask,subnetMask));
  268. ASSERT(EnetBase.StrToIpAddr(IntfGateway,gateway));
  269. ASSERT(Interfaces.SetIpConfig(intf,ipAddr,subnetMask,gateway,res));
  270. ASSERT(Interfaces.Add(intf,res));
  271. (* create a UDP socket *)
  272. ASSERT(EnetUdp.NewSocket(udpSocket,LocalUdpPort,res));
  273. ASSERT(EnetUdp.SetRecvHandler(udpSocket,UdpRecvHandler,res));
  274. END InitMod;
  275. BEGIN
  276. InitMod;
  277. END Test.
  278. (* KRM *)
  279. FSTools.CreateFile -c -r Replacements.tmp
  280. BootConfig.UartInputClockHz = 100000000;
  281. BootConfig.KernelOutputUart = 0;
  282. BootConfig.CpuNb = 2;
  283. EnetBase.ThreadSafe = TRUE;
  284. Enet.UseSpinLocks = TRUE;
  285. ~
  286. (* ZYBO & ZedBoard *)
  287. FSTools.CreateFile -c -r Replacements.tmp
  288. BootConfig.UartInputClockHz = 50000000;
  289. BootConfig.KernelOutputUart = 1;
  290. BootConfig.CpuNb = 1;
  291. EnetBase.ThreadSafe = TRUE;
  292. Enet.UseSpinLocks = TRUE;
  293. EnetEmacPs7.AllowZeroPhyAddr = [TRUE,TRUE];
  294. ~
  295. SystemTools.DoCommands
  296. FSTools.Unsafe ~
  297. FSTools.DeleteFiles "*.Gof" "*.Sym" ~
  298. FSTools.Safe ~
  299. ~
  300. SystemTools.DoCommands
  301. Release.Build -b -f=ARM.Release.Tool -o='--replacements=Replacements.tmp --noInitLocals --traceModule=Trace' --only="Kernel" ZynqA2 ~
  302. Release.Build -b -f=ARM.Release.Tool -o='--replacements=Replacements.tmp --traceModule=Trace' --only="System Enet Shell" ZynqA2 ~
  303. Compiler.Compile -b=ARM --traceModule=Trace --replacements=Replacements.tmp
  304. ENET:Zynq.TestEnetMT.Mod
  305. ~
  306. ~
  307. Release.Build -l -f=ARM.Release.Tool --only="Kernel System Enet Shell" ZynqA2 ~
  308. FSTools.CloseFiles Test.bin ~
  309. FoxARMInstructionSet.Disassemble Test.bin -a=19cc8cH ~