[video member=cmuratori stream_platform=twitch stream_username=handmade_hero project=code title="Fixing an Asset System Thread Bug" vod_platform=youtube id=9_jVu7RfP88 annotator=Miblo annotator=debiatan] [0:50][Two possible plans for today:] [1:01][a) Construction of sentences and paragraphs] [2:09][b) Fixing a bug. Let's fix the bug] [3:43][Explanation of the bug] [5:58][How does the bug happen and how should we fix it?] [7:53][One approach: Marking assets as used or not used] [8:29][Cons of asset locking] [9:34][Blackboard brainstorming] [10:04][In-flight asset protection] [11:13][Usage patterns of assets] [13:21][Keeping an asset usage count and its associated problems] [16:05][Introducing render_group generation IDs] [20:02][Cons of this approach: Possible wrapping of the IDs] [21:44][Maybe the wrapping is not a problem, after all] [23:14][Some other complications of this approach] [27:14][Feasibility of using generation IDs given the current state of our asset system code] [30:45][Generation IDs make MoveHeaderToFront superfluous] [32:00][Doubly-linked lists and threading don't play well] [35:58][Blackboard explanation of some problems we will encounter] [37:29][One possible solution: Queuing our MoveHeaderToFronts so that only one thread performs them] [39:02][Another solution: Lock-free heap data structure] [39:59][Yet another idea... that also poses some problems] [42:48][We could also sort the generation ID-asset pairs separately] [46:20][How about a multithreaded heap?] [48:22][Coding the "generation IDs" approach] [55:28][Updating the GenerationID] [57:24][Compressing GetBitmap and GetSound together] [1:01:50][Leaving the code in a working state (although we are still not finished)] [1:03:57][Q&A][:speech] [1:04:52][@Sharlock93][Hey Casey, can you do a 2-min recap of everything done today?] [1:07:49][@andsz_][How often do you actually implement something from a paper?] [1:08:45][@SvK151][What would be the worst case scenario if you had multiple threads trying to remove an asset? Couldn't you just wait till no thread was trying to remove the asset?] [1:09:14][@Pseudonym73][One way to avoid the lock is to split the LRU list into two parts. Keep the most recent 25% of it in one partition and the least recent 75% in another. Only move an asset to the head of the list if it's in the least recent part] [1:09:54][@JamesWidman][So IIUC, our problem is that "least recently used", in this context, means "least-recently-stopped-being-used-in-all-threads", and we can't really know that for certain without having some form of inter-thread communication.... Is that correct?] [1:10:43][Meathead protein-powder action][quote 165] [1:13:18][@Pseudonym73][You don't take the lock on hot assets most of the time] [1:14:14][@Sharlock93][I haven't seen you drink any milk this stream, is that why you are tired?!] [1:14:56][@EzyFool][You can avoid the genid gap checking list by keeping min/max/cnt rendergroup "done" ids, and freeing all assets <max when cnt = max - min, then reset min=max. Not the best if you want to free ASAP all the time. and the window gets large] [1:17:45][@EzyFool][You know the min rendergroup that completed, but like you mentioned at the start, if they complete out of order, the min isn't...] [1:18:31][@EzyFool][...correct when a gap occurs, so you need to track the interval and jump ahead when it fills. But maybe I'm just misunderstanding the situation] [1:19:40][@Vargolindo][I'm at the Day 19 video (improving audio sync) and in order to get timeBeginPeriod to work I had to call it twice. Do you have any idea why?] [1:21:07][@hitmanatee][Any update on what algorithm you are using to do laundry these days?] [1:21:50][@EzyFool][Never mind, my keyboard & my internet seem to be dying, I'll wait 'til tomorrow] [1:22:11][@Sharlock93][I think we should do a detour and make a simple ray tracer] [1:22:43][Wind it down][:speech] [/video]