• Log InLog In
  • Register
Liquid`
Team Liquid Liquipedia
EDT 12:01
CET 17:01
KST 01:01
  • Home
  • Forum
  • Calendar
  • Streams
  • Liquipedia
  • Features
  • Store
  • EPT
  • TL+
  • StarCraft 2
  • Brood War
  • Smash
  • Heroes
  • Counter-Strike
  • Overwatch
  • Liquibet
  • Fantasy StarCraft
  • TLPD
  • StarCraft 2
  • Brood War
  • Blogs
Forum Sidebar
Events/Features
News
Featured News
Intel X Team Liquid Seoul event: Showmatches and Meet the Pros7[ASL20] Finals Preview: Arrival13TL.net Map Contest #21: Voting10[ASL20] Ro4 Preview: Descent11Team TLMC #5: Winners Announced!3
Community News
Weekly Cups (Oct 20-26): MaxPax, Clem, Creator win52025 RSL Offline Finals Dates + Ticket Sales!10BSL21 Open Qualifiers Week & CONFIRM PARTICIPATION1Crank Gathers Season 2: SC II Pro Teams10Merivale 8 Open - LAN - Stellar Fest4
StarCraft 2
General
RotterdaM "Serral is the GOAT, and it's not close" Intel X Team Liquid Seoul event: Showmatches and Meet the Pros Weekly Cups (Oct 20-26): MaxPax, Clem, Creator win Weekly Cups (Oct 13-19): Clem Goes for Four DreamHack Open 2013 revealed
Tourneys
2025 RSL Offline Finals Dates + Ticket Sales! SC4ALL $6,000 Open LAN in Philadelphia Merivale 8 Open - LAN - Stellar Fest Crank Gathers Season 2: SC II Pro Teams $5,000+ WardiTV 2025 Championship
Strategy
Custom Maps
Map Editor closed ?
External Content
Mutation # 497 Battle Haredened Mutation # 496 Endless Infection Mutation # 495 Rest In Peace Mutation # 494 Unstable Environment
Brood War
General
SnOw's ASL S20 Finals Review BW General Discussion [ASL20] Ask the mapmakers — Drop your questions BGH Auto Balance -> http://bghmmr.eu/ Ladder Map Matchup Stats
Tourneys
[ASL20] Grand Finals Small VOD Thread 2.0 The Casual Games of the Week Thread BSL21 Open Qualifiers Week & CONFIRM PARTICIPATION
Strategy
How to stay on top of macro? Current Meta PvZ map balance Soma's 9 hatch build from ASL Game 2
Other Games
General Games
General RTS Discussion Thread Path of Exile Stormgate/Frost Giant Megathread Nintendo Switch Thread Dawn of War IV
Dota 2
Official 'what is Dota anymore' discussion LiquidDota to reintegrate into TL.net
League of Legends
Heroes of the Storm
Simple Questions, Simple Answers Heroes of the Storm 2.0
Hearthstone
Deck construction bug Heroes of StarCraft mini-set
TL Mafia
TL Mafia Community Thread SPIRED by.ASL Mafia {211640}
Community
General
US Politics Mega-thread Russo-Ukrainian War Thread Things Aren’t Peaceful in Palestine The Big Programming Thread YouTube Thread
Fan Clubs
White-Ra Fan Club The herO Fan Club!
Media & Entertainment
[Manga] One Piece Anime Discussion Thread Movie Discussion! Korean Music Discussion Series you have seen recently...
Sports
MLB/Baseball 2023 2024 - 2026 Football Thread Formula 1 Discussion TeamLiquid Health and Fitness Initiative For 2023 NBA General Discussion
World Cup 2022
Tech Support
SC2 Client Relocalization [Change SC2 Language] Linksys AE2500 USB WIFI keeps disconnecting Computer Build, Upgrade & Buying Resource Thread
TL Community
The Automated Ban List Recent Gifted Posts
Blogs
Career Paths and Skills for …
TrAiDoS
KPDH "Golden" as Squid Game…
Peanutsc
Reality "theory" prov…
perfectspheres
Customize Sidebar...

Website Feedback

Closed Threads



Active: 1461 users

Who the hell coded 1.16? - Page 3

Blogs > R1CH
Post a Reply
Prev 1 2 3 4 5 6 7 8 Next All
funkie
Profile Blog Joined November 2005
Venezuela9376 Posts
December 16 2008 15:04 GMT
#41
On December 16 2008 23:01 tec27 wrote:
I'm pretty sure whoever programmed that part of the patch jsut rolled some dice to pick the sleeping time. That's how all the good programmers do it, anyhow

Also, the reason its probably taking so long for 1.16.1 is that they are actually putting it through its QA paces this time, unlike last time Can't release two crappy patches in a row (or can they?)



Heh, well, Blizzard has never ceased to amaze me, so What do you know ;D:
CJ Entusman #6! · Strength is the basis of athletic ability. -Rippetoe /* http://j.mp/TL-App <- TL iPhone App 2.0! */
FreeZEternal
Profile Joined January 2003
Korea (South)3396 Posts
December 16 2008 15:18 GMT
#42
well, obviously this was not tested in QA before pushing it live. At least this is just a game, same thing happened in the place I work, Production went down for half a day...do you know how much money is that? lol
miseiler
Profile Blog Joined October 2008
United States1389 Posts
December 16 2008 17:07 GMT
#43
I can't believe how straightforward this is. And like someone mentioned earlier in the thread, it seems exactly like something I would do as well, having zero experience in real time programming.

I'll bet a 1 ms delay never occurred to him/her, either.

Thought process:
"Huh. CPU overloaded. What happens if I introduce a 5 ms delay here?"
"Nice! It worked! I told my boss it'd take a week, so I think I'll get paid to play the D3 beta for a while."
"Jinro soo manly wearing only a T-Shirt while the Koreans freeze in their jackets" -- Double_O
"He's from Sweden, man. We have to fight polar bears on our way to school." -- Yusername
Disastorm
Profile Joined January 2008
United States922 Posts
Last Edited: 2008-12-16 17:17:29
December 16 2008 17:14 GMT
#44
so wait i dont understand. why did the devs put a random 10 msecond delay loop in the middle of their code? was that their solution to removing the 100% cpu usage? so if i understand correctly, their code is less efficient than CPU Savior which only adds 1 msecond delay?
"Don't worry so much man. There won't be any more zergs left to QQ. Lots of QQ about TvT is incoming though I bet." - Vrok 9/21/10
Scorch
Profile Blog Joined March 2008
Austria3371 Posts
Last Edited: 2008-12-16 17:23:12
December 16 2008 17:22 GMT
#45
On December 17 2008 02:14 Disastorm wrote:
so wait i dont understand. why did the devs put a random 10 msecond delay loop in the middle of their code? was that their solution to removing the 100% cpu usage? so if i understand correctly, their code is less efficient than CPU Savior which only adds 1 msecond delay?

I don't know any specifics, but my guess is that stuff is ten times as responsive if the sleep lasts only 1ms instead of 10ms. No sleeping at all results in busy waiting and thus 100% load.
MasterOfChaos
Profile Blog Joined April 2007
Germany2896 Posts
December 16 2008 17:52 GMT
#46
Things are not that simple. The delay passed to sleep is a minimum delay. The function only returns at the next tick after the minimum delay has elapsed. On my comp the tick occurs every 16ms, on older comps/OS that interval can be up to 55ms.
The tick interval can be changed by a program at global level, affecting the whole system. Afaik CPU-Savior does that.
The mistakes blizzard made are not that noobish as some of you thought. The early CPU-Savior versions had similar problems. And the ingame lag does not occur on every comp (or atleast some people like me don't notice it).
The main problem is that it passed QA(or was not send to QA at all).
The /r bug is a real wtf on the other hand.
LiquipediaOne eye to kill. Two eyes to live.
Ki_Do
Profile Blog Joined July 2008
Korea (South)981 Posts
Last Edited: 2008-12-16 18:32:20
December 16 2008 18:31 GMT
#47
noobish or not
rich/you and not blizzard programmers fixed many of problems like this.
maybe you and him could be hired too,bet u would be successful breaking sc2 engine
I've got a point, and i'm ready to kill or die for it.
Equinox_kr
Profile Blog Joined December 2006
United States7395 Posts
December 16 2008 19:11 GMT
#48
R1CH BRINGING DOWN THE PAIN
^-^
Night[Mare
Profile Blog Joined December 2004
Mexico4793 Posts
December 16 2008 19:21 GMT
#49
wow rich i hope i'll be as good programmer as you someday :D
Teamliquidian townie
floor exercise
Profile Blog Joined August 2008
Canada5847 Posts
December 16 2008 19:23 GMT
#50
I understand how this could happen when CPU savior did the same thing. I even understand not having a ton of testing go into these patches since SC is really old and frankly for it to be updated at all anymore is surprising. What I don't like is that this patch has been out for how long now? There was feedback about how awful 1.16 runs on some peoples computers hours after the patch was released. There's even detailed explanations why from people like r1ch, so why has there not been a followup patch yet to fix this?
Not_Computer
Profile Blog Joined January 2007
Canada2277 Posts
December 16 2008 19:27 GMT
#51
R1CH is amazing :o
"Jaedong hyung better be ready. I'm going to order the most expensive dinner in Korea."
ZergZoul
Profile Joined April 2007
Mexico408 Posts
Last Edited: 2008-12-16 19:44:24
December 16 2008 19:44 GMT
#52
R1CH can see the matrix code... He Is The One!
Racenilatr
Profile Blog Joined August 2008
United States2756 Posts
December 16 2008 19:55 GMT
#53
lol I love ur language R1ch! It actually makes sense to me....but even if i tried i would never be able to apply it :D Still all very reasonable though and its easy to follow on.
BloodyC0bbler
Profile Blog Joined September 2004
Canada7876 Posts
December 16 2008 20:36 GMT
#54
R1ch, single handedly bitch slapping the man with each failed if statement
#3 Member of the Chill Fanclub / Rhaegar fought nobly. Rhaegar fought valiantly. Rhaegar fought honorably. And Rhaeger died. --Ser Jorah Mormont TL MAFIA FORUM http://www.teamliquid.net/forum/index.php?show_part=31 go go !
Bill307
Profile Blog Joined October 2002
Canada9103 Posts
Last Edited: 2008-12-16 20:50:27
December 16 2008 20:41 GMT
#55
On December 17 2008 02:52 MasterOfChaos wrote:
Things are not that simple. The delay passed to sleep is a minimum delay. The function only returns at the next tick after the minimum delay has elapsed. On my comp the tick occurs every 16ms, on older comps/OS that interval can be up to 55ms.
The tick interval can be changed by a program at global level, affecting the whole system. Afaik CPU-Savior does that.
The mistakes blizzard made are not that noobish as some of you thought. The early CPU-Savior versions had similar problems. And the ingame lag does not occur on every comp (or atleast some people like me don't notice it).
The main problem is that it passed QA(or was not send to QA at all).
The /r bug is a real wtf on the other hand.

The other main problem with this bug is that the programmer did not contact the developers of CPU-Savior to ask them how they implemented it and what kinds of problems they ran into during testing.

Whether this was the fault of the programmer for being ignorant or naive, or the fault of a ridiculous non-disclosure agreement that prohibited him from asking such a harmless question, we'll never know.


As for the /r bug, QA definitely deserves major blame for that one regardless of how WTF-ish the implementation was. Honestly, whoever was responsible for testing that feature is a mediocre tester at best, definitely not the kind of guy you'd expect to be working for Blizzard. A message like ".r test" should have been an obvious test case and it takes about 2 seconds to verify it.
b3h47pte
Profile Blog Joined May 2007
United States1317 Posts
December 16 2008 22:47 GMT
#56
On December 16 2008 20:06 freelander wrote:
thx for the explanation.
this is my 3rd semester studying c++, i am making (lame) games with SDL, so i am interested in this stuff where is the good places in the game loop to put delays.
i have learnt some microcontroller programming meanwhile so I can understand some part of the assembly

i will check out this ollydbg stuff, I haven't heard about it yet but sounds great


if you're focused on making games, Assembly probably isn't THAT relevant to what you want to do. Assembly is probalby only helpful if you plan on making anti-hacks or something of that sort.
GearitUP
Profile Joined November 2008
United States337 Posts
December 16 2008 23:51 GMT
#57
Awesome discovery, I been wondering why these problems were occuring however I have to agree with

On December 16 2008 19:23 Plexa wrote:
First step in making SC obsolete in preparation for SC2


i believe this is true :/
Own<Owned<Ownt<Pwn<Pwned<PwnT< YOU NEWB!
Ganfei
Profile Blog Joined August 2008
Taiwan1439 Posts
December 17 2008 00:07 GMT
#58
well if iccup adds that 3v3 ladder then screw bnet, don't need it for anything anymore
You are crushing me like a cheese sandwich
CharlieMurphy
Profile Blog Joined March 2006
United States22895 Posts
Last Edited: 2008-12-17 00:21:16
December 17 2008 00:20 GMT
#59
Yea, they really have a tester problem. I bet they don't even test it properly. Guy probably just makes the code and makes sure it works then passes it up (without checking for side effects).

They really need to consult outside programmers like MoC, Tec27(the adv loader guy, sorry i forget ur name :/), and you r1ch.

I was just discussing this with EchoOfRain on bnet yesterday. He said that they changed the ports or something too? I don't think he was right.
..and then I would, ya know, check em'. (Aka SpoR)
R1CH
Profile Blog Joined May 2007
Netherlands10341 Posts
December 17 2008 00:25 GMT
#60
On December 17 2008 02:52 MasterOfChaos wrote:
Things are not that simple. The delay passed to sleep is a minimum delay. The function only returns at the next tick after the minimum delay has elapsed. On my comp the tick occurs every 16ms, on older comps/OS that interval can be up to 55ms.

This too was another wtf, they added sleeps without setting the timer resolution to 1ms! So every Sleep could be up to 16ms, however as my test program I posted on my previous blog showed, most people have high timer resolutions to begin with.
AdministratorTwitter: @R1CH_TL
Prev 1 2 3 4 5 6 7 8 Next All
Please log in or register to reply.
Live Events Refresh
Epic.LAN
13:00
Epic.LAN 46 Group Stage
Liquipedia
CrankTV Team League
13:00
Playoffs: Bo13
BASILISK vs Team LiquidLIVE!
LiquipediaDiscussion
WardiTV Invitational
12:15
Playoffs
MaNa vs Gerald
Rogue vs GuMiho
TBD vs Solar
WardiTV1049
TKL 245
IndyStarCraft 169
Rex115
LiquipediaDiscussion
[ Submit Event ]
Live Streams
Refresh
StarCraft 2
RotterdaM 314
TKL 245
IndyStarCraft 169
LamboSC2 145
Rex 115
UpATreeSC 1
StarCraft: Brood War
Calm 4965
Hyuk 2895
Bisu 1720
Mini 1049
Flash 928
Shuttle 590
firebathero 301
actioN 225
Sea.KH 67
Mong 67
[ Show more ]
sas.Sziky 59
Soulkey 42
yabsab 28
JulyZerg 24
Free 18
Shine 14
soO 13
Sacsri 12
HiyA 10
Dota 2
Gorgc6799
qojqva3058
Dendi1005
syndereN296
420jenkins290
XcaliburYe207
canceldota19
Counter-Strike
fl0m2244
oskar113
Heroes of the Storm
Khaldor150
Other Games
B2W.Neo796
DeMusliM391
crisheroes334
Lowko316
Hui .268
Sick157
KnowMe150
Fuzer 102
QueenE52
nookyyy 45
Organizations
Counter-Strike
PGL14444
StarCraft 2
Blizzard YouTube
StarCraft: Brood War
BSLTrovo
sctven
[ Show 14 non-featured ]
StarCraft 2
• StrangeGG 67
• AfreecaTV YouTube
• intothetv
• Kozan
• IndyKCrew
• LaughNgamezSOOP
• Migwel
• sooper7s
StarCraft: Brood War
• BSLYoutube
• STPLYoutube
• ZZZeroYoutube
League of Legends
• TFBlade999
• Shiphtur479
Other Games
• WagamamaTV146
Upcoming Events
Replay Cast
6h 59m
Epic.LAN
19h 59m
BSL Team A[vengers]
21h 59m
Dewalt vs Shine
UltrA vs ZeLoT
LAN Event
21h 59m
BSL 21
1d 2h
BSL Team A[vengers]
1d 21h
Cross vs Motive
Sziky vs HiyA
LAN Event
1d 22h
BSL 21
2 days
Replay Cast
2 days
Wardi Open
2 days
[ Show More ]
Monday Night Weeklies
3 days
Replay Cast
3 days
Sparkling Tuna Cup
3 days
Replay Cast
4 days
The PondCast
5 days
Liquipedia Results

Completed

CSL 2025 AUTUMN (S18)
WardiTV TLMC #15
Eternal Conflict S1

Ongoing

BSL 21 Points
BSL 21 Team A
C-Race Season 1
IPSL Winter 2025-26
KCM Race Survival 2025 Season 4
SOOP Univ League 2025
CranK Gathers Season 2: SC II Pro Teams
PGL Masters Bucharest 2025
Thunderpick World Champ.
CS Asia Championships 2025
ESL Pro League S22
StarSeries Fall 2025
FISSURE Playground #2
BLAST Open Fall 2025
BLAST Open Fall Qual
Esports World Cup 2025

Upcoming

SC4ALL: Brood War
YSL S2
BSL Season 21
SLON Tour Season 2
BSL 21 Non-Korean Championship
RSL Offline Finals
WardiTV 2025
RSL Revival: Season 3
Stellar Fest
SC4ALL: StarCraft II
META Madness #9
BLAST Bounty Winter 2026: Closed Qualifier
eXTREMESLAND 2025
ESL Impact League Season 8
SL Budapest Major 2025
BLAST Rivals Fall 2025
IEM Chengdu 2025
TLPD

1. ByuN
2. TY
3. Dark
4. Solar
5. Stats
6. Nerchio
7. sOs
8. soO
9. INnoVation
10. Elazer
1. Rain
2. Flash
3. EffOrt
4. Last
5. Bisu
6. Soulkey
7. Mini
8. Sharp
Sidebar Settings...

Advertising | Privacy Policy | Terms Of Use | Contact Us

Original banner artwork: Jim Warren
The contents of this webpage are copyright © 2025 TLnet. All Rights Reserved.