[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