VSync সংকেত ডিসপ্লে পাইপলাইনকে সিঙ্ক্রোনাইজ করে। ডিসপ্লে পাইপলাইনে অ্যাপ রেন্ডারিং, সারফেসফ্লিংগার কম্পোজিশন এবং হার্ডওয়্যার কম্পোজার (HWC) ডিসপ্লেতে ছবি উপস্থাপন করে। VSync রেন্ডারিং শুরু করার জন্য অ্যাপের জেগে ওঠার সময়, স্ক্রিনকে কম্পোজিট করার জন্য সারফেসফ্লিঙ্গার জেগে ওঠার সময় এবং ডিসপ্লে রিফ্রেশ চক্রকে সিঙ্ক্রোনাইজ করে। এই সিঙ্ক্রোনাইজেশন তোতলামি দূর করে এবং গ্রাফিক্সের ভিজ্যুয়াল কর্মক্ষমতা উন্নত করে।
HWC VSync ইভেন্ট তৈরি করে এবং ইভেন্টগুলিকে কলব্যাকের মাধ্যমে SurfaceFlinger-এ পাঠায়:
typedef void (*HWC2_PFN_VSYNC)(hwc2_callback_data_t callbackData, hwc2_display_t display, int64_t timestamp);
সারফেসফ্লিংগার setVsyncEnabled
এ কল করে HWC VSync ইভেন্ট তৈরি করে কিনা তা নিয়ন্ত্রণ করে। SurfaceFlinger VSync ইভেন্ট তৈরি করতে setVsyncEnabled
সক্ষম করে যাতে এটি প্রদর্শনের রিফ্রেশ চক্রের সাথে সিঙ্ক্রোনাইজ করতে পারে। যখন SurfaceFlinger ডিসপ্লে রিফ্রেশ চক্রের সাথে সিঙ্ক্রোনাইজ করা হয়, তখন SurfaceFlinger HWC-কে VSync ইভেন্ট তৈরি করা থেকে থামাতে setVsyncEnabled
অক্ষম করে। যদি SurfaceFlinger প্রকৃত VSync এবং VSync-এর মধ্যে একটি পার্থক্য সনাক্ত করে তবে এটি পূর্বে প্রতিষ্ঠিত SurfaceFlinger VSync ইভেন্ট জেনারেশন পুনরায় সক্ষম করে।
VSync অফসেট
সিঙ্ক অ্যাপ এবং SurfaceFlinger হার্ডওয়্যার VSync-এ লুপ রেন্ডার করে। একটি VSync ইভেন্টে, ডিসপ্লে ফ্রেম N দেখাতে শুরু করে যখন SurfaceFlinger ফ্রেম N+1 এর জন্য উইন্ডো কম্পোজ করা শুরু করে। অ্যাপটি মুলতুবি থাকা ইনপুট পরিচালনা করে এবং ফ্রেম N+2 তৈরি করে।
VSync-এর সাথে সিঙ্ক্রোনাইজ করা ধারাবাহিক লেটেন্সি প্রদান করে। এটি অ্যাপস এবং সারফেসফ্লিংগারে ত্রুটি কমায় এবং একে অপরের সাথে ফেজের মধ্যে এবং বাইরে প্রবাহিত হওয়া ডিসপ্লে কমিয়ে দেয়। এটি অনুমান করে যে অ্যাপ এবং SurfaceFlinger প্রতি-ফ্রেম সময় ব্যাপকভাবে পরিবর্তিত হয় না। লেটেন্সি কমপক্ষে দুটি ফ্রেমের।
এর প্রতিকারের জন্য, আপনি হার্ডওয়্যার VSync-এর সাপেক্ষে অ্যাপ এবং কম্পোজিশন সিগন্যাল তৈরি করে ইনপুট-টু-ডিসপ্লে লেটেন্সি কমাতে VSync অফসেট ব্যবহার করতে পারেন। এটি সম্ভব কারণ অ্যাপ প্লাস কম্পোজিশনে সাধারণত 33 ms-এর কম সময় লাগে।
একটি VSync অফসেটের ফলাফল একই সময়কাল এবং অফসেট ফেজ সহ তিনটি সংকেত:
-
HW_VSYNC_0
— ডিসপ্লে পরবর্তী ফ্রেম দেখাতে শুরু করে। -
VSYNC
— অ্যাপ ইনপুট পড়ে এবং পরবর্তী ফ্রেম তৈরি করে। -
SF_VSYNC
— SurfaceFlinger পরবর্তী ফ্রেমের জন্য কম্পোজিটিং শুরু করে৷
VSync অফসেটগুলির সাথে, SurfaceFlinger বাফারটি গ্রহণ করে এবং ফ্রেমটিকে সংমিশ্রণ করে যখন অ্যাপটি একই সাথে ইনপুট প্রক্রিয়া করে এবং ফ্রেমটিকে রেন্ডার করে।
DispSync
DispSync একটি প্রদর্শনের পর্যায়ক্রমিক হার্ডওয়্যার-ভিত্তিক VSync ইভেন্টগুলির একটি মডেল বজায় রাখে এবং হার্ডওয়্যার VSync ইভেন্ট থেকে নির্দিষ্ট ফেজ অফসেটে কলব্যাকগুলি চালানোর জন্য সেই মডেলটি ব্যবহার করে।
DispSync হল একটি সফ্টওয়্যার ফেজ-লক লুপ (PLL) যা কোরিওগ্রাফার এবং সারফেসফ্লিংগার দ্বারা ব্যবহৃত VSYNC
এবং SF_VSYNC
সংকেতগুলি তৈরি করে, এমনকি হার্ডওয়্যার VSync থেকে অফসেট না হলেও৷
DispSync প্রবাহটি নিম্নলিখিত চিত্রে চিত্রিত করা হয়েছে:

চিত্র 1. DispSync প্রবাহ।
DispSync এর নিম্নলিখিত গুণাবলী রয়েছে:
- রেফারেন্স —
HW_VSYNC_0
। - আউটপুট —
VSYNC
এবংSF_VSYNC
। - প্রতিক্রিয়া — HWC থেকে রিটায়ার ফেন্স সিগন্যাল টাইমস্ট্যাম্প।
VSync রিটায়ার অফসেট
অবসরের বেড়ার সিগন্যাল টাইমস্ট্যাম্প অবশ্যই HW VSync-এর সাথে মেলে, এমনকি এমন ডিভাইসেও যা অফসেট ফেজ ব্যবহার করে না। অন্যথায়, ত্রুটিগুলি তাদের চেয়ে আরও গুরুতর বলে মনে হচ্ছে। স্মার্ট প্যানেলে প্রায়শই একটি ডেল্টা থাকে যেখানে মেমরি প্রদর্শনের জন্য অবসরের বেড়াটি সরাসরি মেমরি অ্যাক্সেস (DMA) এর শেষ, কিন্তু প্রকৃত প্রদর্শন সুইচ এবং HW VSync কিছু সময় পরে।
PRESENT_TIME_OFFSET_FROM_VSYNC_NS
ডিভাইসের BoardConfig.mk
মেকফাইলে সেট করা আছে। এটি ডিসপ্লে কন্ট্রোলার এবং প্যানেলের বৈশিষ্ট্যের উপর ভিত্তি করে। অবসরের বেড়া টাইমস্ট্যাম্প থেকে HW VSync সংকেত পর্যন্ত সময় ন্যানোসেকেন্ডে পরিমাপ করা হয়।
VSYNC এবং SF_VSYNC অফসেট
VSYNC_EVENT_PHASE_OFFSET_NS
এবং SF_VSYNC_EVENT_PHASE_OFFSET_NS
উচ্চ-লোড ব্যবহারের ক্ষেত্রে রক্ষণশীলভাবে সেট করা হয়েছে, যেমন উইন্ডো ট্রানজিশনের সময় আংশিক GPU কম্পোজিশন বা অ্যানিমেশন ধারণকারী ওয়েব পৃষ্ঠার মাধ্যমে Chrome স্ক্রোল করা। এই অফসেটগুলি দীর্ঘ অ্যাপ রেন্ডার টাইম এবং দীর্ঘ GPU কম্পোজিশন সময়ের জন্য অনুমতি দেয়।
এক বা দুই মিলিসেকেন্ডের বেশি লেটেন্সি লক্ষণীয়। উল্লেখযোগ্যভাবে ত্রুটির সংখ্যা বৃদ্ধি না করে বিলম্ব কমাতে, সম্পূর্ণ স্বয়ংক্রিয় ত্রুটি পরীক্ষা সংহত করুন।