-
Data: 2023-05-17 21:43:10
Temat: Re: Dziwny problem z kodem w C (gcc mips/pic32)
Od: Jacek Radzikowski <j...@s...die.die.die.piranet.org> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]On 5/17/23 15:23, Marek wrote:
> Pierwszy raz się spotkałem z czymś takim, o to problematyczny fragment
> kodu:
>
>
> const char *connectionFailureStrings[] = {
> "NULL",
> /* 0 - not used */
> "NULL",
> /* 1 - not used */
> "WF_JOIN_FAILURE",
> /* 2 */
> "WF_AUTHENTICATION_FAILURE",
> /* 3 */
> "WF_ASSOCIATION_FAILURE",
> /* 4 */
> "WF_WEP_HANDSHAKE_FAILURE",
> /* 5 */
> "WF_PSK_CALCULATION_FAILURE",
> /* 6 */
> "WF_PSK_HANDSHAKE_FAILURE",
> /* 7 */
> "WF_ADHOC_JOIN_FAILURE",
> /* 8 */
> "WF_SECURITY_MISMATCH_FAILURE", /* 9 */
> "WF_NO_SUITABLE_AP_FOUND_FAILURE", /* 10 */
> "WF_RETRY_FOREVER_NOT_SUPPORTED_FAILURE"/*11*/
> };
>
> static void OutputConnectionFailedMsg(UINT16 eventInfo)
> {
> UINT8 status;
> UINT8 reason;
> status = (UINT8)(eventInfo >> 8);
> reason = (UINT8)(eventInfo & 0xff);
>
> printf (" status %d %p\r\n",status,connectionFailureStrings[status]);
> printf("WF_Event: Connection Failed: %s
> ",connectionFailureStrings[status]);
> }
>
>
> Mamy tablicę stringów umieszczoną we flash (pamięci stałej) dzięki
> const. Niestety w losowych przypadkach drugi printf generuje wyjątek
> adresu z poza zakresu. Zmienna status nie przekracza zakresu i zawsze
> nawet jak jest wyjątek ma wartość 3. Okazuje się, że gdy jest wyjątek
> to wskaźnik (%p w pierwszym printf) pokazuje jakiś bzdurny adres, co
> oczywiście doprowadza do wyjątku w drugim printf. Jak to możliwe, że
> adres jest bzdurny??
> Przecież tablica jest we flash, adres tutaj powinien być stały i
> wygenerowany na etapie kompilacji. Oczywiście w większości przypadków
> gdy wszystko jest OK printf pokazuje prawidłowy adres 3 indeksu w tej
> tablicy. Ale raz na 10 startów kodu nie... Co ciekawe wygląda na to, że
> bzdurny adres pojawia się przy pierwszym uruchomieniu kodu po
> flashowaniu mcu ale też nie za każdym razem...
Nie testowałem, ale na pierwszy rzut oka to w deklaracji brakuje jednego
consta:
https://stackoverflow.com/questions/28320538/creatin
g-a-const-array-of-const-elements#28320734
W obecnej formie masz tablicę, która wskazuje na stringi we flashu. To
jest inicjowana stała, więc można by przypuszczać ze zawsze będzie miała
taką samą zawartość, ale czasami coś się popsuje.
Sprawdź w jakim segmencie jest umieszczona tablica, i jeśli w RAMie, to
zacznij szukać gdzie masz bląd w programie, bo najprawdopodobniej coś
gdzieś wyjeżdża poza zaalokowany obszar i nadpisuje losowe rejony pamięci.
Jacek
Następne wpisy z tego wątku
- 17.05.23 22:02 Zbych
- 17.05.23 22:05 Marek
- 17.05.23 22:16 Marek
- 18.05.23 08:55 Janusz
- 18.05.23 12:18 Marek
- 18.05.23 12:44 Janusz
- 18.05.23 13:05 Marek
- 18.05.23 13:08 Dawid Rutkowski
- 18.05.23 13:22 J.F
- 18.05.23 13:29 Grzegorz Niemirowski
- 18.05.23 13:49 heby
- 18.05.23 13:54 Grzegorz Niemirowski
- 18.05.23 14:01 Marek
- 18.05.23 14:13 Dawid Rutkowski
- 18.05.23 14:14 Dawid Rutkowski
Najnowsze wątki z tej grupy
- Jaka ładowarka sieciowa do Iphona?
- Taśma izolacyjna do prac elektrycznych
- Recenzja 3.1A ;) w 6 gniazdach...
- Re: Recenzja 3.1A ;) w 6 gniazdach...
- Re: Recenzja 3.1A ;) w 6 gniazdach...
- Re: Recenzja 3.1A ;) w 6 gniazdach...
- Wkrętarki, wiertarki...
- Zasilacz impulsowy 12V 10A, coś godnego uwagi jako zamiennik akumulatora wkrętarki
- Mouser - koszt wysyłki
- [OT] Jak wycinac ksztalt w piance lub styropianie?
- FV--> ciepła woda w kranie
- Szok
- Dziwny schemat wzmacniacza m.cz.
- We Wrocławiu ruszyła Odra 5, pierwszy w Polsce komputer kwantowy z nadprzewodzącymi kubitami
- CGNAT i ewentualne problemy
Najnowsze wątki
- 2025-07-05 Shrek, wzrośnie cena prądu :-)
- 2025-07-05 Warszawa => Senior Frontend Developer (React + React Native) <=
- 2025-07-05 Środa Wielkopolska => SAP FI/CO Internal Consultant <=
- 2025-07-05 Środa Wielkopolska => SAP FI/CO Konsultant wewnętrzny <=
- 2025-07-06 Płacić za wodę ze studni
- 2025-07-06 Kolejny inżynier...
- 2025-07-05 UE ustępuje pod presją Trumpa. Socjaldemokraci: oddaliśmy miliardy
- 2025-07-04 od kiedy można obrażać Plastusia i do kiedy Batyra?
- 2025-07-05 UE ustępuje pod presją Trumpa. Socjaldemokraci: oddaliśmy miliardy
- 2025-07-03 Trybik
- 2025-07-04 Renault Symbioz
- 2025-07-04 Architektura IIIRP: Wyjątkowa, a prymitywniejsza niż stodoła pod zaborami
- 2025-07-04 Warszawa => International Freight Forwarder <=
- 2025-07-04 Wrocław => SAP ABAP Developer <=
- 2025-07-04 Warszawa => Mid/Senior IT Recruiter <=