ক্যামেরা HAL3 বাফার ম্যানেজমেন্ট API

অ্যান্ড্রয়েড 10 ঐচ্ছিক ক্যামেরা HAL3 বাফার ম্যানেজমেন্ট APIগুলি প্রবর্তন করে যা আপনাকে বিভিন্ন মেমরি অর্জন করতে এবং ক্যামেরা HAL বাস্তবায়নে লেটেন্সি ট্রেডঅফগুলি ক্যাপচার করতে বাফার ম্যানেজমেন্ট লজিক প্রয়োগ করতে দেয়৷

ক্যামেরা HAL এর পাইপলাইনে সারিবদ্ধ N অনুরোধগুলি (যেখানে N পাইপলাইনের গভীরতার সমান) প্রয়োজন, তবে এটি প্রায়শই একই সময়ে আউটপুট বাফারগুলির সমস্ত N সেটের প্রয়োজন হয় না।

উদাহরণস্বরূপ, পাইপলাইনে HAL-এর আটটি অনুরোধ সারিবদ্ধ থাকতে পারে, কিন্তু পাইপলাইনের শেষ পর্যায়ে দুটি অনুরোধের জন্য শুধুমাত্র আউটপুট বাফারের প্রয়োজন। অ্যান্ড্রয়েড 9 এবং তার নিচের ডিভাইসগুলিতে, ক্যামেরা ফ্রেমওয়ার্ক বাফারগুলি বরাদ্দ করে যখন অনুরোধটি HAL-এ সারিবদ্ধ থাকে যাতে HAL-এ ছয় সেট বাফার থাকতে পারে যেগুলি ব্যবহার করা হয় না৷ অ্যান্ড্রয়েড 10-এ, ক্যামেরা HAL3 বাফার ম্যানেজমেন্ট এপিআই ছয় সেট বাফার মুক্ত করতে আউটপুট বাফারগুলির ডিকপলিং করার অনুমতি দেয়। এটি হাই-এন্ড ডিভাইসগুলিতে শত শত মেগাবাইট মেমরি সঞ্চয় করতে পারে এবং কম মেমরির ডিভাইসগুলির জন্যও উপকারী হতে পারে।

চিত্র 1 এন্ড্রয়েড 9 এবং তার নীচের সংস্করণে চলমান ডিভাইসগুলির জন্য ক্যামেরা HAL ইন্টারফেসের একটি চিত্র দেখায়৷ চিত্র 2 Android 10-এ ক্যামেরা HAL3 বাফার ম্যানেজমেন্ট এপিআই প্রয়োগ করে ক্যামেরা HAL ইন্টারফেস দেখায়।

9 বা তার কম সময়ে বাফার ব্যবস্থাপনা

চিত্র 1. অ্যান্ড্রয়েড 9 এবং তার নিচের ক্যামেরা HAL ইন্টারফেস

Android 10 এ বাফার ম্যানেজমেন্ট

চিত্র 2. বাফার ম্যানেজমেন্ট API ব্যবহার করে Android 10-এ ক্যামেরা HAL ইন্টারফেস

বাফার ব্যবস্থাপনা APIs বাস্তবায়ন

বাফার ম্যানেজমেন্ট APIs বাস্তবায়ন করতে, ক্যামেরা HAL-কে অবশ্যই:

ক্যামেরা HAL requestStreamBuffers এ রিকোয়েস্টস্ট্রীমবাফার্স এবং returnStreamBuffers পদ্ধতি ব্যবহার করে বাফার ICameraDeviceCallback.hal করার জন্য অনুরোধ করে। HAL কে অবশ্যই signalStreamFlush এ সিগন্যালস্ট্রিমফ্লাশ পদ্ধতি প্রয়োগ করতে হবে যাতে ক্যামেরা HAL কে বাফার ফেরত ICameraDeviceSession.hal জন্য সংকেত দেয়।

অনুরোধ স্ট্রিমবাফার

ক্যামেরা ফ্রেমওয়ার্ক থেকে বাফারের অনুরোধ করতে requestStreamBuffers পদ্ধতি ব্যবহার করুন। ক্যামেরা HAL3 বাফার ম্যানেজমেন্ট এপিআই ব্যবহার করার সময়, ক্যামেরা ফ্রেমওয়ার্ক থেকে ক্যাপচারের অনুরোধে আউটপুট বাফার থাকে না, অর্থাৎ StreamBuffer bufferId ক্ষেত্রটি হল 0 । অতএব, ক্যামেরা ফ্রেমওয়ার্ক থেকে বাফারের অনুরোধ করতে ক্যামেরা HAL-কে অবশ্যই requestStreamBuffers ব্যবহার করতে হবে।

requestStreamBuffers পদ্ধতি কলকারীকে একক কলে একাধিক আউটপুট স্ট্রীম থেকে একাধিক বাফারের অনুরোধ করতে দেয়, কম HIDL IPC কলের অনুমতি দেয়। যাইহোক, একই সময়ে আরও বাফারের অনুরোধ করা হলে কলগুলি আরও বেশি সময় নেয় এবং এটি মোট অনুরোধ-থেকে-ফলাফল লেটেন্সিকে নেতিবাচকভাবে প্রভাবিত করতে পারে। এছাড়াও, যেহেতু রিকোয়েস্টস্ট্রীমবাফারে কলগুলি ক্যামেরা পরিষেবাতে সিরিয়ালাইজ করা হয়, তাই requestStreamBuffers অনুরোধ করার জন্য ক্যামেরা HAL একটি ডেডিকেটেড উচ্চ-প্রধান থ্রেড ব্যবহার করার পরামর্শ দেওয়া হয়।

যদি একটি বাফার অনুরোধ ব্যর্থ হয়, ক্যামেরা HAL অবশ্যই অপ্রত্যাশিত ত্রুটিগুলি সঠিকভাবে পরিচালনা করতে সক্ষম হবে। নিম্নলিখিত তালিকাটি সাধারণ কারণগুলি বর্ণনা করে যেগুলি বাফার অনুরোধগুলি ব্যর্থ হয় এবং কীভাবে সেগুলি ক্যামেরা HAL দ্বারা পরিচালনা করা উচিত৷

  • অ্যাপটি আউটপুট স্ট্রীম থেকে সংযোগ বিচ্ছিন্ন করে: এটি একটি মারাত্মক ত্রুটি। একটি সংযোগ বিচ্ছিন্ন স্ট্রীম লক্ষ্য করে যে কোনো ক্যাপচার অনুরোধের জন্য ক্যামেরা HAL কে ERROR_REQUEST পাঠাতে হবে এবং পরবর্তী অনুরোধগুলি সাধারণত প্রক্রিয়া করার জন্য প্রস্তুত থাকতে হবে।
  • সময়সীমা: এটি ঘটতে পারে যখন কোনো অ্যাপ কিছু বাফার ধরে রেখে নিবিড় প্রক্রিয়াকরণে ব্যস্ত থাকে। ক্যামেরা HAL কে ক্যাপচারের অনুরোধের জন্য ERROR_REQUEST পাঠাতে হবে যা একটি টাইমআউট ত্রুটির কারণে পূরণ করা যাবে না এবং পরবর্তী অনুরোধগুলি স্বাভাবিকভাবে প্রক্রিয়া করার জন্য প্রস্তুত থাকতে হবে।
  • ক্যামেরা ফ্রেমওয়ার্ক একটি নতুন স্ট্রিম কনফিগারেশন প্রস্তুত করছে: রিকোয়েস্টস্ট্রিমবাফারকে আবার কল করার আগে ক্যামেরা HAL-এর পরবর্তী configureStreams requestStreamBuffers কল সম্পূর্ণ না হওয়া পর্যন্ত অপেক্ষা করা উচিত।
  • ক্যামেরা HAL তার বাফার সীমাতে পৌঁছেছে ( maxBuffers ক্ষেত্র): ক্যামেরা HAL-এর অপেক্ষা করা উচিত যতক্ষণ না এটি স্ট্রিমের অন্তত একটি বাফার ফেরত না আসা পর্যন্ত অনুরোধ requestStreamBuffers আবার কল করার আগে।

রিটার্ন স্ট্রিমবাফার

ক্যামেরা ফ্রেমওয়ার্কে অতিরিক্ত বাফার ফেরত দিতে returnStreamBuffers পদ্ধতি ব্যবহার করুন। ক্যামেরা HAL সাধারণত processCaptureResult পদ্ধতির মাধ্যমে ক্যামেরা ফ্রেমওয়ার্কে বাফার ফেরত দেয়, কিন্তু এটি শুধুমাত্র ক্যামেরা HAL-এ পাঠানো ক্যাপচার অনুরোধের জন্য অ্যাকাউন্ট করতে পারে। requestStreamBuffers পদ্ধতির সাহায্যে, ক্যামেরা HAL বাস্তবায়নের জন্য ক্যামেরা ফ্রেমওয়ার্কের অনুরোধের চেয়ে বেশি বাফার ধরে রাখা সম্ভব। এটি হল যখন returnStreamBuffers পদ্ধতি ব্যবহার করা উচিত। যদি HAL বাস্তবায়নে অনুরোধের চেয়ে বেশি বাফার না থাকে তবে ক্যামেরা HAL বাস্তবায়নের জন্য returnStreamBuffers পদ্ধতিতে কল করার প্রয়োজন নেই।

সিগন্যালস্ট্রিমফ্লাশ

signalStreamFlush পদ্ধতিটি ক্যামেরা ফ্রেমওয়ার্ক দ্বারা ফোন করা হয় যাতে ক্যামেরা HAL কে সমস্ত বাফার ফেরত দেওয়ার জন্য অবহিত করা হয়। এটি সাধারণত বলা হয় যখন ক্যামেরা ফ্রেমওয়ার্ক configureStreams স্ট্রীমসকে কল করতে চলেছে এবং অবশ্যই ক্যামেরা ক্যাপচার পাইপলাইন ড্রেন করতে হবে। returnStreamBuffers পদ্ধতির মতো, যদি একটি ক্যামেরা HAL বাস্তবায়ন অনুরোধের চেয়ে বেশি বাফার না রাখে, তাহলে এই পদ্ধতির একটি খালি বাস্তবায়ন করা সম্ভব।

ক্যামেরা ফ্রেমওয়ার্ক সিগন্যালস্ট্রিমফ্লাশকে কল করার পরে, সমস্ত বাফার ক্যামেরা ফ্রেমওয়ার্কে ফিরে না আসা পর্যন্ত ফ্রেমওয়ার্ক ক্যামেরা signalStreamFlush নতুন ক্যাপচার অনুরোধ পাঠানো বন্ধ করে দেয়। যখন সমস্ত বাফার ফেরত দেওয়া হয়, requestStreamBuffers পদ্ধতির কলগুলি ব্যর্থ হয় এবং ক্যামেরা ফ্রেমওয়ার্ক একটি পরিষ্কার অবস্থায় তার কাজ চালিয়ে যেতে পারে। ক্যামেরা ফ্রেমওয়ার্ক তখন configureStreams স্ট্রীমস বা processCaptureRequest পদ্ধতিতে কল করে। ক্যামেরা ফ্রেমওয়ার্ক configureStreams পদ্ধতিতে কল করলে, configureStreams কল সফলভাবে ফিরে আসার পরে ক্যামেরা HAL আবার বাফারের অনুরোধ করা শুরু করতে পারে। যদি ক্যামেরা ফ্রেমওয়ার্ক processCaptureRequest পদ্ধতিতে কল করে, ক্যামেরা HAL processCaptureRequest কল চলাকালীন বাফারের অনুরোধ করা শুরু করতে পারে।

signalStreamFlush পদ্ধতি এবং flush পদ্ধতির জন্য শব্দার্থবিদ্যা আলাদা। যখন flush পদ্ধতি বলা হয়, HAL যত তাড়াতাড়ি সম্ভব পাইপলাইন নিষ্কাশনের জন্য ERROR_REQUEST এর সাথে মুলতুবি থাকা ক্যাপচার অনুরোধগুলি বাতিল করতে পারে। যখন signalStreamFlush পদ্ধতিটি কল করা হয়, তখন HAL কে অবশ্যই সমস্ত মুলতুবি থাকা ক্যাপচার অনুরোধগুলি স্বাভাবিকভাবে শেষ করতে হবে এবং ক্যামেরা ফ্রেমওয়ার্কে সমস্ত বাফার ফিরিয়ে দিতে হবে।

সিগন্যালস্ট্রিমফ্লাশ পদ্ধতি এবং অন্যান্য পদ্ধতির মধ্যে আরেকটি পার্থক্য হল যে signalStreamFlush হল একটি একমুখী signalStreamFlush পদ্ধতি, যার মানে হল HAL signalStreamFlush কল পাওয়ার আগে ক্যামেরা ফ্রেমওয়ার্ক অন্যান্য ব্লকিং APIগুলিতে কল করতে পারে। এর মানে হল যে signalStreamFlush পদ্ধতি এবং অন্যান্য পদ্ধতিগুলি (বিশেষত configureStreams স্ট্রীমস পদ্ধতি) ক্যামেরা ফ্রেমওয়ার্কে যে ক্রমটি বলা হয়েছিল তার চেয়ে ভিন্ন ক্রমে ক্যামেরা HAL-এ পৌঁছাতে পারে৷ এই অ্যাসিঙ্ক্রোনি সমস্যাটি সমাধান করার জন্য, streamConfigCounter ক্ষেত্রটি স্ট্রিম কনফিগারেশনে যুক্ত করা StreamConfiguration এবং signalStreamFlush পদ্ধতিতে একটি যুক্তি হিসাবে যুক্ত করা হয়েছিল। একটি সিগন্যালস্ট্রিমফ্লাশ কল তার সংশ্লিষ্ট configureStreams signalStreamFlush কলের চেয়ে পরে আসে কিনা তা নির্ধারণ করতে ক্যামেরা HAL বাস্তবায়নের streamConfigCounter আর্গুমেন্ট ব্যবহার করা উচিত। একটি উদাহরণের জন্য চিত্র 3 দেখুন।

দেরিতে আসা কলগুলি পরিচালনা করা

চিত্র 3. ক্যামেরা HAL কীভাবে দেরিতে আসা সিগন্যালস্ট্রিমফ্লাশ কলগুলি সনাক্ত এবং পরিচালনা করবে

বাফার ম্যানেজমেন্ট এপিআই প্রয়োগ করার সময় আচরণ পরিবর্তন হয়

বাফার ম্যানেজমেন্ট লজিক বাস্তবায়নের জন্য বাফার ম্যানেজমেন্ট API ব্যবহার করার সময়, ক্যামেরা এবং ক্যামেরা HAL বাস্তবায়নে নিম্নলিখিত সম্ভাব্য আচরণ পরিবর্তনগুলি বিবেচনা করুন:

  • ক্যামেরা HAL-এ ক্যাপচারের অনুরোধগুলি দ্রুত এবং আরও ঘন ঘন আসে: বাফার ম্যানেজমেন্ট API ছাড়া, ক্যামেরা HAL-এ ক্যাপচার অনুরোধ পাঠানোর আগে ক্যামেরা ফ্রেমওয়ার্ক প্রতিটি ক্যাপচার অনুরোধের জন্য আউটপুট বাফারের অনুরোধ করে। বাফার ম্যানেজমেন্ট এপিআই ব্যবহার করার সময়, ক্যামেরা ফ্রেমওয়ার্ককে আর বাফারের জন্য অপেক্ষা করতে হবে না এবং তাই আগে ক্যামেরা HAL কে ক্যাপচারের অনুরোধ পাঠাতে পারে।

    এছাড়াও, বাফার ম্যানেজমেন্ট API ছাড়া, ক্যামেরা ফ্রেমওয়ার্ক ক্যাপচার অনুরোধ পাঠানো বন্ধ করে দেয় যদি ক্যাপচার অনুরোধের আউটপুট স্ট্রীমগুলির মধ্যে একটি HAL এক সময়ে ধরে রাখতে পারে এমন বাফারগুলির সর্বাধিক সংখ্যায় পৌঁছে যায় (এই মানটি ক্যামেরা HAL দ্বারা নির্ধারিত হয় HalStream::maxBuffers ফিল্ড একটি configureStreams কলের রিটার্ন মানের মধ্যে)। বাফার ম্যানেজমেন্ট API-এর সাথে, এই থ্রোটলিং আচরণটি আর বিদ্যমান নেই এবং HAL-এর কাছে অনেকগুলি ক্যাপচার অনুরোধ সারিবদ্ধ থাকলে ক্যামেরা HAL বাস্তবায়ন processCaptureRequest রিকোয়েস্ট কলগুলি গ্রহণ করবে না।

  • requestStreamBuffers কল লেটেন্সি উল্লেখযোগ্যভাবে পরিবর্তিত হয়: একটি requestStreamBuffers কল গড়ের চেয়ে বেশি সময় নিতে পারে এমন অনেক কারণ রয়েছে। উদাহরণ স্বরূপ:

    • একটি নতুন তৈরি স্ট্রিমের প্রথম কয়েকটি বাফারের জন্য, কলগুলি বেশি সময় নিতে পারে কারণ ডিভাইসটিকে মেমরি বরাদ্দ করতে হবে৷
    • প্রতিটি কলে অনুরোধ করা বাফারের সংখ্যার অনুপাতে প্রত্যাশিত লেটেন্সি বৃদ্ধি পায়।
    • অ্যাপটি বাফার ধরে আছে এবং প্রক্রিয়াকরণে ব্যস্ত। এটি বাফারের অভাব বা ব্যস্ত CPU এর কারণে বাফার অনুরোধগুলিকে ধীর করতে বা টাইমআউটকে আঘাত করতে পারে।

বাফার ব্যবস্থাপনা কৌশল

বাফার ম্যানেজমেন্ট এপিআই বিভিন্ন ধরনের বাফার ম্যানেজমেন্ট কৌশল বাস্তবায়নের অনুমতি দেয়। কিছু উদাহরণ হল:

  • ব্যাকওয়ার্ড সামঞ্জস্যপূর্ণ: HAL processCaptureRequest রিকোয়েস্ট কলের সময় একটি ক্যাপচার অনুরোধের জন্য বাফারের অনুরোধ করে। এই কৌশলটি কোনো মেমরি সঞ্চয় প্রদান করে না, তবে বাফার ম্যানেজমেন্ট API-এর প্রথম বাস্তবায়ন হিসাবে কাজ করতে পারে, বিদ্যমান ক্যামেরা HAL-তে খুব কম কোড পরিবর্তনের প্রয়োজন।
  • সর্বাধিক মেমরি সঞ্চয়: ক্যামেরা HAL শুধুমাত্র একটি পূরণ করার আগে অবিলম্বে আউটপুট বাফারের অনুরোধ করে। এই কৌশলটি সর্বাধিক মেমরি সঞ্চয় করার অনুমতি দেয়। সম্ভাব্য নেতিবাচক দিক হল আরও ক্যামেরা পাইপলাইন জ্যাঙ্ক যখন বাফার অনুরোধগুলি শেষ হতে অস্বাভাবিকভাবে দীর্ঘ সময় নেয়।
  • ক্যাশে: ক্যামেরা HAL কয়েকটি বাফার ক্যাশে করে যাতে এটি মাঝে মাঝে ধীরগতির বাফার অনুরোধ দ্বারা প্রভাবিত হওয়ার সম্ভাবনা কম থাকে।

ক্যামেরা HAL বিশেষ ব্যবহারের ক্ষেত্রে বিভিন্ন কৌশল অবলম্বন করতে পারে, উদাহরণস্বরূপ, প্রচুর মেমরি ব্যবহার করে এমন ব্যবহারের ক্ষেত্রে সর্বাধিক মেমরি সংরক্ষণের কৌশল ব্যবহার করা এবং অন্যান্য ব্যবহারের ক্ষেত্রে ব্যাকওয়ার্ড-সামঞ্জস্যপূর্ণ কৌশল ব্যবহার করা।

বহিরাগত ক্যামেরা HAL-এ নমুনা বাস্তবায়ন

বাহ্যিক ক্যামেরা এইচএএল অ্যান্ড্রয়েড 9 এ চালু করা হয়েছিল এবং hardware/interfaces/camera/device/3.5/ এ সোর্স ট্রিতে পাওয়া যাবে। অ্যান্ড্রয়েড 10-এ, এটিকে ExternalCameraDeviceSession.cpp .cpp অন্তর্ভুক্ত করার জন্য আপডেট করা হয়েছে, যা বাফার ম্যানেজমেন্ট API-এর একটি বাস্তবায়ন। এই বাহ্যিক ক্যামেরা HAL C++ কোডের কয়েকশ লাইনে বাফার ম্যানেজমেন্ট কৌশলগুলিতে উল্লিখিত সর্বাধিক মেমরি সঞ্চয় কৌশল প্রয়োগ করে।