A 500MHz multi-banked compilable DRAM macro with direct write and programmable pipelining | IEEE Conference Publication | IEEE Xplore