ALT Linux Team development discussions
 help / color / mirror / Atom feed
* [devel] memcpy глючит (или я не умею его готовить)
@ 2019-02-21 13:17 Paul Wolneykien
  2019-02-21 13:22 ` Vladimir Didenko
  2019-02-21 13:25 ` Alexey V. Vissarionov
  0 siblings, 2 replies; 15+ messages in thread
From: Paul Wolneykien @ 2019-02-21 13:17 UTC (permalink / raw)
  To: ALT Linux Team development discussions


  Коллеги, прошу помощи разбором одной проблемы. Предполагаю, что это
какая-то очевидная ошибка: то ли я действительно не умею готовить
memcpy(), то ли где-то в программе есть ошибки при работе с памятью,
которые влияют косвенно (может в данном случае такое быть?).

  Итак, у меня есть вот такой код¹

> 1460 if (_data.size % 2 && _data.data[8] == 0x04) {
> 1461     // Uncompressed point (the first 8 bytes is the UKM)
> 1462     memcpy (_data.data + 8, _data.data + 9, _data.size - 9);
> 1463     _data.size--;
> 1464 }

после выполнения которого на Сизифе, я получаю копию массива данных за
исключением 9-го (по счёту с 1) байта. Как и планировалось. Однако, если
тот же самый бинарь запустить на машинке с p8, то получается неожиданный
и странный эффект: 57-й байт заменяется копией 58-го. Вот
как это выглядит (см. конец строки 0x4cc050 – начало строки 0x4cc058 во
втором дампе):

> (gdb) x/73ubfx _data.data
> 0x4cc020:	0xdd	0x0a	0x35	0x80	0x51	0x13	0xed	0xdb
> 0x4cc028:	0x04	0xd6	0x9b	0xa0	0x15	0x3b	0xa2	0x72
> 0x4cc030:	0x98	0x72	0xd0	0x2a	0x64	0x45	0x79	0x05
> 0x4cc038:	0x4e	0x0f	0x74	0x4e	0x70	0x07	0xa9	0x4f
> 0x4cc040:	0x87	0x53	0xb4	0x55	0xd3	0xc6	0x81	0x48
> 0x4cc048:	0x90	0xbd	0xa1	0xff	0x28	0x7e	0x97	0x41
> 0x4cc050:	0x2a	0x6e	0xbf	0x5e	0xfc	0xa0	0xf4	0x2b
> 0x4cc058:	0xcd	0x47	0x64	0x36	0x46	0xb0	0x02	0x7b
> 0x4cc060:	0x11	0x03	0xe6	0x9c	0xed	0x94	0x43	0x50
> 0x4cc068:	0xdf
> 
> (gdb) n
> 1463
> 
> (gdb) x/73ubfx _data.data
> 0x4cc020:	0xdd	0x0a	0x35	0x80	0x51	0x13	0xed	0xdb
> 0x4cc028:	0xd6	0x9b	0xa0	0x15	0x3b	0xa2	0x72	0x98
> 0x4cc030:	0x72	0xd0	0x2a	0x64	0x45	0x79	0x05	0x4e
> 0x4cc038:	0x0f	0x74	0x4e	0x70	0x07	0xa9	0x4f	0x87
> 0x4cc040:	0x53	0xb4	0x55	0xd3	0xc6	0x81	0x48	0x90
> 0x4cc048:	0xbd	0xa1	0xff	0x28	0x7e	0x97	0x41	0x2a
> 0x4cc050:	0x6e	0xbf	0x5e	0xfc	0xa0	0xf4	0x2b	0x47
> 0x4cc058:	0x47	0x64	0x36	0x46	0xb0	0x02	0x7b	0x11
> 0x4cc060:	0x03	0xe6	0x9c	0xed	0x94	0x43	0x50	0xdf
> 0x4cc068:	0xdf

На других входных данных пока не пробовал. Зато пробовал на разных
машинах с Сизифом и p8 — воспроизводится стабильно. Причём, один из
Сизифов не самый новый. Однако на Сизифах работает, а на p8 — получаю
паразитную копию того самого 57-го байта. Архитектуры везде x86_64.

---
¹
http://git.altlinux.org/gears/g/gnupg-pkcs11-scd.git?p=gnupg-pkcs11-scd.git;a=blob;f=gnupg-pkcs11-scd/gnupg-pkcs11-scd/command.c;h=6fd39a8ef70dede06e54c49ab86bdfc2c01e74c3;hb=6bda8fd5e3b3862edca3a38ac62c01477b6ab909#l1460


^ permalink raw reply	[flat|nested] 15+ messages in thread

end of thread, other threads:[~2019-02-24 16:22 UTC | newest]

Thread overview: 15+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-02-21 13:17 [devel] memcpy глючит (или я не умею его готовить) Paul Wolneykien
2019-02-21 13:22 ` Vladimir Didenko
2019-02-21 13:28   ` Paul Wolneykien
2019-02-21 13:25 ` Alexey V. Vissarionov
2019-02-22 19:27   ` Leonid Krivoshein
2019-02-22 20:51     ` Vladimir Didenko
2019-02-22 22:48       ` Leonid Krivoshein
2019-02-23  1:21         ` Mikhail Efremov
2019-02-23 12:28           ` Leonid Krivoshein
2019-02-23 12:55             ` Alexey V. Vissarionov
2019-02-23 13:08               ` Leonid Krivoshein
2019-02-23 14:46                 ` Alexey Tourbin
2019-02-23 15:02                   ` Leonid Krivoshein
2019-02-24 11:06               ` Mikhail Efremov
2019-02-24 16:22                 ` [devel] gcc pointer arithmetics Dmitry V. Levin

ALT Linux Team development discussions

This inbox may be cloned and mirrored by anyone:

	git clone --mirror http://lore.altlinux.org/devel/0 devel/git/0.git

	# If you have public-inbox 1.1+ installed, you may
	# initialize and index your mirror using the following commands:
	public-inbox-init -V2 devel devel/ http://lore.altlinux.org/devel \
		devel@altlinux.org devel@altlinux.ru devel@lists.altlinux.org devel@lists.altlinux.ru devel@linux.iplabs.ru mandrake-russian@linuxteam.iplabs.ru sisyphus@linuxteam.iplabs.ru
	public-inbox-index devel

Example config snippet for mirrors.
Newsgroup available over NNTP:
	nntp://lore.altlinux.org/org.altlinux.lists.devel


AGPL code for this site: git clone https://public-inbox.org/public-inbox.git