[sisyphus] i586 rpm setversions regression
Alexey Tourbin
at на altlinux.ru
Пн Дек 24 16:59:59 MSK 2012
On Mon, Dec 24, 2012 at 04:42:46PM +0400, Gleb Fotengauer-Malinovskiy wrote:
> On Mon, Dec 24, 2012 at 04:05:23PM +0400, Alexey Tourbin wrote:
> > [builder на people ~]$ /usr/lib/rpm/setcmp set:kdSxWgTyZxEcQx104N1sOQPFrBU4hMyJgswBQdypWl99UkQfZ7FfVfLes8xXStDq2ZBO04AhAjro2klgZ3IPusa9PpeHQCT4xiF5vDAsf0PvkfkbHFKHGGYt7lk6gVuQUZg05tAONMVt1 set:jhK9a5Z0
> > -2
> > [builder на people ~]$
> >
> > Похоже на проблему перекодирования в меньшую битность (в данном
> > случае set:k > set:j). Кажется, нашел ошибку, только теперь не знаю,
> > как проверить - хешер не заводится.
>
> У меня завёлся hasher на i586, в нём собрался rpm с этим патчем.
> C этим rpm и corosync собирается и:
>
> [builder на people .in]$ /usr/lib/rpm/setcmp set:kdSxWgTyZxEcQx104N1sOQPFrBU4hMyJgswBQdypWl99UkQfZ7FfVfLes8xXStDq2ZBO04AhAjro2klgZ3IPusa9PpeHQCT4xiF5vDAsf0PvkfkbHFKHGGYt7lk6gVuQUZg05tAONMVt1 set:jhK9a5Z0
> 1
Да, теперь работает.
4.0.4-alt100.58-1-gf25f962
> > --- lib/set.c-
> > +++ lib/set.c
> > @@ -1107,8 +1107,8 @@ int rpmsetcmp(const char *str1, const ch
> > int c1 = cache_decode_set(str1, Mshift1, &v1);
> > if (c1 < 0)
> > return -3;
> > - unsigned v1bufA[c1 + 1];
> > - unsigned v1bufB[c1 + 1];
> > + unsigned v1bufA[c1 + SENTINELS];
> > + unsigned v1bufB[c1 + SENTINELS];
> > // decode set2 (on the stack)
> > int len2 = strlen(str2);
> > int c2 = decode_set_size(len2, Mshift2);
Подробная информация о списке рассылки Sisyphus