get familiar with the external C API. Don't bother with the pattern matcher though. Just the easy functions.
Check how the API is implemented internally. Only skim this to get a feeling for the code. Cross-reference to lua.h and luaconf.h as needed.
tagged values and object representation. skim through this first. you'll want to keep a window with this file open all the time.
state objects. ditto.
bytecode instruction format and opcode definitions. easy.
scroll down to luaV_execute, the main interpreter loop. see how all of the instructions are implemented. skip the details for now. reread later.
calls, stacks, exceptions, coroutines. tough read.
string interning. cute, huh?
hash tables and arrays. tricky code.
metamethod handling, reread all of lvm.c now.
surprise waiting for you. abstract interpretation is used to find object names for tracebacks. does bytecode verification, too.
recursive descent parser, targetting a register-based VM. start from chunk() and work your way through. read the expression parser and the code generator parts last.
incremental garbage collector. take your time.
Read all the other files as you see references to them. Don't let your stack get too deep though.