Skip to content

B fix #1480 : RTC not starting after soft reset #1499

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Closed
wants to merge 5 commits into from
Closed

B fix #1480 : RTC not starting after soft reset #1499

wants to merge 5 commits into from

Conversation

adustm
Copy link
Member

@adustm adustm commented Jan 11, 2016

We needed to change the location of the check of RTC_INITS flag after the PWR_CLK_ENABLE and LSE LSI oscillator configuration.
Only the HAL_RTC_ENABLE and HAL_RTC_Init are bypassed in case the RTC_INITS is already set.
This has been tested with MBED_16 test.
This fits also with the request of the issue #1403.

@0xc0170
Copy link
Contributor

0xc0170 commented Jan 11, 2016

Are you using any GUI? Can you set it up to use pull --rebase ? It would not produce the merge commits

@0xc0170
Copy link
Contributor

0xc0170 commented Jan 11, 2016

Why this change? Why did it fail before?

@adustm
Copy link
Member Author

adustm commented Jan 12, 2016

Hello,
Yes it used to fail since PR #1449 merge, that was included in release 111.
The issue #1480 has been created explaining that the RTC is not re-starting after a soft reset.
We have fixed this issue #1480 , taking care of keeping the fix of the previous request #1403 .
Cheers

@0xc0170
Copy link
Contributor

0xc0170 commented Jan 12, 2016

Merged manually

@0xc0170 0xc0170 closed this Jan 12, 2016
@adustm
Copy link
Member Author

adustm commented Jan 12, 2016

Hello, here is a quick test passed on the merged version :
| | Result | Target | Toolchain | Test ID | Test Description | Elapsed Time (sec) | Timeout (sec) | Loops
------------ | ------------- | ------------- | ------------- | ------------- | ------------- | ------------- | -------------
OK | DISCO_F429ZI | [F4D9] | uARM | MBED_16 | RTC | 4.67 | 20 | 1/1

@star297
Copy link
Contributor

star297 commented Jan 20, 2016

If this has been merged in Mbed-dev rev: 58, I'm afraid you can't light up that cigar.

Remains the same issue.

This function needs testing correctly:

int rtc_isenabled(void)
{
    return rtc_inited;
}

To something like this (that works):

int rtc_isenabled(void)
{
    if ((RTC->ISR & RTC_ISR_INITS) ==  RTC_ISR_INITS) {
        return 1;
    } else {
        return 0;
    } 
}

Otherwise the RTC time registers are reset on POR (with bat V applied) and nRST.

@star297
Copy link
Contributor

star297 commented Jan 20, 2016

There is another problem, the RTC now runs 10 seconds per minute slow on the L476.

@0xc0170
Copy link
Contributor

0xc0170 commented Jan 21, 2016

@star297 Besides that rtc_inited can be removed, shouldn't this be functional? It checks for ISR_INITS in the init, thus should not reset it, or did we miss something?

@adustm rtc_inited check please

@0xc0170
Copy link
Contributor

0xc0170 commented Jan 21, 2016

@star297 I just realized this one was a fix for #1403 , which is still open, is that correct that it should not be closed (my question above - is this not functional).

@star297
Copy link
Contributor

star297 commented Jan 23, 2016

Took some tracking to find the problems, but here's the fix:

Tested using L476 Nucleo
Set up tried with 48MHz and 80MHz HSE EXTC and EXTL( I have the 8MHz crystal fitted )

rtc_inited parts need to be removed.

The rtc_isenabled part above is required otherwise Mbed does not know it has been enabled.
The Mbed RTC api checks this, if the registers indicate not enabled it calls rtc_init.

Change line 162 in the hal_rcc.h file to:
#define RCC_LSE_TIMEOUT_VALUE ((uint32_t)300)

100mS is not enough time for the LSE to stabilize, 200mS works but add some contingency.
These crystal do vary quite a bit.
This fixes the slow RTC, that was falling back to the LSI.

Once this is done you should be okay to close both #1403 & #1480.
I will run some tests on the other boards.

@0xc0170
Copy link
Contributor

0xc0170 commented Jan 24, 2016

@adustm @bcostm

@star297
Copy link
Contributor

star297 commented Feb 2, 2016

@adustm
@0xc0170

I have loaded Mbed_dev rev: 58, it is not correct and will not work.

This part has to be changed/ included:

int rtc_isenabled(void)
{
if ((RTC->ISR & RTC_ISR_INITS) == RTC_ISR_INITS){
return 1;
} else {
return 0;
}
}

All the "rtc_inited" code needs to be removed, it's no longer required and has no use here.

I have this implemented on several targets L476, L152, F4xx, F746 and is working correctly.

If you prefer I will send an individual PR with the working code for each of the targets I have fully tested.

Each target that uses the same embedded peripheral RTC in the Mbed line up will need this change to work properly. Some of the other 'low end' targets do not have the RTC->ISR register so must not be changed.

Paul

@adustm adustm deleted the b_fix1403_1480 branch February 29, 2016 15:50
deepakvenugopal added a commit to deepakvenugopal/mbed-os that referenced this pull request Feb 9, 2018
…changes from c9bf20f..43c7ec2

43c7ec2 Merge branch 'release_internal' into release_external
ed76459 Merge pull request ARMmbed#1558 from ARMmbed/IOTTHD-2195
8d3bcb7 Add new function to unit tests
56f66a4 Review correction
8b7d018 Move indirect queue size public API to net_interface
d877c9e Review corrections
c25e476 Remove Eclipse project files for external release
d51f442 Merge branch 'release_internal' into release_external
135c48d Increase Thread SED buffer size for big packets
70931a7 Fix indirect queue packet ordering
10e51a4 API for changing Thread SED parent buffer size
6122d24 dereference null value issue fixed. (ARMmbed#1557)
d1378dc Clear IPv6 neighbor cache in partition change (ARMmbed#1554)
7610e91 Child neighbor entry updates (ARMmbed#1550)
c727295 cleared neighbours with child address that are not ours (ARMmbed#1549)
80b4d72 Thread partition merge mode TLV change (ARMmbed#1546)
edd7599 RLOC was updated before clearing child info (ARMmbed#1547)
a666056 router short address set to 0xfffe for non routers (ARMmbed#1543)
759ab05 delete route set and link set entries for a router ID (ARMmbed#1540)
23a1265 REED advertisement handling (Thread spec 5.16.3): (ARMmbed#1535)
0a32cb4 added active and pending timestamps to child update response (ARMmbed#1533)
d0eec80 Fix error case memory leak (ARMmbed#1537)
da9860f Pending set after link sync (ARMmbed#1526)
ffa1569 Thread router network data update after link sync (ARMmbed#1530)
3b46d8d Fix defects found by coverity (ARMmbed#1529)
3a57101 Fix compiler warnings and update traces (ARMmbed#1523)
c288227 Add extension check for partition weight drop in parent selection (ARMmbed#1521)
d8dea28 network data cleared after router forms new partition (ARMmbed#1525)
44a85e5 removed router flagging for thread_management_server file (ARMmbed#1524)
1cbced9 Merge pull request ARMmbed#1520 from ARMmbed/IOTTHD-2105_2
3d07365 Review corrections to network data clearing
22a0375 Clear network data from lost children
ffd8517 added a new thread management function (ARMmbed#1519)
80af9cb Thread BR network data clearing (ARMmbed#1518)
5a6f6b5 thread nvm valgrind uninitialized data fix (ARMmbed#1517)
d5e2198 Add API for partition weighting set (ARMmbed#1513)
8811d6f multicast forwarding scope changed and address registration updated. (ARMmbed#1516)
c277384 printf to tr_info (ARMmbed#1515)
bb21264 Thread combined nvm test (ARMmbed#1507)
76f7725 Primary BBR fixes from interop (ARMmbed#1512)
12ed5ab FHSS unit test: fixed fhss mac interface test (cherry picked from commit 805eb42e4416b00cc018dc32dceb353d0b6c8bb6)
dd21ea9 Remvoed unnecessary trace print's.
cb6e78b FHSS unit test: fixed fhss beacon tasklet test (cherry picked from commit abe6d671b058f4f069741eab24d51e4d62d550b0)
237b3d4 Fhss info print (ARMmbed#1486)
0f39a47 FHSS: Do not update synch monitor right after superframe change (cherry picked from commit 99d50ad9d7f8dad80f10c2a4303f4e75ab31a3c2)
c9a098f Fixed Timeoout force which actually never generate timeout.
957c7fb Pana server and client update:
ae230e5 FHSS: Update Beacon synch info in critical state
84bd8a4 FHSS: Synchronization must be done in critical state
fb1b163 Pan coordinator blacklist update
39fe6ba Added missing HAVE_RPL compiler flag
16a1bc5 MLE bootsrap and message timeout update
eeb2d39 enable BBR to support multicast registration in non   commercial networks (ARMmbed#1509)
4ea2bf8 uri modified. (ARMmbed#1510)
f443853 timeout corrected for neighbour entry (ARMmbed#1508)
ea93c1f Thread dev conf taken use (ARMmbed#1503)
5d5b239 bug fix in bbr start (ARMmbed#1505)
8dbd521 commented a trace. (ARMmbed#1504)
145dbdf device conf copy fix (ARMmbed#1502)
f60268f eid&random mac moved to device conf struct (ARMmbed#1497)
df18635 Let MAC choose address when mesh forwarding
42f916b fixed BBR stop to remove network data and routing information (ARMmbed#1500)
e058c2a pbbr changes (ARMmbed#1499)
1ece307 Merge pull request ARMmbed#1485 from ARMmbed/merge_release_back
dda8164 thread address handling updated. (ARMmbed#1496)
1dc21a1 thread extension fixes. (ARMmbed#1495)
543fe98 Merge branch 'release_internal'
bade70e Dua req changes (ARMmbed#1494)
1979df8 added status to MLR response and implemeted BMLR.ntf multicast. (ARMmbed#1492)
1807c01 mle class initialisation (ARMmbed#1488)
d809831 Merge pull request ARMmbed#1479 from ARMmbed/merge_release_to_master
bce812d Update license to Thread test file (ARMmbed#1483)
aaa4b1f Revert eclipse file removal

git-subtree-dir: features/nanostack/FEATURE_NANOSTACK/sal-stack-nanostack
git-subtree-split: 43c7ec2
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants