From what I can tell, it is technically possible and valid to send/receive a packet with a zero byte payload*, though I have no idea why anyone would try to send a packet like that.
It's possible CloudFlare does some header only communication for some reason, which doesn't require a payload. They do weird things with headers sometimes...
*I was researching this while trying to debug some Sim Broadcasts stuff
Something worth noting regarding the replay in my screenshot, that was a replay of a race I'd just been in. I don't think I'd restarted LFS in the meantime, so it may have been a download that was still stuck from the race itself.
Edit: Said race happened *before* Victor turned off CloudFlare, even if I couldn't load the replay sometime after. It's still possible that turning off CF has solved the issue.
Wild stab in the dark in case it is a CloudFlare issue - could it have been that the first time someone downloads a particular skin, CF's attempt to load and cache does something weird when someone requests the file the first time? All of the events I've been in lately will likely have had multiple brand-new skins uploaded for them.
FWIW, I'm also using the test patch, though looking at my downloads I only changed from U7 to U11 on October 3rd. I've only noticed this issue over the last few weeks, so that *may* be related, though could be a red herring. I'd previously been using U7 since ~July last year with no issues.
When I reopened it after restarting LFS, it downloaded all the skins fine, so it seems to be somewhat random.
Here are some replays with a lot of skins, all of which at least one person had trouble with when on the server. It's possible you might be able to hit the issue purely based on the number of skins.
I just had this when loading a replay (-12/8 screenshot attached).
The skins don't download over several hours; it gets stuck permanently until you close LFS from what I can tell.
It seems to be a random skin every time, restarting LFS will usually successfully download the one that was stuck, but may or may not get stuck with another.
AFAICT, when a new packet turns up, it just corrects the initial conditions for the next physics loop.
More pps should mean that the prediction error wouldn't get so large, but I don't see how it would cause more physics processing.
It could potentially even reduce the distance to other cars where physics calculations could be turned off (assuming this is already a thing), as less prediction would be needed.
Edit:
Servers' connection speeds and bandwidth limits have increased a *lot* since the current pps settings were done. There's a lot of room for improvement.
I was talking to Pete about this a couple of months ago (along with other broadcasting stuff) and did some calculations - there should be plenty of bandwidth headroom to increase both pps *and* max number of cars on track a decent amount with no issues as far as we're concerned.
Already on it. Nearly all Sim Broadcasts streams have been running early versions of my new director software (shameless plug).
There's quite a long way to go before it will be ready for a public release and it isn't yet able to do much useful when running standalone (it currently relies on other Sim Broadcasts software) but that will change in future.
We've come across this a few times, which was noticed as it caused issues with the Simbroadcasts results overlay.
If a player leaves (Shift+S or disconnect) after finishing a race, but before the IS_RES packet is sent, the PLID in IS_RES is still the old, no-longer valid, PLID.
This is presumably a bug, as the documentation in insim.txt says:
byte PLID; // player's unique id (0 = player left before result was sent)
Replay download (again, the same OEC replay as the other threads)
Compressed log: (more complete log attached)
2020-07-18 11:06:20.403 UTC Finished: PLID 5 TotalTime: 02:55:24.440 BestLap: 03:06.210 L 54 P 2 2020-07-18 11:07:44.963 UTC PlayerLeave: PLID 5 2020-07-18 11:08:54.553 UTC ResultConfirmed: PLID 5 does not exist
Another bug report based on the OEC R1 replay, as promised here. Replay download (same as other thread)
There are some cases (potentially only when a Takeover happens) where an IS_PSF (Pitstop Finished) packet is not sent.
While looking into this, I also spotted something strange and potentially related - in this specific case where IS_PSF wasn't sent, it seems an extra IS_PLA was sent. I'm not sure how often this happens; I'll have another scan of the log when I get some time.
In the log below, we have:
Cyan: A pitstop with TOC & PSF (bold) as expected. PSF STime is wrong as reported here
Green: A pitstop with TOC, but no PSF. Has an extra PLA (bold) instead.
White: A "normal" pitstop, no TOC.
More reports to follow when I'm more awake.
Text version of log if you find it helpful:
2020-07-12 22:38:16.651 UTC CSC: [excellent15] [^101 ^7R. Takahashi] STOP @ 01:05:12.550 2020-07-12 22:38:16.652 UTC Pitstop Started: [excellent15] [^101 ^7R. Takahashi] Work: 141474 2020-07-12 22:38:17.371 UTC Entered Pitlane: Fact 1 PLID 66 [excellent15] [^101 ^7R. Takahashi] 2020-07-12 22:38:27.612 UTC Entered Pitlane: Fact 1 PLID 72 [narkoze] [^134 LLM. ^7Ripe] 2020-07-12 22:38:31.252 UTC Entered Pitlane: Fact 1 PLID 53 [zapphord] [^142 ^2CR^0^v^7Eisbaer] 2020-07-12 22:38:33.452 UTC CSC: [zapphord] [^142 ^2CR^0^v^7Eisbaer] STOP @ 01:05:29.260 2020-07-12 22:38:33.453 UTC Pitstop Started: [zapphord] [^142 ^2CR^0^v^7Eisbaer] Work: 141474 2020-07-12 22:38:34.203 UTC CSC: [narkoze] [^134 LLM. ^7Ripe] STOP @ 01:05:30.210 2020-07-12 22:38:34.203 UTC Pitstop Started: [narkoze] [^134 LLM. ^7Ripe] Work: 141474 2020-07-12 22:38:35.742 UTC TOC: PLID 66; Connections: 8 [excellent15] [^101 ^7R. Takahashi] -> 18 [fastlt] [^101 ^7K. Takahashi] 2020-07-12 22:38:37.131 UTC CSC: [fastlt] [^101 ^7K. Takahashi] START @ 01:05:32.970 2020-07-12 22:38:37.132 UTC Pitstop Finished: [fastlt] [^101 ^7K. Takahashi] 00:02.050 2020-07-12 22:38:51.742 UTC Left Pitlane: PLID 66 [fastlt] [^101 ^7K. Takahashi] 2020-07-12 22:38:53.192 UTC TOC: PLID 72; Connections: 29 [narkoze] [^134 LLM. ^7Ripe] -> 31 [sobis] [^134 LLM^0.^7Sobis] 2020-07-12 22:38:53.452 UTC CSC: [sobis] [^134 LLM^0.^7Sobis] START @ 01:05:49.260 2020-07-12 22:38:55.872 UTC Missing splits: we have 0 splits, new split is: 2 2020-07-12 22:38:56.101 UTC Entered Pitlane: Fact 1 PLID 72 [sobis] [^134 LLM^0.^7Sobis] 2020-07-12 22:38:59.052 UTC CSC: [zapphord] [^142 ^2CR^0^v^7Eisbaer] START @ 01:05:54.840 2020-07-12 22:38:59.052 UTC Pitstop Finished: [zapphord] [^142 ^2CR^0^v^7Eisbaer] 00:25.580 2020-07-12 22:39:01.231 UTC Left Pitlane: PLID 72 [sobis] [^134 LLM^0.^7Sobis] 2020-07-12 22:39:04.741 UTC CSC: [lacko86] [^299 ^4LFS.HU ^7Lacko] STOP @ 01:06:00.600 2020-07-12 22:39:04.742 UTC Pitstop Started: [lacko86] [^299 ^4LFS.HU ^7Lacko] Work: 141474 2020-07-12 22:39:04.912 UTC Entered Pitlane: Fact 1 PLID 61 [lacko86] [^299 ^4LFS.HU ^7Lacko]
Can concur.
There were numerous cases of this in the first round of the current OEC series, which uses pitstop time for Balance of Performance, where knowing correct pit timing automatically is helpful.
TBH, I wouldn't hold out any hope in finding an actual VOB file that can bypass the check alone - as you said, the checks done by LFS itself should probably find any issues.
My concern is that there are tools that mess with the LFS client (or network) in some way that fools the server into thinking that the mesh is the correct one. Considering the many weird and wonderful physics hacks we've seen over the years that don't get caught by OOS checks, I'd imagine it would be (relatively speaking) trivial for similar tools to load un-fixed VOB files on the client, but just trick the server into thinking that the mesh is fine.
We know of a few tests that can be done to check whether issues are lag related or not and LFS itself is pretty good at letting us know what kind of lag issues an individual has. Typical VOB-related issues are also subtly (and sometimes not so subtly, depending on the mesh) different from lag, though it does often require specific testing that we usually don't have the luxury of doing - people don't tend to hang around once they think they've been busted breaking the rules; the number of times the problem goes away after the suspicious player "accidentally" disconnects/loses connection when questioned and returns shortly after is remarkable.
Rockstar seem to be able to get away with it to a certain extent in GTA, though most of them have a similar level of "inspiration" as some of the stock LFS cars (though Rockstar use much more blatant names).
Chinese manufacturers have been known to be sued for copying designs, however the local courts normally side with the local companies and the cases don't go anywhere. It would be very different in western courts.
Edit: See also: Nikola vs Tesla (truck design), Apple's infamous "literally nothing more than a rectangle with rounded corners" patent.
Traditionally, this has often inadvertently also affected the collision behaviour. Since we don't know how the offending VOB mods get through the detection, we have a blanket ban to be safe.
That's certainly the theory, and there were a lot that got caught by the OOS check soon after the collision mesh was added to it, however based on our (extensive) experience, it seems to be possible to get around this somehow.
There are a few things that we look out for and checks that we make that strongly indicate there is still an effect on collisions for at least some VOB mods.
There are still several other physics related hacks that seem to get past the OOS detection last I heard, so it's possible that some of the VOB related issues we have also involve .exe/memory hacks/something else to fool the OOS check.
Either way, the end result is that we still get collision-based weirdness (that's different from lag) where, more often than not, it turns out that the player involved has a VOB mod on the car they're driving (it's harder to check if they have a VOB loaded on other cars, but it causes the same issues).
We had considered lifting the TC ban on VOB mods after the OOS check was added, but it didn't sufficiently resolve the issue, so the ban remains.