Android 13 বা উচ্চতর সংস্করণে চলমান ডিভাইসগুলির জন্য, Android eUICC-এর জন্য একাধিক সক্রিয় প্রোফাইল (MEPs) সমর্থন করে। এই বৈশিষ্ট্যটি ডিভাইসগুলিকে একটি একক eSIM চিপ ব্যবহার করে ডুয়াল সিম সমর্থন করার অনুমতি দেয়, যার একাধিক সিম প্রোফাইল থাকতে পারে এবং একই সময়ে দুটি ভিন্ন ক্যারিয়ারের সাথে সংযোগ করতে পারে। ডিভাইস নির্মাতাদের অবশ্যই তাদের ডিভাইসে এই বৈশিষ্ট্যটি সংহত করতে SoC বিক্রেতা এবং eSIM চিপসেট বিক্রেতাদের সাথে কাজ করতে হবে।
পটভূমি
অ্যান্ড্রয়েড 12 এবং তার চেয়ে কম সংস্করণে চলমান ডিভাইসগুলিতে, AOSP একটি একক eSIM একই সময়ে একাধিক প্রোফাইল সমর্থন করার জন্য সীমিত সমর্থন প্রদান করে। eSIM অফার করে উল্লেখযোগ্য স্থান এবং খরচ সাশ্রয় সত্ত্বেও, ডুয়াল সিম সমর্থনের এই অভাব ডিভাইস নির্মাতাদের শুধুমাত্র eSIM ডিভাইসগুলি গ্রহণ করতে বাধা দেয়। শুধুমাত্র eSIM-এর ডিভাইসে ডুয়াল সিম সমর্থন প্রদান করতে, ডিভাইস নির্মাতাদের ডিভাইসে দুটি eSIM উপাদান প্যাক করতে হবে, যা উপাদানের বিল (BOM) খরচ বাড়ায় এবং সাবস্ক্রিপশন পরিচালনার জন্য খারাপ ব্যবহারকারীর অভিজ্ঞতার দিকে পরিচালিত করে। অ্যান্ড্রয়েড 13 থেকে AOSP-এ উপলব্ধ MEP বৈশিষ্ট্যটি এই সমস্যার সমাধান করে।
eUICC আর্কিটেকচার
এই বিভাগটি বিভিন্ন Android সংস্করণের জন্য MEP সহ ডিভাইসগুলির জন্য eSIM চিপ আর্কিটেকচার এবং MEP ছাড়া ডিভাইসগুলির জন্য eSIM চিপ আর্কিটেকচার বর্ণনা করে৷
অ্যান্ড্রয়েড 14
Android 14 বা তার উচ্চতর সংস্করণে চলমান ডিভাইসগুলির জন্য, Android ইস্যুকারী নিরাপত্তা ডোমেন রুট (ISD-R) নির্বাচন এবং GSMA SGP V22 3.0 -এ উল্লেখিত eSIM পোর্ট নির্বাচনের জন্য MEP-A1 এবং MEP-B বিকল্পগুলিকে সমর্থন করে। নিম্নলিখিত MEP-A1 এবং MEP-B ISD-R নির্বাচন মডেলগুলি বর্ণনা করে৷
MEP-A1: ISD-R পোর্ট 0 এ নির্বাচন করা হয়েছে (কমান্ড পোর্ট 0) এবং প্রোফাইলগুলি eSIM পোর্ট 1 এবং উচ্চতর নির্বাচন করা হয়েছে। ES10 কমান্ড সবসময় 0 পোর্টে পাঠানো হয় এবং কমান্ড পোর্ট এবং টার্গেট পোর্ট সবসময় আলাদা হয়। LPA পোর্ট নির্বাচন করে।
চিত্র 1. MEP-A1 ISD-R নির্বাচন মডেল
MEP-B: ISD-R যেকোন পোর্টে নির্বাচন করা হয় এবং যেকোন পোর্টে একটি প্রোফাইল বরাদ্দ করা যেতে পারে। সক্ষম এবং নিষ্ক্রিয় কমান্ডগুলি পোর্টে পাঠানো হয় যেখানে প্রোফাইলটি সক্ষম বা নিষ্ক্রিয় করা প্রয়োজন (যেখানে একটি রিফ্রেশ মুলতুবি আছে)। কমান্ড পোর্ট এবং টার্গেট পোর্ট সবসময় একই।
চিত্র 2. MEP-B ISD-R নির্বাচন মডেল
অ্যান্ড্রয়েড 13
Android 13 বা উচ্চতর সংস্করণে, MEP সমর্থন করে এমন ডিভাইসগুলিতে, eSIM স্লটে একাধিক eUICC পোর্ট থাকে যেখানে পোর্টে একটি সক্ষম প্রোফাইল থাকতে পারে। চিত্র 3 তে দেখানো হয়েছে, এই আর্কিটেকচারের সাথে, একটি একক eUICC (একটি একক ফিজিক্যাল স্লট) একটি মডেম বেসব্যান্ডের সাথে প্রতিটি eUICC পোর্ট লিঙ্ক থাকার মাধ্যমে ডুয়াল সিম ডুয়াল স্ট্যান্ডবাই (DSDS) সমর্থন করে। Android 13 HAL এবং APIগুলি MEP ভেরিয়েন্ট স্বাধীন।
চিত্র 3. এমইপি সমর্থন সহ eSIM চিপ আর্কিটেকচার (Android 13 বা উচ্চতর)
অ্যান্ড্রয়েড 12 এবং তার নিচের
চিত্র 4-এ দেখানো হিসাবে MEP ছাড়া Android 12 বা তার নিচের সংস্করণে চলমান ডিভাইসগুলির জন্য, eSIM স্লট শুধুমাত্র একবারে একটি সক্রিয় প্রোফাইল সমর্থন করে এবং ডিভাইসটি DSDS সমর্থন করতে পারে না।
চিত্র 4. MEP সমর্থন ছাড়াই eSIM চিপ আর্কিটেকচার (Android 12 বা তার নিচের)
একাধিক সক্রিয় প্রোফাইলের জন্য API তথ্য প্রবাহ
চিত্র 5 এন্ড্রয়েড 13-এ eUICC-এর জন্য MEP-এর তথ্য প্রবাহ বর্ণনা করে। টেলিফোনি ফ্রেমওয়ার্ক UiccPort
ক্লাস অন্তর্ভুক্ত করে, যা eUICC-তে শারীরিক গঠনকে প্রতিনিধিত্ব করে। UiccPort
ক্লাসটি সব ধরনের সিম কার্ডের জন্য ব্যবহৃত হয়: ফিজিক্যাল সিম (pSIM), ইন্টিগ্রেটেড সিম (iSIM), এবং এমবেডেড সিম (eSIM)। একাধিক পোর্ট সহ একটি eUICC এর জন্য, একটি একক UiccSlot
অবজেক্ট এবং একাধিক UiccPort
দৃষ্টান্তে UiccCard
অবজেক্ট ম্যাপ। প্রতিটি UiccPort
উদাহরণ সর্বাধিক একটি UiccProfile
উদাহরণের সাথে লিঙ্ক করতে পারে। এই প্রবাহটি UiccPort
একটি লজিক্যাল স্লটে ম্যাপ করতে এবং UiccSlot
(ভৌতিক স্লট) কে একাধিক লজিক্যাল স্লটে ম্যাপ করতে দেয়।
চিত্র 5. MEP সমর্থন সহ eUICC-এর জন্য তথ্য প্রবাহ
বাস্তবায়ন
এই বিভাগে HAL প্রয়োজনীয়তা, API, এবং ব্যবহারকারী ইন্টারফেস সম্পর্কে বিশদ সহ MEP বৈশিষ্ট্য কীভাবে বাস্তবায়ন করা যায় তা বর্ণনা করে। MEP সমর্থন করার জন্য ডিভাইস নির্মাতাদের SoC বিক্রেতা এবং eSIM চিপসেট বিক্রেতাদের সাথে কাজ করা উচিত।
HAL প্রয়োজনীয়তা
eUICC-এর জন্য MEP সমর্থন করতে, নিম্নলিখিত IRadio AIDL HAL APIগুলি প্রয়োগ করুন, /platform/hardware/interfaces/radio/aidl/aidl_api
এ অবস্থিত।
অ্যান্ড্রয়েড 14 বা উচ্চতর চলমান ডিভাইসগুলিকে অবশ্যই HAL ইন্টারফেসের IRadio 2.1 সংস্করণ ব্যবহার করতে হবে, যা MultipleEnabledProfileMode
(ISD-R নির্বাচন মডেলটি মোডেম বা eUICC দ্বারা সমর্থিত) ব্যবহার করে এবং ICC লজিক্যাল চ্যানেল অপারেশনের সময় ES10 APDU কমান্ড তথ্য পাস করে৷
কার্ড স্ট্যাটাস
getIccCardStatusResponse
পদ্ধতির প্রতিক্রিয়া হিসাবে মোডেমকে অবশ্যই CardStatus
API সমর্থন করতে হবে। প্রতিক্রিয়াতে পোর্ট ইনডেক্স এবং SimPortSlotMapping
দ্বারা নির্দিষ্ট করা ফিজিক্যাল স্লট সূচক অন্তর্ভুক্ত থাকতে হবে।
Android 14 বা উচ্চতর সংস্করণে চলমান ডিভাইসগুলির জন্য, মডেমকে অবশ্যই সমস্ত কার্ড স্ট্যাটাস ইভেন্ট সহ সমর্থিত MEP মোড পাস করতে হবে।
সিমস্লট স্ট্যাটাস
getSimSlotsStatus
পদ্ধতির প্রতিক্রিয়া হিসাবে মোডেমটিকে অবশ্যই SimSlotStatus
API সমর্থন করতে হবে। সিম স্লট স্ট্যাটাসে SimPortInfo
ইন্টারফেসের একটি অ্যারে অন্তর্ভুক্ত থাকে, যার মধ্যে পোর্ট ইনডেক্স, সক্রিয় প্রোফাইলের জন্য ICCID এবং পোর্ট স্টেট অন্তর্ভুক্ত থাকে। মডেমকে অবশ্যই কমপক্ষে দুটি SimPortInfo
বস্তু ফেরত দিতে হবে।
Android 14 বা উচ্চতর সংস্করণে চলমান ডিভাইসগুলির জন্য, মডেমকে অবশ্যই সমস্ত কার্ড স্ট্যাটাস ইভেন্ট সহ সমর্থিত MEP মোড পাস করতে হবে।
সেট সিমস্লটম্যাপিং
setSimSlotMapping
পদ্ধতিটিকে অবশ্যই SimPortSlotMapping
এর একটি অ্যারে পাস করতে হবে। অ্যারের সূচী হল লজিক্যাল স্লট এবং SimPortSlotMapping
সংশ্লিষ্ট ম্যাপ করা পোর্ট এবং ফিজিক্যাল স্লট সূচক নির্দিষ্ট করে। setSimSlotMapping
পদ্ধতি পোর্ট থেকে লজিক্যাল স্লটে ম্যাপিং সেট করে। LPA অ্যাপ সক্রিয় পোর্ট নির্বাচন করতে এই পদ্ধতি ব্যবহার করে।
EUICC-এর জন্য MEP সমর্থনকারী API
AOSP টেলিফোনি স্ট্যাকের অংশ হিসাবে একাধিক সক্রিয় প্রোফাইল সমর্থন করে এমন Android ডিভাইসগুলিকে নিম্নলিখিত APIগুলিকে সমর্থন করতে হবে৷
UiccCardInfo
- (Android 13 এবং উচ্চতর)
isMultipleEnabledProfilesSupported
: এই UICC MEP সমর্থন করে কিনা তা ফেরত দেয়। - (Android 13 এবং উচ্চতর)
getPorts
: একটি নির্দিষ্ট UICC-এর জন্য সম্ভাব্য সমস্ত পোর্টের তালিকা প্রদান করে। যদি UICC একটি pSIM বা eSIM হয় যা MEP সমর্থন করে না, তাহলে একটি উপাদানের একটি তালিকা প্রদান করে। - (অপ্রচলিত)
getIccId
: একটি ICCID প্রদান করে। যেহেতু একটি UICC-এর MEP সহ ডিভাইসগুলির জন্য একাধিক ICCID থাকতে পারে, তার পরিবর্তেUiccPortInfo.getIccId()
ব্যবহার করুন৷
(Android 13 এবং উচ্চতর) UiccPortInfo
-
getIccId
: এই পোর্টে একটি সক্রিয় সদস্যতা থাকলে ICCID ফেরত দেয়। -
getPortIndex
: পোর্ট ইনডেক্স প্রদান করে। -
getLogicalSlotIndex
: সক্রিয় লজিক্যাল মডেম স্ট্যাক ইনডেক্স প্রদান করে।
সদস্যতা তথ্য
- (Android 13 এবং উচ্চতর)
getPortIndex
: সাবস্ক্রিপশন সক্রিয় করা আছে এমন পোর্ট সূচী প্রদান করে। সদস্যতা অক্ষম করা হলে,INVALID_PORT_ID -1
প্রদান করে।
EuiccManager
-
switchToSubscription
: একটি প্রদত্ত সাবস্ক্রিপশনে স্যুইচ করে। অ্যাক্টিভ সাবস্ক্রিপশনে ক্যারিয়ারের বিশেষাধিকার নেই এমন অ্যাপগুলির দ্বারা ব্যবহৃত। যখন কল করা হয়, প্ল্যাটফর্মটি অভ্যন্তরীণভাবে পোর্ট সূচী সমাধান করে একটি তিন-পছন্দ নির্বাচন ডায়ালগের মাধ্যমে নির্বাচিত সক্রিয় সদস্যতা নিষ্ক্রিয় করতে যদি কোনো উপলব্ধ পোর্ট না থাকে। অ্যান্ড্রয়েড 13 এবং উচ্চতর টার্গেট করা অ্যাপগুলি অবশ্যই একটি অবৈধ সাবস্ক্রিপশন আইডি পাস করে সাবস্ক্রিপশন অক্ষম করতে এই API ব্যবহার করবে না; পরিবর্তে তাদের অবশ্যইswitchToSubscription
পদ্ধতি ব্যবহার করতে হবে (অ্যান্ড্রয়েড 13-এ যোগ করা হয়েছে) পোর্ট ইনডেক্স নির্দিষ্ট করা আছে। - (Android 13 এবং উচ্চতর)
switchToSubscription(int subscriptionId, int portIndex, PendingIntent callback)
: একটি প্রদত্ত সাবস্ক্রিপশনে স্যুইচ করে। সক্রিয় সাবস্ক্রিপশনের উপর ক্যারিয়ারের বিশেষাধিকার সহ অ্যাপগুলিকে কল করা কোন পোর্টে সাবস্ক্রিপশন চালু করতে হবে তা নির্দিষ্ট করতে পারে। - (Android 13 এবং উচ্চতর)
isSimPortAvailable
: পাসিং পোর্ট সূচক উপলব্ধ কিনা তা ফেরত দেয়। কোনো সাবস্ক্রিপশন সক্রিয় না থাকলে বা নির্বাচিত পোর্টে ইনস্টল করা সাবস্ক্রিপশনের উপর কলিং অ্যাপের ক্যারিয়ারের বিশেষাধিকার থাকলে একটি পোর্ট উপলব্ধ।
EuiccService
- (Android 13 এবং উচ্চতর)
onSwitchToSubscriptionWithPort
: একটি নির্দিষ্ট পোর্টে প্রদত্ত সাবস্ক্রিপশনে স্যুইচ করে। LPA বাস্তবায়ন অবশ্যই Android 13 এবং উচ্চতর সংস্করণে এটি সমর্থন করবে।
টেলিফোনি ম্যানেজার
- (Android 13 এবং উচ্চতর)
getSimApplicationState
: কার্ড আবেদনের অবস্থা নির্দেশ করে একটি ধ্রুবক প্রদান করে। এই API একটি শারীরিক স্লট সূচক এবং একটি পোর্ট সূচক উভয়ই পাস করে।getSimApplicationState(int physicalSlotIndex)
পদ্ধতি (অবঞ্চিত) একটিsimApplicationState
অবজেক্ট পেতে শুধুমাত্র শারীরিক স্লট সূচক পাস করে। - (Android 13 এবং উচ্চতর)
setSimSlotMapping(Collection<UiccSlotMapping> slots)
: লজিক্যাল স্লটগুলিকে ফিজিক্যাল স্লট এবং পোর্টে ম্যাপ করে। - (Android 13 এবং উচ্চতর)
Collection<UiccSlotMapping> getSimSlotMapping
: লজিক্যাল স্লট থেকে ফিজিক্যাল সিম স্লট এবং পোর্ট ইনডেক্সে ম্যাপিং পায়।
ইউজার ইন্টারফেস
eSIM পোর্ট নির্বাচনের অস্পষ্টতা সমাধান করতে, MEP সমর্থনকারী ডিভাইসগুলিতে, ব্যবহারকারীদের অবশ্যই একটি নতুন সাবস্ক্রিপশন সক্রিয় করতে সক্রিয় সদস্যতার একটি অক্ষম করতে সক্ষম হতে হবে। অ্যান্ড্রয়েড 13-এ, AOSP একটি তিন-পছন্দের ডায়ালগ সহ একটি ব্যবহারকারী প্রবাহ অন্তর্ভুক্ত করে যা সেটিংস অ্যাপ থেকে ব্যবহারকারীর প্রবাহ সক্ষম করে সদস্যতাতে প্রয়োগ করা যেতে পারে। চিত্র 6 এই UX প্রবাহের একটি উদাহরণ দেখায়।
চিত্র 6. সিম সাবস্ক্রিপশন সক্রিয় করার জন্য ব্যবহারকারীর প্রবাহ
বৈশিষ্ট্য পতাকা
MEP সমর্থন করার জন্য, ডিভাইসগুলিকে অবশ্যই নিম্নলিখিত বৈশিষ্ট্যের পতাকাগুলি ঘোষণা করতে হবে:
এলপিএ বাস্তবায়ন
MEP সমর্থন করার জন্য, নিশ্চিত করুন যে আপনার LPA বাস্তবায়ন নিম্নলিখিত প্রয়োজনীয়তাগুলি পূরণ করে:
- একাধিক পোর্ট সমর্থন করতে EuiccService থেকে APIs প্রয়োগ করে।
- পোর্ট নির্বাচন এবং প্রোফাইল সক্ষম করার জন্য API ব্যবহার করে।
- UX প্রদান করে যা ক্যারিয়ার অ্যাপকে নির্বাচিত পোর্টে প্রোফাইল সক্ষম করতে দেয়।
বৈধতা
আপনার MEP বৈশিষ্ট্যের বাস্তবায়ন পরীক্ষা করতে, নিশ্চিত করুন যে বিল্ডগুলি নিম্নলিখিত CTS টেস্ট কেসগুলি পাস করেছে (সর্বজনীন APIগুলির জন্য): /platform/cts/tests/tests/telephony/current/src/android/telephony/euicc/cts
ডিভাইস নির্মাতাদের তাদের মডেম, eUICC চিপ এবং eSIM OS বিক্রেতাদের সাথেও কাজ করা উচিত যাতে ডিভাইসটি নিম্নলিখিতগুলি করতে পারে:
- দুটি eSIM প্রোফাইল সক্রিয় এবং দুটি ভিন্ন নেটওয়ার্কে সংযুক্ত করা যেতে পারে৷
- যেকোন ইসিম পোর্টে ই-সিম প্রোফাইল সক্রিয় এবং নিষ্ক্রিয় করা যেতে পারে।
- ব্যবহারকারীদের প্রোফাইল স্যুইচ করার অনুমতি দেয় ক্যারিয়ার অ্যাপ দ্বারা ট্রিগার করা একটি UX প্রবাহ রয়েছে।
বাহকদের জন্য সুপারিশ
ব্যবহারকারীরা ই-সিম প্রোফাইলগুলিকে এক পোর্ট থেকে অন্য পোর্টে সরানোর সময় পরিষেবাটি হারাবেন না তা নিশ্চিত করার জন্য, আমরা সুপারিশ করি যে ক্যারিয়ারগুলি নিম্নলিখিতগুলির জন্য সহায়তা প্রদান করে:
- IMEI এবং SIM এর ফ্লুইড ম্যাপিং
- প্রতিটি eUICC শনাক্তকারীর (EID) জন্য একাধিক ICCID বা সিম