0
سبد خرید شما خالیست!
میتواند برای مشاهده محصولات بیشتر به صفحات زیر بروید

حافظه رم (RAM) چیست و چه کاربردی دارد؟

حافظه‌ی رم یکی از مهم‌ترین قطعات سخت‌افزاری انواع کامپیوتر محسوب می‌شود که ساختار جالبی برای ذخیره‌سازی و مدیریت حافظه‌ی موقت دارد.

هر کامپیوتر یا دستگاه الکترونیکی از حافظه‌ی رم (RAM) بهره می‌برد. رم را می‌توان به‌صورت یکپارچه داخل پردازنده یا در برد مداری مجزا روی سیستم در نظر گرفت. به‌هرحال، کامپیوترها بدون استفاده از حافظه‌ی رم هیچ کارایی ندارند. رم یکی از شاهکارهای مهندسی محسوب می‌شود که در پایه‌‌ای‌ترین سطوح ساختاری، دستاوردهای جالبی دارد. تولید انبوه این قطعه‌ی سخت‌افزاری نیز هرسال در حجم زیادی انجام می‌شود و هر ساله هم شاهد رشد فناوری‌ها و قابلیت‌های آن هستیم. میلیاردها ترانزیستور روی ماژول رم قرار دارد؛ اما این قطعه، تنها چند وات برق مصرف می‌کند که خود دستاورد الکترونیکی جذابی محسوب می‌شود. درنهایت، همین اهمیت و ساختار جالب رم باعث می‌شود تا بررسی زیرساخت آن جذاب بشود. درادامه‌ی این مطلب زومیت، آناتومی رم را در سطوح گوناگون بررسی می‌کنیم.

کاربرد حیاتی رم

پردازنده‌ها نیاز به دسترسی سریع به داده و دستورالعمل‌های پردازشی دارند. آن‌ها برای مدیریت عملکرد نرم‌افزارها، باید به منابع مناسب دسترسی پیدا کنند. به‌علاوه، دسترسی باید به‌گونه‌ای باشد که اگر درخواست تصادفی و غیر منتظره‌ای برای دسترسی به داده ارسال شد، عملکرد کلی دچار مشکل نشود؛ به‌همین‌دلیل، رم (مخفف Random Access Mempry یا حافظه‌ی دسترسی تصادفی) اهمیت زیادی برای کامپیوتر دارد.

حافظه‌های رم به دو نوع استاتیک و داینامیک (ایستا و پویا) تقسیم می‌شوند که با نام‌های SRAM و DRAM می‌شناسیم. حافظه‌های رم ایستا فقط در داخل پردازنده‌ها (حافظه‌های کش) استفاده می‌شوند. در این مطلب، تنها حافظه‌‌های پویای DRAM را بررسی می‌کنیم. برای اولین بخش، ابتدا به این سؤال‌های حیاتی پاسخ می‌دهیم: DRAM را چگونه در کامپیوتر شخصی پیدا کنیم؟ DRAM چگونه کار می‌کند؟

حجم زیادی از حافظه‌ی رم درکنار پردازنده قرار دارد که به‌نام حافظه‌ی سیستمی (System Memory) شناخته می‌شود. البته بهتر است آن را حافظه‌ی پردازنده‌ی مرکزی یا CPU Memory بنامیم؛ چون به‌عنوان حافظه‌ی اصلی برای کار روی داده‌ها و دستورالعمل‌ها در پردازنده استفاده می‌شود.


همان‌طورکه در تصاویر ماژول رم مشاهده می‌شود، DRAM روی بردهای مداری کوچکی نصب می‌شود که هرکدام ازطریق درگاهی اختصاصی، به مادربرد کامپیوتر متصل می‌شوند. هریک از بردها به‌نام DIMM یا UDIMM شناخته می‌شوند که مخفف dual inline memory module هستند (حرف U در UDIM عبارت unbuffered را به آن اضافه می‌کند). درادامه، هریک از اصطلاح‌ها را شرح می‌دهیم. فعلا بدانید واضح‌ترین و مشخص‌ترین حافظه‌ی رم در کامپیوترهای شخصی همین ماژول‌ها هستند. حافظه‌ی رم لزوما به سرعت بسیار زیادی نیاز ندارد؛ اما کامپیوترهای شخصی مدرن امروزی برای هماهنگی و مدیریت بهتر اپلیکیشن‌های حرفه‌ای با فرایندهای پردازشی بی‌شمار، نیاز به حجم زیاد و البته سریعی از حافظه‌ی تصادفی دارند.

قطعه‌ی دیگری که نیاز به فضای حافظه‌ی زیادی دارد، کارت گرافیک است. کارت‌های گرافیک به حافظه‌ی DRAM مجزا نیازمند هستند؛ چون رندر سه‌بعدی با دسترسی و نوشتن داده‌های بی‌شمار همراه می‌شود. این نوع از DRAM برای عملکرد در شیوه‌ای تقریبا متفاوت برنامه‌ریزی می‌شود که کمی با حافظه‌ی رم سیستمی، تفاوت دارد. همان‌طورکه در تصویر زیر می‌بینید، در اطراف پردازنده‌ی گرافیکی، ۱۲ قطعه‌‌ی الکترونیکی تخت حضور دارد که همان تراشه‌های DRAM هستند. این حافظه‌ها در انواع مختلفی تولید می‌شود که می‌توان به GDDR5 و GDDR5X و GDDR6 اشاره کرد که در بخش‌های بعدی آن‌ها را شرح می‌دهیم. درنهایت، کارت‌های گرافیکی به حافظه‌ی رم زیادی به اندازه‌ی پردازنده‌ی مرکزی نیاز ندارند؛ اما آن‌ها نیز با هزاران مگابایت حافظه عرضه می‌شوند.


لزوما تمامی قطعات سخت‌افزاری کامپیوتر شخصی به حجم زیادی از حافظه‌ی رم نیاز ندارند. به‌عنوان مثال، هارد درایو با مقدار کمی رم فعالیت‌های خود را به‌خوبی انجام می‌دهد. به‌صورت میانگین، هارد درایوها از ۲۵۶ مگابایت رم بهره می‌برند که پیش از نوشتن داده روی درایو، آن‌ها را گروه‌بندی می‌کند.

در تصویر زیر، برد مداری درایو HDD را در سمت چپ و برد SSD را در سمت راست مشاهده می‌کنید. در هر دو بخش، رم با چهارگوش قرمز مشخص شده است. همان‌طورکه می‌بینید، در درایو ذخیره ‌سازی، تنها یک تراشه برای رم داریم؛ چون ۲۵۶ مگابایت نیاز به فضای زیادی ندارد و با قطعه‌ی سیلیکونی منفرد می‌توان آن را برای درایو ذخیره‌سازی تأمین کرد.


توضیحات مذکور نشان داد که هر قطعه یا لوازم جانبی با کاربردهای پردازشی به رم نیاز دارد؛ درنتیجه، در اکثر قطعات کامپیوتر شخصی می‌توان اثری از رم مشاهده کرد. به‌عنوان مثال، کنترلرهای SATA و PCI Express نیاز به تراشه‌های کوچک و محدود DRAM دارند. ابزارهای رابط شبکه و کارت‌های صوتی نیز از این قطعه بهره می‌برند. حتی پرینترها و اسکنرها هم حافظه‌ی DRAM دارند. شاید درنگاه اول، همین حقیقت که DRAM در همه‌ی قطعات قرار دارد، آن را به تجهیزی نه‌چندان جذاب تبدیل کند؛ اما وقتی به زیرساخت آن نگاه می‌کنیم، متوجه جذابیت‌های عملکردی می‌شویم.

بررسی قطعات ریز موجود در تراشه

مهندسان الکترونیک برای بررسی و تغییر عمیق در محصولات نیمه‌هادی خود، ابزارهای خاصی دارند که دردسترس نویسنده‌ی مقاله‌ی سخت‌افزاری نیست (مانند میکروسکوپ الکترونی)؛ درنتیجه نمی‌توان تراشه‌ی واقعی DRAM را شکافت و اجزای داخلی آن را به‌راحتی مشاهده کرد. به‌هرحال، برخی از کارشناسان با بهره‌برداری از همان ابزارها، تصاویر دقیق و مفیدی را از ساختار تراشه منتشر کرده‌اند.


در نگاه اولیه به ساختار سطحی تراشه‌ی رم، تصویری مشابه با مجموعه‌ای از مزرعه‌های ذرت را مشاهده می‌کنیم که با راه‌هایی به‌هم متصل شده‌اند. نکته‌ی جالب اینکه این برداشت اولیه تفاوت چندانی با عملکرد اصلی تراشه ندارد. محدوده‌هایی که در تراشه‌ی رم می‌بینید، به‌جای ذرت یا گندم عموما از دو قطعه‌ی الکترونیکی تشکیل می‌شوند: سوئیچی در فرمت MOSFET‌ (مخفف Metal Oxide Semiconductor Field-Effect Transistor) و ساختار ذخیره‌سازی که خازن شیاری فراهم می‌کند.

ترکیب دو قطعه‌ی الکترونیکی بخشی به‌نام سلول حافظه (Memory Cell) را ایجاد می‌کنند و هریک، یک بیت داده را در خود نگه می‌دارند. در نمودار زیر، تصویر کلی و ابتدایی از ساختار سلول حافظه را مشاهده می‌کنید؛ البته قطعا مهندسان الکترونیک تفسیر و نمای بهتری از آن می‌شناسند.


خطوط آبی و سبز اتصال‌هایی را نشان می‌دهند که ولتاژ را به MOSFET و خازن ارسال می‌کند. این اتصال‌ها برای نوشتن و خواندن داده در ارتباط با سلول حافظه کاربرد دارند. خط عمودی (Bit line) همیشه ابتدا فعال می‌شود. خازن شیاری رفتاری شبیه به سطل دارد که با بار الکتریکی پر می‌شود. حالت پر یا خالی بودن آن وضعیت یک بیت داده را نشان می‌دهد که صفر به‌معنای خالی‌بودن و یک به‌معنای پربودن خواهد بود. با وجود تلاش‌های بسیار مهندسان، خازن‌ها توانایی حفظ بار در طولانی‌مدت را ندارند و با گذشت زمان، خازن خالی می‌شود.

چالش یادشده بدین‌معنا خواهد بود که هر سلول حافظه باید در دوره‌ی زمانی منظم، تازه شود که عموما بازه‌ی ۱۵ تا ۳۰ بار در ثانیه خواهد بود. تمام فرایند بسیار سریع خواهد بود و در مدت چند نانوثانیه، مجموعه‌ای از سلول‌ها عملیات را انجام می‌دهند. متأسفانه تعداد زیادی سلول در هر تراشه‌ی DRAM وجود دارد و حافظه نمی‌تواند در زمان پرشدن مجدد شارژ، عملیات نوشتن یا خواندن انجام دهد. تصویر زیر، نحوه‌ی اتصال سلول‌‌های متعدد را نمایش می‌دهد.


یک سطر کامل از سلول‌های حافظه به‌نام صفحه (Page) شناخته می‌شود و طول آن‌ها در انواع رم با پیکربندی‌های متنوع تفاوت دارد. صفحه‌ی بلندتر بیت‌های بیشتری خواهد داشت؛ اما نیروی برق بیشتری هم برای مدیریت آن نیاز خواهد بود. به‌همین‌ترتیب، صفحه‌های کوچک‌تر مصرف و قابلیت ذخیره‌سازی کمتری دارند.

عامل دیگری هم در فرایند عملکردی تراشه‌‌ی رم باید در نظر گرفته شود: وقتی داده روی تراشه‌ی DRAM نوشته یا از روی آن خوانده می‌شود، اولین مرحله‌ی فرایند فعال کردن صفحه‌ی کامل خواهد بود. سطر بیت‌ها (مجموعه‌ای از صفر و یک) در بخشی به‌نام Row buffer ذخیره می‌شود که خود مجموعه‌ای از آمپلی‌فایرها و Latch هستند و درواقع، حافظه‌ی بیشتری ارائه نمی‌کنند. درنهایت، ستون مدنظر سیستم فعال می‌شود تا داده‌ی مرتبط را از بافر بخواند.

اگر صفحه‌ها بسیار کوچک باشند، هر ستون باید در دور‌‌ه‌های متناوب‌تری برای پاسخ به نیازهای داده‌ای فعال شود. درمقابل، صفحه‌ی بزر‌گ‌تر بخش‌های بیشتری را پوشش می‌دهد و در دوره‌های تناوب بزرگ‌تری فعال می‌شود. ستون‌های بزرگ نیاز به نیروی برق بیشتری دارند و پایداری کمتری هم ارائه می‌کنند؛ اما بزرگ‌تربودن صفحه‌ درنهایت مزیت محسوب می‌شود.


ترکیب‌کردن صفحه‌ها منجر به ساخت المانی به‌نام بانک (Bank) در DRAM می‌شود. شبیه به روندی که در صفحه‌ها داشتیم، ابعاد و نحوه‌ی چینش سطرها و ستون‌ها در سلول‌ها نیز اهمیت بسیاری در ظرفیت نهایی ذخیره‌ی داده در حافظه دارند. به‌علاوه، عوامل دیگر همچون سرعت و مصرف نیرو و موارد مشابه نیز تحت‌تأثیر خواهند بود.

جانمایی مرسوم در صفحه‌ها شامل ۴۰۹۶ سطر و ۴۰۹۶ ستون می‌شود؛ درنتیجه، هر بانک ظرفیت ذخیره‌سازی ۱۶،۷۷۷،۲۱۶ بیت یا دو مگابایت دارد. البته تمامی تراشه‌های DRAM از بانک با ساختار لزوما مربعی بهره نمی‌برند؛ چون طولانی‌تربودن صفحه‌ها برای آن‌ها بهتر خواهد بود. به‌عنوان مثال، جانمایی ۱۶،۳۸۴ سطر و ۱،۰۲۴ ستون هم دو مگابایت حافظه‌ی ذخیره‌سازی را به‌همراه دارد؛ اما هر صفحه چهاربرابر داده‌ی بیشتری از ساختار مربعی ذخیره می‌کند.

تمامی صفحه‌هایی که در بانک وجود دارند، با استفاده از سیستم آدرس‌دهی سطر به‌هم متصل شده‌اند و ستون‌ها نیز همین ساختار اتصالی را دارند. همه‌ی آن‌ها با سیگنال‌های کنترلی و آدرس‌هایی برای هر سطر یا ستون کنترل می‌شوند. هرچه ستون و سطرهای بیشتری در بانک وجود داشته باشد، بیت‌های زیادی برای آدرس‌دهی آن‌ها نیاز خواهد بود.

برای بانک با ساختار ۴۰۹۶ در ۴۰۹۶، هر سیستم آدرس‌دهی نیاز به ۱۲ بیت دارد؛ اما در ساختار ۱۶۳۸۴ در ۱۰۲۴، به ۱۴ بیت فضا برای آدرس‌دهی سطرها نیاز خواهد بود و ۱۰ بیت هم برای ستون‌ها استفاده می‌شود. فراموش نکنید هر دو سیستم ابعاد ۲۴ بیتی دارند.


اگر تراشه‌ی DRAM در هر رتبه یک صفحه را ارائه کند، کاربرد چندانی نخواهد داشت؛ درنتیجه، هر تراشه شامل مجموعه‌های متعدد بانک سلول حافظه‌ خواهد بود. بسته به ابعاد کلی تراشه، شاید چهار یا هشت یا شانزده بانک در آن وجود داشته باشد. مرسوم‌ترین حالت استفاده از هشت بانک است.

تمامی بانک‌ها از باس‌های داده و آدرس و فرمان مشترک استفاده می‌کنند که ساختار کلی سیستم حافظه را ساده‌تر می‌کند. زمانی‌که بانک مشغول منظم‌کردن دستورالعمل باشد، بانک‌های دیگر فعالیت‌های دیگری انجام می‌دهند. کل تراشه که شامل بانک‌ها و باس‌های متعدد می‌شود، داخل محفظه‌ی امن حفظ و درنهایت، به برد مداری اصلی لحیم می‌شود. برد مداری مسیرهای الکتریکی را دربر می‌گیرد که نیروی موردنیاز فعالیت DRAM و سیگنال‌های دستور و آدرس‌دهی و داده را جابه‌جا می‌کنند.


در تصویر بالا، تراشه‌ی DRAM را می‌بینیم که عموما به‌نام ماژول (Module) شناخته می‌شود. این عکس مربوط به محصول سامسونگ است. از تولیدکننده‌های بزرگ دیگر می‌توان توشیبا، میکرون، اس‌کی هاینیکس و نانیا را نام برد. سامسونگ اکنون بزرگ‌ترین تولید‌کننده‌ی بازار به شمار می‌رود که ۴۰ درصد از سهم بازار کل جهان را دراختیار دارد. هر تولیدکننده‌ی DRAM برای نشان‌دادن مشخصات حافظه، سیستم کدگذاری اختصاصی دارد. تراشه‌ای که در بالا می‌بینید، تراشه‌ی یک‌گیگابیتی است که هشت بانک ۱۲۸ مگابیتی دارد و در ساختاری با ۱۶،۳۸۴ سطر و ۸،۱۹۲ ستون پیکربندی شده است.

مفهوم و اهمیت رنک (Rank) در رم

شرکت‌های تولیدکننده‌ی حافظه تراشه‌های متعدد DRAM را روی برد مداری قرار می‌دهند که درنهایت، به‌نام DIMM شناخته می‌شود. D در کلمه‌ی مذکور معنای Dual یا دوگانه دارد؛ اما لزوما تمامی بردها محدود به دو تراشه نیستند. درواقع، دوال در اینجا به ارتباط‌های الکتریکی با بخش پایینی برد مرتبط می‌شود و هر دو بخش ماژول‌ها را مدیریت می‌کنند. ماژول‌های DIMM ازلحاظ ابعاد و تعداد تراشه‌های موجود با هم تفاوت دارند.


در تصویر بالا، DIMM استاندارد کامپیوتر شخصی رومیزی را مشاهده می‌کنیم و قطعه‌ی پایینی SO-DIMM (یا Small Outline DIMM) نام دارد. ماژول کوچک برای استفاده در کامپیوترهای شخصی با فرم‌فکتور کوچک‌تر مانند لپ‌تاپ یا کامپیوترهای همه‌کاره کاربر دارد. الزام تولیدکننده به جانمایی همه‌ی بخش‌ها در ابعاد کوچک‌تر تعداد تراشه‌های مورداستفاده در ماژول و سرعت اجرای وظایف و بسیاری موارد دیگر را تحت‌تأثیر قرار می‌دهد.

برای استفاده از تراشه‌‌های حافظه‌ی متعدد در DIMM، دلایل گوناگونی وجود دارد. دلیل اصلی را می‌توان در افزایش حافظه‌ی دردسترس مشاهد کرد. دلیل بعدی این است که در ساختار چندتراشه‌ای، در هر مرتبه فقط یک بانک دردسترس قرار می‌گیرد و اشغال می‌شود و سایر بانک‌ها در پس‌زمینه عملیات خود را با بهره‌وری بیشتری انجام می‌دهند. دلیل دیگر به پردازنده مرتبط می‌شود که باس آدرس‌دهی مرتبط با مدیریت حافظه در آن، عریض‌تر از باس DRAM است.

آخرین دلیلی که ذکر کردیم، اهمیت بسیار بیشتری دارد. اکثر تراشه‌های DRAM تنها باس داده‌ی هشت بیتی و پردازنده‌ی اصلی و مرکز تفاوت‌هایی جزئی با آن‌ها دارد. به‌عنوان مثال، پردازنده‌ی AMD Ryzen 7 3800X دو کنترلر ۶۴ بیتی دارد؛ درحالی‌که پردازنده‌ی گرافیکی Radeon RX 5700 XT از هشت کنترلر ۳۲ بیتی بهره می‌برد. درنتیجه، هر ماژول DIMM که در کامپیوترهای AMD نصب می‌شود، باید هشت ماژول داشته باشد (هشت ماژول ۸ بیتی برابر با ۶۴ بیت). شاید تصویر کنید کارت گرافیک AMD 5700XT از ۳۲ تراشه‌ی حافظه بهره می‌برد؛ درحالی‌که تنها هشت تراشه در آن دیده می‌شود. چرا؟ تراشه‌های حافظه که برای کارت‌های گرافیکی طراحی می‌شوند، در هر تراشه بانک‌های بیشتری دارند (عموما ۱۶ یا ۳۲ بانک)؛ چون رندر سه‌بعدی نیاز به دسترسی هم‌زمان به داده‌های بیشتری دارد.


مجموعه‌ی ماژول‌های حافظه که باس داده‌ی کنترلر حافظه را پر می‌کند، رنک (Rank) نامیده می‌شود. اتصال بیش از یک رنک به کنترلر دورازذهن نیست؛ اما کنترلر در هر مرتبه فقط توانایی استخراج داده از یک رنک را دارد؛ چون همه‌ی آن‌ها از یک باس داده‌ی مشترک استفاده می‌کنند. این مورد مشکلی ایجاد نمی‌کند؛ چون تا زمانی‌که یک رنک مشغول پاسخ‌دادن به یک دستورالعمل باشد، مجموعه‌ی از دستورهای جدید را می‌توان به رنک دیگر ارسال کرد.

ماژول‌های DIMM می‌توانند با بیش از یک رنک طراحی و ساخته شوند که خصوصا درصورت نیاز به حافظه‌ی زیاد و باتوجه‌به محدودبودن تعداد درگاه‌های رم روی مادربرد، کاربردی خواهد بود. پیکربندی‌های با رنک دوگانه یا چهارگانه بهره‌وری و قدرت بیشتری درمقایسه‌با پیکربندی‌های با رنک تکی ارائه می‌کنند. البته اضافه‌شدن رنک به‌معنای فشار بر سیستم الکتریکی هم خواهد بود. اکثر کامپیوترهای شخصی رومیزی فقط توانایی مدیریت یک یا دو رنک را در هر کنترلر دارند. اگر سیستم نیاز به ساختار رنک بیشتر داشته باشد، استفاده از DIMM با ساختار Buffered پیشنهاد می‌شود. این نوع از حافظه یک تراشه‌ی اضافه روی DIMM دارد که فشار روی سیستم را با ذخیره‌سازی دستورالعمل و داده در چند چرخه پیش از ارسال به مرحله‌ی بعد نگه‌داری می‌کند.


تمامی انواع رنک الزاما ابعاد ۶۴ بیتی ندارند. DIMMهایی که در سرورها و ورک‌استیشن‌ها استفاده می‌شوند، رنک ۷۲ بیتی دارند؛ یعنی یک ماژول DRAM اضافه روی آن‌ها وجود دارد. تراشه‌ی اضافه لزوما حافظه یا سرعت و کارایی بیشتر را به‌همراه ندارد و درعوض، برای کاربرد بررسی و اصلاح خطا (ECC) استفاده می‌شود.

همان‌طورکه گفته شد، همه‌ی انواع پردازنده برای انجام وظایف به حافظه نیاز دارند. در بخش ECC RAM، دستگاه کوچکی که همه‌ی کارها را انجام می‌دهد، ماژول اختصاصی خود را دارد. باس داده در چنین نوعی از حافظه فقط ۶۴ بیت عرض دارد؛ اما پایداری داده به میزان درخورتوجهی بهبود پیدا می‌کند. درنهایت، استفاده از بافر و ECC تنها کمی به بهبود کارایی کلی کمک می‌کند؛ اما هزینه‌ی زیادی را در پی دارد.

ساختار کلاک حافظه

تمامی حافظه‌های رم کلاک مرکزی I/O (ورودی و خروجی) دارند که به‌صورت ولتاژ با تغییر دائم بین دو سطح تعریف می‌شود. این کلاک برای سازمان‌دهی تمام فعالیت‌هایی به‌کار می‌رود که در تراشه‌ی حافظه و باس‌ها رخ می‌دهد. در سا‌ل‌های بسیار دور (۱۹۹۳)، حافظه‌هایی به‌نام SDRAM (یا Synchronous DRAM) در بازار وجود داشتند که تمامی فرایندها را با استفاده از دوره‌ی زمانی توالی می‌دادند ‌که کلاک از فاز پایین به بالا تغییر می‌‌کرد. ازآنجاکه این اتفاق بسیار سریع رخ می‌دهد، روش بسیار دقیقی برای شناسایی زمان رخ‌دادن اتفاق دراختیار قرار می‌دهد.

SDRAM‌های قدیمی کلاک‌های I/O با فرکانسی بین ۶۶ تا ۱۳۳ مگاهرتز داشتند و برای هر چرخه‌ی کلاک، دستورالعمل به DRAM ارسال می‌شد. درمقابل، تراشه می‌توانست هشت بیت داده را در همان دوره‌ی زمانی جابه‌جا کند. توسعه‌ی سریع SDRAM که با پیش‌گامی سامسونگ رخ داد، نوع جدیدی از آن‌ها را در سال ۱۹۹۸ به بازار معرفی کرد. نوع جدید انتقال داده را در اوج و فرود ولتاژ کلاک مدیریت می‌کرد؛ درنتیجه در هر چرخه‌ی کلاک، داده به‌صورت هم‌زمان دو بار ارسال و دریافت می‌شد. نام فناوری جدید Double data rate synchronous dynamic random access memory بود که به‌صورت خلاصه DDR-SDRAM یا تنها DDR خوانده می‌شد.


حافظه‌های DDR به‌سرعت به ساختار مرسوم بازار حافظه تبدیل شدند؛ درنتیجه، SDRAMهای ابتدایی به‌نام single data rate SDRAM یا SDR-DRAM شناخته می‌شدند و تا ۲۰ سال، به‌عنوان تجهیز پایه‌ای سیستم‌های کامپیوتری به‌کار می‌رفتند. پیشرفت‌هایی که در دنیای فناوری رخ داد، بهبود فناوری حافظه‌ها را هم ممکن کرد و در سال ۲۰۰۳، شاهد عرضه‌ی DDR2 بودیم. فناوری‌های بعدی به‌نام‌های DDR3 و DDR4 در سال‌‌‌های ۲۰۰۷ و ۲۰۱۲ به بازار عرضه شدند. هر به‌روزرسانی با بهره‌وری و کارایی بیشتر همراه بود؛ چون از کلاک سریع‌تری در بخش I/O بهره می‌برد. به‌علاوه، نسخه‌های جدید، سیستم‌های سیگنال‌دهی بهینه و مصرف نیروی کمتر داشتند.

فناوری DDR2 تغییری وارد دنیای رم کرد که امروزه نیز هنوز استفاده می‌شود. کلاک I/O در حافظه‌ها به سیستم جداگانه‌ای تبدیل شد که به‌نوعی خود را از دیگر ساختارهای کلاک جدا کرد و سرعتی دوبرابر آن‌ها دارد. همین ساختار را می‌توان در پردازنده‌های مرکزی تفسیر کرد که کلاک ۱۰۰ مگاهرتزی توانایی مدیریت همه‌ی رخدادها را دارد؛ اما کلاک‌‌های داخلی در پردازنده، ۳۰ تا ۴۰ برابر سریع‌تر هستند. DDR3 و DDR4 سرعت را با چهاربار اجرای چرخه در کلاک I/O افزایش دادند؛ اما در تمامی موارد، باس داده بازهم تنها از بالارفتن و پایین‌آمدن کلاک I/O برای ارسال و دریافت اطلاعات استفاده می‌کند.

تراشه‌های حافظه در سرعت‌های آن‌چنان سریعی فعالیت نمی‌کنند و درواقع، حتی سرعت نسبتا کمی دارند. نرخ جابه‌جایی داده که با معیار میلیون جابه‌جایی در ثانیه MT/s اندازه‌گیری می‌شود، در DRAMهای مدرن بسیار زیاد است؛ چون از چند بانک در هر تراشه استفاده می‌شود. اگر در هر ماژول فقط یک بانک داشتیم،‌ همه‌ی فعالیت‌ها به میزان چشمگیری کندتر می‌شد.


هر نسخه‌ی جدید از DRAM قابلیت هماهنگی با نسخه‌های قبلی را ندارد؛ درنتیجه، DIMM مورداستفاده در هر نوع اتصال‌های الکتریکی متفاوتی با انوع دیگر دارد. همچنین، درگاه‌ها و بریدگی‌ها تفاوت می‌کند تا از هرگونه اختلال سهوی همچون استفاده از حافظه‌ی DDR4 در درگاه DDR-SDRAM جلوگیری شود.


حافظه‌ی رم برای کارهای گرافیکی ابتدا به‌نام SGRAM یا synchronous graphics RAM شناخته می‌شد. آن نوع از رم نیز در سال‌های گذشته توسعه‌های متعددی تجربه کرده است. امروزه، از اصطلاح GDDR برای رم گرافیکی استفاده می‌شود تا کاربرد آن به‌خوبی در نام مشخص شود. درحال‌حاضر، GDDR نسخه‌ی ۶ در بازار وجود دارد و برای جابه‌جایی داده از سیستم نرخ داده‌ی چهارگانه استفاده می‌کند. به‌بیان‌دیگر در هر چرخه‌ی کلاک، چهارمرتبه جابه‌جایی داده رخ می‌دهد.


حافظه‌های رم در کارت گرافیک علاوه‌بر نرخ جابه‌جایی داده‌ی سریع‌تر، قابلیت‌های اضافه‌ای برای مدیریت بهتر جریان دارند. به‌عنوان مثال، در این حافظه‌ها دو صفحه به‌صورت هم‌زمان در یک بانک باز یا باس‌های آدرس و دستور در DDR اجرا می‌شوند. از قابلیت‌های دیگر می‌توان به عملکرد تراشه‌های حافظه در سرعت‌های کلاک بسیار بیشتر اشاره کرد؛ البته تمامی پیشرفت‌ها و قابلیت‌های مذکور با افزایش هزینه و گرمای تولیدشده همراه هستند.

ماژول رم GDDR6 تقریبا قیمتی دوبرابر ماژول مشابه DDR4 دارد و زمان استفاده در حداکثر سرعت واقعا گرم می‌شود؛ به‌همین‌دلیل، کارت‌های گرافیک که حافظه‌های رم با سرعت بسیار زیاد دارند، عموما مجهز به سیستم خنک‌کننده‌ی مجزای حرفه‌ای و قدرتمند نیز هستند.

مفاهیم تأثیرگذار بر سرعت

بهره‌وری و سرعت حافظه‌ی DRAM عموما با تعداد بیت‌های داده‌ای جابه‌جا شده در هر ثانیه محاسبه می‌شود. در بخش‌های قبلی مقاله، دیدیم که DDR4 به‌عنوان حافظه‌ی سیستم تراشه‌هایی با عرض هشت بیت دارد؛ درنتیجه، هر ماژول تا هشت بیت در هر چرخه‌ی کلاک داده منتقل می‌کند. اگر نرخ جابه‌جایی داده را 3200MT/s در نظر بگیریم، درمجموع ۳۲۰۰x۸=۲۶،۶۰۰ میلیون‌ بیت‌برثانیه یا کمی بیشتر از سه گیگابیت‌برثانیه سرعت داریم. ازآنجاکه اکثر ماژول‌ها از هشت تراشه استفاده می‌کنند، به سرعت حدودی ۲۵ گیگابایت‌برثانیه می‌رسیم. برای انواع GDDR6، هشت ماژول به‌معنای ۴۴۰ گیگابایت‌برثانیه خواهد بود.

اکثر افراد این مقدارِ محاسبه‌شده را پهنای باند (Bandwidth) حافظه می‌نامند که یکی از عوامل مهم در بهره‌وری و کارایی رم به‌حساب می‌آید. به‌هرحال، این مقدار کاملا تئوری است؛ چون همه‌ی رخدادها در رم لزوما هم‌زمان اتفاق نمی‌افتند. برای درک این بخش، به تصویر زیر دقت کنید که طرح کاملا ساده و البته به دور از واقعیت از اتفاق‌هایی را نشان می‌دهد که در زمان ارسال درخواست داده به حافظه رخ می‌دهند.


مرحله‌ی اول شامل فعال‌کردن صفحه در DRAM می‌شود که داده‌های مدنظر را نگه‌داری می‌کند. این مرحله ابتدا به حافظه می‌‌گوید که کدام رنک موردنیاز است و سپس ماژول مرتبط و بانک مدنظر انتخاب می‌شود. موقعیت صفحه به تراشه اعلام می‌شود و آن بخش کل صفحه را فعال می‌کند. اجرای مراحل نیاز به زمان دارد و از همه مهم‌تر برای فعال‌شدن کامل صفحه نیز به زمان نیاز داریم. فرایندها به این دلیل انجام می‌شوند که از قفل‌شدن کل سطر بیت‌ها پیش از ارائه‌ی دسترسی اطمینان حاصل شود.

پس از مراحل بالا، ستون مرتبط پیدا و اطلاعات مدنظر ارائه می‌شود. کل DRAM داده را به‌صورت یک بلوک ارائه می‌کند که در انواع امروزی، هربار ارسال بلوک هشت بیت است. درنهایت، اگر در یک چرخه‌ی کلاک یک بیت از یک ستون دریافت شود، داده‌ی مذکور تا پیش از آماده‌شدن هفت بیت دیگر، ارسال نخواهد شد. درنتیجه، اگر بیت بعدی داده از صفحه‌ی دیگر درخواست شود، صفحه‌ی باز کنونی ابتدا باید به حالت بسته برود (فرایند pre-charging) تا دراداه صفحه‌ی بعدی اجازه‌ی بازشدن پیدا کند. فرایند مذکور زمان موردنیاز را افزایش می‌دهد.

مؤلفه‌های متعدد دیگری برای بررسی وجود دارند و همه‌ی آن‌ها باید با دقت برنامه‌ریزی شوند تا DRAM در رویکردی پایدار فعالیت کند؛ رویکردی که بدون ایجاد اختلال و آسیب در داده و با بیشترین بهره‌وری ممکن رخ می‌دهد. با وجود تمام فرایندهای تأخیری که در عملکرد رم وجود دارد، دستورالعمل‌ها حتی زمانی اجرا می‌شوند ‌که رم مشغول انجام دادن کار دیگری باشد؛ به‌همین‌دلیل در قطعات پردازشی گوناگون، ماژول‌های RAM متعددی مشاهده می‌کنیم. تایمینگ‌های حافظه تنظیم‌شدنی هستند و درواقع در داخل DRAM، به‌عنوان اصلی تغییر‌ناپذیر ثبت نشده‌اند؛ چون تمامی دستورالعمل‌ها با استفاده از رم از کنترلر حافظه در پردازنده ارسال می‌شوند. تولیدکننده‌ها همه‌ی تراشه‌های تولیدی خود را آزمایش می‌کنند و آن‌هایی که در زمان مشخص به حد معمولی از سرعت برسند، با یکدیگر ترکیب و روی DIMMها نصب می‌شوند. سپس تایمینگ‌ها در تراشه‌ی کوچک روی برد اصلی نصب می‌شوند.


فرایندی که برای دسترسی و استفاده از اطلاعات بالا به‌کار می‌رود، با عنوان serial presence detect یا SPD شناخته می‌شود. این اصطلاح به‌صورت استاندارد صنعتی به BIOS امکان می‌دهد تا تنظیم‌بندی زمانی را برای انجام کارها انجام دهد. بسیاری از مادربردها به کاربر امکان می‌دهند زمان‌بندی‌ها را تغییر دهند که با هدف افزایش بهره‌وری سیستم یا پایداری پلتفرم انجام می‌شود.

همچنین، بسیاری از ماژول‌های رم از استاندارد Extreme Memory Profile یا XMP اینتل پشتیبانی می‌کنند. این استاندارد به‌نوعی اطلاعات اضافه را در SPD حافظه ذخیره می‌کند که به بایوس می‌گوید: «من می‌توانم این زمان‌بندی‌های غیراستاندارد را مدیریت کنم». درنهایت، استاندارد جدید امکان می‌دهد به‌جای ایجاد تغییر غیرالزامی در استانداردها، تنها با یک کلیک تنظیمات موردنیاز را اجرا کنید.

توضیحات مذکور جزئیات قطعه‌ی رم را در کامپیوترهای شخصی شرح دادند. اکنون که زیرساخت‌های این قطعه‌ی حساس کامپیوتری را درک کرده‌اید، تصور کنید که حافظه‌ی هشت گیگابایتی DDR4-SDRAM را در دست دارید. این حافظه از ۷۰ میلیارد خازن تشکیل می‌شود و همین تعداد هم ترانزیستور دارد. هریک از آن‌ها مقدار کمی بار الکتریکی ذخیره می‌کنند و در چند نانوثانیه می‌توان به هریک دسترسی پیدا کرد. ماژول‌‌های رم می‌توانند تعداد بسیار زیادی دستورالعمل‌را مدیریت کنند و اکثر آن‌ها درمقایسه‌با قطعات قیمت مناسب و عمر طولانی دارند.

حافظه‌های DRAM همیشه در مسیر توسعه و بهینه‌سازی قرار دارند. به‌زودی، شاهد عرضه‌ی DDR5 خواهیم بود که با ادعای پهنای باندی تقریبا برابر با دو ماژول DDR4 عرضه می‌شود. فناوری جدید قطعا قیمت گرانی خواهد داشت؛ اما مزیت‌های بی‌شماری هم برای ورک‌استیشن‌ها و سرورها به‌‌همراه دارد.