Forum: Mikrocontroller und Digitale Elektronik Pointerübergabe an Funktion / Sporadisch fehlerhafte Funktion


von Pascal Schröer (Gast)


Lesenswert?

Hi @ all,
ich habe eine Funktion geschrieben, die fehlerhafte Parameterübergaben 
an Funktionen verhindern soll. Normalerweise läuft diese Funktion auch… 
Aber wenn ich sie z.B. 2 Mal hintereinander aufrufe, kommt es zu einer 
Fehlfunktion. Hier die Funktion:
1
void value_error(int32_t *value_in,int32_t value_min,int32_t value_max,uint32_t error_code)
2
{
3
  if(*value_in < value_min)
4
  {
5
    *value_in = value_min;
6
    error_struct.general_error_struct_1.VALUE_ERROR &= ~(error_code);  
7
  }
8
  if(*value_in > value_max)
9
  {
10
    *value_in = value_max;
11
    error_struct.general_error_struct_1.VALUE_ERROR &= ~(error_code);  
12
  }
13
}
Kann mir dazu jemand helfen? Die Fehlfunkion äußert sich darin, dass der 
Wert von *value_in unmögliche Werte annimmt.

Hier der Funktionsaufruf:
1
void PIT_init(uint8_t module, uint8_t status, uint16_t time_ms, uint8_t interrupt_en)
2
{
3
value_error((int32_t*)&module,0,3,VALUE_ERROR_PIT_init); //Funktioniert
4
value_error((int32_t*)&status,0,1,VALUE_ERROR_PIT_init); //Fehlfunktion
5
..
Dankeschön! :)

von Peter II (Gast)


Lesenswert?

Pascal Schröer schrieb:
> Kann mir dazu jemand helfen? Die Fehlfunkion äußert sich darin, dass der
> Wert von *value_in unmögliche Werte annimmt.

und das wundert dich?

du castest deine Parameter von 8bit auf 32bit und weist dann den 32bit 
etwas zu. Damit überschreibst du die fleißig den speichern.

von Pascal (Gast)


Lesenswert?

Ja ich weiß^^ aber hättest du einen lösungsvorschlag für mich? Ich 
möchte ja quasi eine "universal" funktion schreiben... Was kann ich tun?

von Peter II (Gast)


Lesenswert?

Pascal schrieb:
> Ja ich weiß^^ aber hättest du einen lösungsvorschlag für mich? Ich
> möchte ja quasi eine "universal" funktion schreiben... Was kann ich tun?

es geht so nicht.

Schreibe zur not eine Funktion für jeden Datentyp, oder mache es als 
Makro.

von Easylife (Gast)


Lesenswert?

1
int32_t value_error(int32_t value_in, int32_t value_min, int32_t 
2
value_max, uint32_t error_code)
3
{
4
  int32_t ret = value_in;
5
  if(value_in < value_min)
6
  {
7
    ret = value_min;
8
    error_struct.general_error_struct_1.VALUE_ERROR &= ~(error_code);
9
  } 
10
  else if(value_in > value_max)
11
  {
12
    value_in = value_max;
13
    error_struct.general_error_struct_1.VALUE_ERROR &= ~(error_code);
14
  }
15
16
  return (ret);
17
}
18
19
(...)
20
21
module = value_error(module, 0, 3, VALUE_ERROR_PIT_init);

von Easylife (Gast)


Lesenswert?

sorry, muss natürlich
1
(...)
2
  else if(value_in > value_max)
3
  {
4
    ret = value_max;
5
    error_struct.general_error_struct_1.VALUE_ERROR &= ~(error_code);
6
  }

heissen

von Peter II (Gast)


Lesenswert?

Easylife schrieb:
> sorry, muss natürlich

dürfte auch nicht zuverlässig funktionieren.

> value_in < value_min

hier wird der 8bit wert der nur auf 32bit gecastet ist, mit 32bit 
verglichen. Keiner kann sagen was in den restlichen 24bit steht.

von Karl H. (kbuchegg)


Lesenswert?

Peter II schrieb:

> hier wird der 8bit wert der nur auf 32bit gecastet ist, mit 32bit
> verglichen. Keiner kann sagen was in den restlichen 24bit steht.

Doch. Kann man.

Da hier kein Pointer gecastet wird, sondern der Wert selber, wird er 
kontrolliert und entsprechend den C Regeln auf 32 Bit aufgeblasen.

Bei Casts muss man unterscheiden zwischen Casts, die nur den Datentyp 
verändern und solchen, die auch eine tatsächliche Aktion, wie eine 
Wertveränderung, nach sich ziehen.
Einen Pointer umcasten gehört zur ersten Kategorie. Einen Wert umcasten 
gehört normalerweise zur zweiten Kategorie.

von Peter II (Gast)


Lesenswert?

Karl Heinz schrieb:
> Da hier kein Pointer gecastet wird, sondern der Wert selber, wird er
> kontrolliert und entsprechend den C Regeln auf 32 Bit aufgeblasen.

oh, hatte ich übersehen das er jetzt keinen Pointer mehr übergibt.

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.