এসপিআই স্লেভ
এই মডিউলটি 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
সেট করে কল করা হয়েছিল।
একবার aOutputBufLen
এর aOutputBuf
বাইট ক্লক আউট হয়ে গেলে, মাস্টার SPI লেনদেন শেষ না করা পর্যন্ত MISO পিনটি উচ্চ সেট করা হবে। এটি লেনদেনের দৈর্ঘ্যের সাথে 0xFF
বাইট সহ aOutputBuf
এর শেষ প্যাডিংয়ের কার্যকরী সমতুল্য।
একবার aInputBufLen
এর 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- এ উপলব্ধ। আরও তথ্যের জন্য, বা আমাদের ডকুমেন্টেশনে অবদান রাখতে, সম্পদ দেখুন।