北卡州立大學和英特爾公司的研究人員提出了一個方案去解決現代處理器的一個最具持久性的難題:處理器多個核心之間的通信。他們的方法是一組被稱為 Queue Management Device 或QMD的專門邏輯回路。在模擬中,處理器整合QMD后其片上網絡核心對核心的通信速度最低提升了一倍,某些情況下提升更多。
更令人稱奇的是,隨著核心數量的增加,速度提升將更為顯著。多核處理器面臨的一個問題是多個核心有時候需要同時在相同的數據上工作,它們使用鎖保護軟件隊列防止一個核心覆寫了另一個核心需要的信息,這種方法性能開銷很大,核心越多惡化更嚴重。
電機和計算機工程教授Yan Solihin和他的學生 Yipeng Wang的方法是將軟件隊列變成硬件,將三步軟件隊列操作變成三個簡單的指令:從隊列中加入數據,從隊列中減去數據,將數據放到需要的地方。