Pretypovani ukazatele struktury na bajt

Hynek Sladky econf na centrum.cz
Úterý Únor 25 13:58:11 CET 2020


To vypada na znamenko...
0xAD << 8 je 16-bitovy int se zapornou hodnotou
Pak se to implicitne pretypuje na uint32_t (podle dalsich clenu), ale 
protoze to je zaporna hodnota, tak se znamenko expanduje do vyssich bytu 
jako 0xFFFF0000.

Mohlo by pomoct zapisovat konstanty s priponou u, tedy napr. 0xADu << 8

Hynek Sladky


Dne 25.2.2020 v 13:28 David Obdrzalek napsal(a):
> ALE když odmažu přetypování prvních dvou bytů, tak tam vyjde:
> hdr.ident = 0xDE | 0xAD << 8 | ((uint32_t)0xBE) << 16 | ((uint32_t)0xEF) << 24;
>   4c6:	8e ed       	ldi	r24, 0xDE	; 222
>   4c8:	9d ea       	ldi	r25, 0xAD	; 173
>   4ca:	af ef       	ldi	r26, 0xFF	; 255
>   4cc:	bf ef       	ldi	r27, 0xFF	; 255
>   4ce:	80 93 b1 01 	sts	0x01B1, r24	; 0x8001b1 <hdr+0x2>
>   4d2:	90 93 b2 01 	sts	0x01B2, r25	; 0x8001b2 <hdr+0x3>
>   4d6:	a0 93 b3 01 	sts	0x01B3, r26	; 0x8001b3 <hdr+0x4>
>   4da:	b0 93 b4 01 	sts	0x01B4, r27	; 0x8001b4 <hdr+0x5>
>
> Vůbec nachápu, proč ty dvě FF ??
>
> hdr je deklarované takhle:
> typedef struct {
>    uint16_t magic;
>    uint32_t ident;
> } _hdr;
> _hdr hdr;
>
> Překladač avr-gcc (GCC) 5.4.0 na Win.
>
>
> Jo tak teď jsem ještě zmatenější, protože mě napadlo zkusit:
> hdr.ident = 0xADDE | ((uint32_t)0xBE) << 16 | ((uint32_t)0xEF) << 24;
>   4c6:	8e ed       	ldi	r24, 0xDE	; 222
>   4c8:	9d ea       	ldi	r25, 0xAD	; 173
>   4ca:	ae eb       	ldi	r26, 0xBE	; 190
>   4cc:	bf ee       	ldi	r27, 0xEF	; 239
>   4ce:	80 93 b1 01 	sts	0x01B1, r24	; 0x8001b1 <hdr+0x2>
>   4d2:	90 93 b2 01 	sts	0x01B2, r25	; 0x8001b2 <hdr+0x3>
>   4d6:	a0 93 b3 01 	sts	0x01B3, r26	; 0x8001b3 <hdr+0x4>
>   4da:	b0 93 b4 01 	sts	0x01B4, r27	; 0x8001b4 <hdr+0x5>
>
> a tohle prošlo jak bych původně čekal!
>



Další informace o konferenci Hw-list