Skip to content
Snippets Groups Projects
Commit ab2ed909 authored by Sandeep Mistry's avatar Sandeep Mistry
Browse files

Wire slave receiver with repeated starts working

parent 4efe39eb
No related branches found
No related tags found
No related merge requests found
......@@ -219,13 +219,26 @@ void TwoWire::onService(void)
{
if ( sercom->isSlaveWIRE() )
{
if(sercom->isAddressMatch()) //Address Match
if(sercom->isStopDetectedWIRE() ||
(sercom->isAddressMatch() && sercom->isRestartDetectedWIRE())) //Stop or Restart detected
{
sercom->prepareAckBitWIRE();
sercom->prepareCommandBitsWire(0x03);
//Is a request ?
if(sercom->isMasterReadOperationWIRE())
//Calling onReceiveCallback, if exists
if(onReceiveCallback)
{
onReceiveCallback(available());
}
rxBuffer.clear();
}
else if(sercom->isAddressMatch()) //Address Match
{
sercom->prepareAckBitWIRE();
sercom->prepareCommandBitsWire(0x03);
if(sercom->isMasterReadOperationWIRE()) //Is a request ?
{
//Calling onRequestCallback, if exists
if(onRequestCallback)
......@@ -247,19 +260,6 @@ void TwoWire::onService(void)
sercom->prepareCommandBitsWire(0x03);
}
else if(sercom->isStopDetectedWIRE() || sercom->isRestartDetectedWIRE()) //Stop or Restart detected
{
sercom->prepareAckBitWIRE();
sercom->prepareCommandBitsWire(0x03);
//Calling onReceiveCallback, if exists
if(onReceiveCallback)
{
onReceiveCallback(available());
}
rxBuffer.clear();
}
}
}
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment