এসপিআই স্লেভ
এই মডিউলটি SPI স্লেভ যোগাযোগের জন্য প্ল্যাটফর্ম বিমূর্ততা অন্তর্ভুক্ত করে।
সারসংক্ষেপ
Typedefs | |
|---|---|
otPlatSpiSlaveTransactionCompleteCallback )(void *aContext, uint8_t *aOutputBuf, uint16_t aOutputBufLen, uint8_t *aInputBuf, uint16_t aInputBufLen, uint16_t aTransactionLength) | typedefbool(* নির্দেশ করে যে একটি SPI লেনদেন প্রদত্ত দৈর্ঘ্যের সাথে সম্পন্ন হয়েছে। |
otPlatSpiSlaveTransactionProcessCallback )(void *aContext) | typedefvoid(* একটি লেনদেন সম্পূর্ণ কলব্যাক কল করার পরে আমন্ত্রণ জানানো হয় এবং প্রয়োজনীয় পরবর্তী প্রক্রিয়াকরণ করতে TRUE ফেরত দেয়। |
ফাংশন | |
|---|---|
otPlatSpiSlaveDisable (void) | void SPI স্লেভ ইন্টারফেস বন্ধ করুন এবং নিষ্ক্রিয় করুন। |
otPlatSpiSlaveEnable ( otPlatSpiSlaveTransactionCompleteCallback aCompleteCallback, otPlatSpiSlaveTransactionProcessCallback aProcessCallback, void *aContext) | SPI স্লেভ ইন্টারফেস আরম্ভ করুন। |
otPlatSpiSlavePrepareTransaction (uint8_t *aOutputBuf, uint16_t aOutputBufLen, uint8_t *aInputBuf, uint16_t aInputBufLen, bool aRequestTransactionFlag) | পরবর্তী SPI লেনদেনের জন্য ডেটা প্রস্তুত করুন। |
Typedefs
otPlatSpiSlaveTransactionCompleteCallback
bool(* otPlatSpiSlaveTransactionCompleteCallback)(void *aContext, uint8_t *aOutputBuf, uint16_t aOutputBufLen, uint8_t *aInputBuf, uint16_t aInputBufLen, uint16_t aTransactionLength)
নির্দেশ করে যে একটি SPI লেনদেন প্রদত্ত দৈর্ঘ্যের সাথে সম্পন্ন হয়েছে।
স্লেভের কাছে লেখা তথ্যটি পূর্ববর্তী কলে otPlatSpiSlavePrepareTransaction() এর জন্য aInputBuf আর্গুমেন্ট দ্বারা নির্দেশিত পয়েন্টারে লেখা হয়েছে।
একবার এই ফাংশনটি কল করা হলে, otPlatSpiSlavePrepareTransaction() অবৈধ এবং পরবর্তী লেনদেন বৈধ হওয়ার জন্য আবার কল করতে হবে৷
মনে রাখবেন যে এই ফাংশনটি সর্বদা একটি লেনদেনের শেষে কল করা হয়, এমনকি যদি otPlatSpiSlavePrepareTransaction() এখনও কল করা না হয়। এই ধরনের ক্ষেত্রে, aOutputBufLen এবং aInputBufLen শূন্য হবে।
এই কলব্যাকটি আইএসআর প্রসঙ্গে কল করা যেতে পারে। এই ফাংশন থেকে রিটার্ন মান নির্দেশ করে যদি আরও কোনো প্রক্রিয়াকরণের প্রয়োজন হয়। যদি TRUE ফেরত দেওয়া হয় তাহলে প্ল্যাটফর্ম spi-স্লেভ ড্রাইভার বাস্তবায়ন লেনদেন প্রক্রিয়া কলব্যাক ( aProcessCallback সেট otPlatSpiSlaveEnable() ) চালু করতে হবে যা এই কলব্যাকের বিপরীতে একই OS প্রসঙ্গ থেকে কল করতে হবে যা অন্য কোন OpenThread API/কলব্যাক বলা হয়।
| বিস্তারিত | |||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| পরামিতি |
| ||||||||||||
| রিটার্নস | TRUE যদি এই কল রিটার্ন করার পরে প্ল্যাটফর্মটি প্রসেস কলব্যাক aProcessCallback , FALSE যদি প্রসেস করার কিছু না থাকে এবং প্রসেস কলব্যাক করার দরকার নেই। |
otPlatSpiSlaveTransactionProcessCallback
void(* otPlatSpiSlaveTransactionProcessCallback)(void *aContext)
একটি লেনদেন সম্পূর্ণ কলব্যাক কল করার পরে আমন্ত্রণ জানানো হয় এবং প্রয়োজনীয় পরবর্তী প্রক্রিয়াকরণ করতে TRUE ফেরত দেয়।
otPlatSpiSlaveTransactionCompleteCallback এর বিপরীতে যেটিকে যেকোনো OS প্রসঙ্গ (যেমন, ISR) থেকে কল করা যেতে পারে, এই কলব্যাকটিকে অবশ্যই অন্য যে কোনো OpenThread API/কলব্যাকের মতো একই OS প্রসঙ্গ থেকে কল করতে হবে।
| বিস্তারিত | |||
|---|---|---|---|
| পরামিতি |
|
ফাংশন
otPlatSpiSlaveDisable
void otPlatSpiSlaveDisable( void )
SPI স্লেভ ইন্টারফেস বন্ধ করুন এবং নিষ্ক্রিয় করুন।
otPlatSpiSlaveEnable
otError otPlatSpiSlaveEnable( otPlatSpiSlaveTransactionCompleteCallback aCompleteCallback, otPlatSpiSlaveTransactionProcessCallback aProcessCallback, void *aContext )
SPI স্লেভ ইন্টারফেস আরম্ভ করুন।
মনে রাখবেন যে otPlatSPISlavePrepareTransaction() ব্যবহার করে একটি লেনদেন প্রস্তুত না হওয়া পর্যন্ত SPI স্লেভ সম্পূর্ণরূপে প্রস্তুত নয়।
otPlatSPISlavePrepareTransaction() is not called before the master begins a transaction, the resulting SPI transaction will send all এবং সমস্ত প্রাপ্ত বাইট বাতিল করে দেবে।
| বিস্তারিত | |||||||
|---|---|---|---|---|---|---|---|
| পরামিতি |
| ||||||
| রিটার্ন মান |
|
otPlatSpiSlavePrepare লেনদেন
otError otPlatSpiSlavePrepareTransaction( uint8_t *aOutputBuf, uint16_t aOutputBufLen, uint8_t *aInputBuf, uint16_t aInputBufLen, bool aRequestTransactionFlag )
পরবর্তী SPI লেনদেনের জন্য ডেটা প্রস্তুত করুন।
এসপিআই স্লেভ ড্রাইভার দ্বারা লেনদেন সম্পূর্ণ কলব্যাক কলব্যাক না করা পর্যন্ত বা otPlatSpiSlavePrepareTransaction() এ পরবর্তী কল না হওয়া পর্যন্ত ডেটা পয়েন্টার অবশ্যই বৈধ থাকবে।
SPI মাস্টার লেনদেন শুরু করার আগে একাধিকবার কল করা যেতে পারে। এই ফাংশনে প্রতিটি সফল কল পূর্ববর্তী কলগুলির পূর্ববর্তী মানগুলিকে বাতিল করে দেবে৷
একটি সম্পূর্ণ লেনদেনের পরে এই ফাংশনটিকে কল না করা একই রকম যদি এই ফাংশনটিকে আগে কল করা হয়েছিল উভয় বাফার দৈর্ঘ্য শূন্য এবং aRequestTransactionFlag সেট করে false ।
একবার aOutputBuf এর aOutputBufLen বাইট ক্লক আউট হয়ে গেলে, মাস্টার SPI লেনদেন শেষ না করা পর্যন্ত MISO পিনটি উচ্চ সেট করা হবে। এটি লেনদেনের দৈর্ঘ্যের সাথে 0xFF বাইট সহ aOutputBuf এর শেষ প্যাডিংয়ের কার্যকরী সমতুল্য।
একবার aInputBuf-এর aInputBufLen বাইটগুলি MOSI থেকে ক্লক করা হয়ে গেলে, SPI মাস্টার লেনদেন শেষ না করা পর্যন্ত MOSI পিনের সমস্ত পরবর্তী মানগুলি উপেক্ষা করা হয়৷
মনে রাখবেন যে SPI মাস্টার একটি লেনদেন শেষ করার আগে যদি aInputBufLen বা aOutputBufLen (বা উভয়ই) নিঃশেষ হয়ে যায়, তবুও লেনদেনের চলমান আকারের ট্র্যাক রাখতে হবে লেনদেন সম্পূর্ণ কলব্যাকে পাস করার জন্য। উদাহরণস্বরূপ, যদি aInputBufLen 10 এর সমান এবং aOutputBufLen 20 এর সমান হয় এবং SPI মাস্টার 30 বাইট ক্লক করে, তাহলে মান 30 লেনদেন সম্পূর্ণ কলব্যাকে পাস করা হয়।
যদি একটি NULL পয়েন্টার aOutputBuf বা aInputBuf হিসাবে পাস করা হয় তবে এর মানে হল যে বাফার পয়েন্টারটি তার আগের/বর্তমান মান থেকে পরিবর্তন করা উচিত নয়। এই ক্ষেত্রে, সংশ্লিষ্ট দৈর্ঘ্যের যুক্তি উপেক্ষা করা উচিত। উদাহরণস্বরূপ, otPlatSpiSlavePrepareTransaction(NULL, 0, aInputBuf, aInputLen, false) ইনপুট বাফার পয়েন্টার এবং এর দৈর্ঘ্য পরিবর্তন করে কিন্তু আউটপুট বাফার পয়েন্টারটিকে আগের মতোই রাখে।
একটি লেনদেন চলমান অবস্থায় এই ফাংশনে যেকোনও কল করলে সমস্ত আর্গুমেন্ট উপেক্ষা করা হবে এবং ফেরতের মান OT_ERROR_BUSY হবে।
| বিস্তারিত | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|
| পরামিতি |
| ||||||||||
| রিটার্ন মান |
|
সম্পদ
OpenThread API রেফারেন্স বিষয়গুলি উৎস কোড থেকে উদ্ভূত হয়, যা GitHub- এ উপলব্ধ। আরও তথ্যের জন্য, বা আমাদের ডকুমেন্টেশনে অবদান রাখতে, সম্পদ দেখুন।