ALT Linux Team development discussions
 help / color / mirror / Atom feed
* [devel] Fwd: fuse-encfs-1.5.2-alt7: Sisyphus/x86_64 test rebuild failed [3]
  @ 2010-03-11 12:49 ` Denis Smirnov
  2010-03-11 13:03   ` Dmitry V. Levin
  0 siblings, 1 reply; 8+ messages in thread
From: Denis Smirnov @ 2010-03-11 12:49 UTC (permalink / raw)
  To: ALT Devel discussion list

Так что мне делать-то? Или encfs никому кроме меня не нужен?

Понять в чем проблема и как ее исправлять мне слабо.


---------- Forwarded message ----------
From: ALT beekeeper <beehive@altlinux.org>
Date: 2010/3/10
Subject: fuse-encfs-1.5.2-alt7: Sisyphus/x86_64 test rebuild failed [3]
To: mithraen@altlinux.org
Копия: beehive@altlinux.org

Testing interfaces
AES, key length 128, block size 256:  terminate called after throwing
an instance of 'boost::archive::archive_exception'
 what():  stream error
/usr/src/tmp/rpm-tmp.51960: line 127: 19515 Aborted                 encfs/test
error: Bad exit status from /usr/src/tmp/rpm-tmp.51960 (%build)

RPM build errors:
   Bad exit status from /usr/src/tmp/rpm-tmp.51960 (%build)
Command exited with non-zero status 1
49.65user 10.77system 1:13.42elapsed 82%CPU (0avgtext+0avgdata 0maxresident)k
0inputs+0outputs (0major+2100033minor)pagefaults 0swaps
hsh-rebuild: rebuild of `fuse-encfs-1.5.2-alt7.src.rpm' failed.
Command exited with non-zero status 1

--
Sincerely yours,
ALT beekeeper


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

* Re: [devel] Fwd: fuse-encfs-1.5.2-alt7: Sisyphus/x86_64 test rebuild failed [3]
  2010-03-11 12:49 ` [devel] Fwd: fuse-encfs-1.5.2-alt7: Sisyphus/x86_64 test rebuild failed [3] Denis Smirnov
@ 2010-03-11 13:03   ` Dmitry V. Levin
  2010-03-11 17:52     ` Денис Смирнов
  0 siblings, 1 reply; 8+ messages in thread
From: Dmitry V. Levin @ 2010-03-11 13:03 UTC (permalink / raw)
  To: ALT Devel discussion list

[-- Attachment #1: Type: text/plain, Size: 498 bytes --]

On Thu, Mar 11, 2010 at 03:49:31PM +0300, Denis Smirnov wrote:
> Так что мне делать-то? Или encfs никому кроме меня не нужен?
> 
> Понять в чем проблема и как ее исправлять мне слабо.

Апстриму отрепортить не пробовал?

> Testing interfaces
> AES, key length 128, block size 256:  terminate called after throwing
> an instance of 'boost::archive::archive_exception'
>  what():  stream error
> /usr/src/tmp/rpm-tmp.51960: line 127: 19515 Aborted                 encfs/test


-- 
ldv

[-- Attachment #2: Type: application/pgp-signature, Size: 198 bytes --]

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

* Re: [devel] Fwd: fuse-encfs-1.5.2-alt7: Sisyphus/x86_64 test rebuild failed [3]
  2010-03-11 13:03   ` Dmitry V. Levin
@ 2010-03-11 17:52     ` Денис Смирнов
  2010-03-11 20:42       ` Vladislav Zavjalov
  0 siblings, 1 reply; 8+ messages in thread
From: Денис Смирнов @ 2010-03-11 17:52 UTC (permalink / raw)
  To: ALT Linux Team development discussions

[-- Attachment #1: Type: text/plain, Size: 485 bytes --]

On Thu, Mar 11, 2010 at 04:03:54PM +0300, Dmitry V. Levin wrote:

DVL> Апстриму отрепортить не пробовал?

Проблема вылезла после обновления boost'а у нас.

Притом я, честно говоря, совсем не в состоянии понять что там происходит,
ибо C++ знаю на уровне "С с классами" и дать сколь-нибудь внятный репорт.

Может просто линковаться со старым boost?

-- 
С уважением, Денис

http://mithraen.ru/
----------------------------------------------------------------------------

[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 198 bytes --]

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

* Re: [devel] Fwd: fuse-encfs-1.5.2-alt7: Sisyphus/x86_64 test rebuild failed [3]
  2010-03-11 17:52     ` Денис Смирнов
@ 2010-03-11 20:42       ` Vladislav Zavjalov
  2010-03-11 21:58         ` Vladislav Zavjalov
  0 siblings, 1 reply; 8+ messages in thread
From: Vladislav Zavjalov @ 2010-03-11 20:42 UTC (permalink / raw)
  To: ALT Linux Team development discussions

On Thu, Mar 11, 2010 at 08:52:05PM +0300, Денис Смирнов wrote:
> On Thu, Mar 11, 2010 at 04:03:54PM +0300, Dmitry V. Levin wrote:
> 
> DVL> Апстриму отрепортить не пробовал?
> 
> Проблема вылезла после обновления boost'а у нас.
> 
> Притом я, честно говоря, совсем не в состоянии понять что там происходит,
> ибо C++ знаю на уровне "С с классами" и дать сколь-нибудь внятный репорт.
> 
> Может просто линковаться со старым boost?

Покопался...

boost::archive используется для чтения/записи xml в FileUtils.cpp

Облом происходит в std::istream &operator >>
в test.cpp:230. Записать xml оно сумело, а прочитать - нет.

А прочитать оно его не сумело, поскольку была выставлена версия класса
20080816 (см BOOST_CLASS_VERSION в FileUtils.cpp), а в xml попало 26800 (а для
старых версий она хочет читать что-то другое).

Взяв минимальный пример с
http://www.boost.org/doc/libs/1_42_0/libs/serialization/doc/index.html
устроил такую штуку, показывающую, что с большими версиями классов
происходит фигня, а именно, они устанавливаются по модулю 65536:

Так что проблема в boost, и как ее хорошо обойти  в fuse-encfs -
непонятно...

===

#include <iostream>

#include <boost/archive/text_oarchive.hpp>
#include <boost/archive/text_iarchive.hpp>

#define VERSION 65536

struct test{
    template<class Archive>
    void serialize(Archive & ar, const unsigned int version)
    {
        std::cerr << "\n" << "new_version: " << version << "\n"
                       << "old_version: " << VERSION << "\n";
        ar & i;
    }
    int i;
};

BOOST_CLASS_VERSION(test, VERSION)

int main() {
    test var;
    var.i=100;

    boost::archive::text_oarchive oa(std::cout);
    oa << var;
}



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

* Re: [devel] Fwd: fuse-encfs-1.5.2-alt7: Sisyphus/x86_64 test rebuild failed [3]
  2010-03-11 20:42       ` Vladislav Zavjalov
@ 2010-03-11 21:58         ` Vladislav Zavjalov
  2010-03-12 15:21           ` Денис Смирнов
  0 siblings, 1 reply; 8+ messages in thread
From: Vladislav Zavjalov @ 2010-03-11 21:58 UTC (permalink / raw)
  To: ALT Linux Team development discussions

[-- Attachment #1: Type: text/plain, Size: 144 bytes --]

> Так что проблема в boost, и как ее хорошо обойти  в fuse-encfs -
> непонятно...

Придумал не слишком красивенький обход (в приложении)

Слава

[-- Attachment #2: 0001-boost-serialization-version-workaround.patch --]
[-- Type: text/plain, Size: 2267 bytes --]

>From 37e22a7215e7cd68aa5ee49a996bbed302b7c25e Mon Sep 17 00:00:00 2001
From: Vladislav Zavjalov <slazav@altlinux.org>
Date: Fri, 12 Mar 2010 03:44:21 +0300
Subject: [PATCH] boost::serialization::version workaround

---
 fuse-encfs/encfs/FileUtils.cpp |   18 +++++++++++++++++-
 1 files changed, 17 insertions(+), 1 deletions(-)

diff --git a/fuse-encfs/encfs/FileUtils.cpp b/fuse-encfs/encfs/FileUtils.cpp
index 73a589f..9e69b57 100644
--- a/fuse-encfs/encfs/FileUtils.cpp
+++ b/fuse-encfs/encfs/FileUtils.cpp
@@ -131,6 +131,10 @@ namespace boost
         void save(Archive &ar, const EncFSConfig &cfg, 
                 unsigned int version)
         {
+	    //workaround: some boost versions wraps version to 65536!
+            //works for years 2006..2012
+	    if (version < 65536) version+=65536*306;
+
             (void)version;
             ar << make_nvp("creator", cfg.creator);
             ar << make_nvp("cipherAlg", cfg.cipherIface);
@@ -161,6 +165,10 @@ namespace boost
         template<class Archive>
         void load(Archive &ar, EncFSConfig &cfg, unsigned int version)
         {
+	    //workaround: some boost versions wraps version to 65536!
+            //works for years 2006..2012
+	    if (version < 65536) version+=65536*306;
+
             cfg.subVersion = version;
             ar >> make_nvp("creator", cfg.creator);
             ar >> make_nvp("cipherAlg", cfg.cipherIface);
@@ -207,12 +215,20 @@ namespace boost
         template<class Archive>
         void serialize(Archive &ar, EncFSConfig &cfg, unsigned int version)
         {
+	    //workaround: some boost versions wraps version to 65536!
+            //works for years 2006..2012
+	    if (version < 65536) version+=65536*306;
+
             split_free(ar, cfg, version);
         }
 
         template<class Archive>
-        void serialize(Archive &ar, Interface &i, const unsigned int version)
+        void serialize(Archive &ar, Interface &i, unsigned int version)
         {
+	    //workaround: some boost versions wraps version to 65536!
+            //works for years 2006..2012
+	    if (version < 65536) version+=65536*306;
+
             (void)version;
             ar & make_nvp("name", i.name());
             ar & make_nvp("major", i.current());
-- 
1.6.5.3


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

* Re: [devel] Fwd: fuse-encfs-1.5.2-alt7: Sisyphus/x86_64 test rebuild failed [3]
  2010-03-11 21:58         ` Vladislav Zavjalov
@ 2010-03-12 15:21           ` Денис Смирнов
  2010-03-12 15:49             ` Vladislav Zavjalov
  0 siblings, 1 reply; 8+ messages in thread
From: Денис Смирнов @ 2010-03-12 15:21 UTC (permalink / raw)
  To: ALT Linux Team development discussions

[-- Attachment #1: Type: text/plain, Size: 395 bytes --]

On Fri, Mar 12, 2010 at 12:58:06AM +0300, Vladislav Zavjalov wrote:

VZ> Придумал не слишком красивенький обход (в приложении)

Спасибо! А что вообще этот кусок кода в encfs делает, и есть ли риск
несовместимостей от этого патча?

Я могу его слепо приложить?

-- 
С уважением, Денис

http://mithraen.ru/
----------------------------------------------------------------------------

[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 198 bytes --]

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

* Re: [devel] Fwd: fuse-encfs-1.5.2-alt7: Sisyphus/x86_64 test rebuild failed [3]
  2010-03-12 15:21           ` Денис Смирнов
@ 2010-03-12 15:49             ` Vladislav Zavjalov
  2010-03-12 16:33               ` Денис Смирнов
  0 siblings, 1 reply; 8+ messages in thread
From: Vladislav Zavjalov @ 2010-03-12 15:49 UTC (permalink / raw)
  To: ALT Linux Team development discussions

On Fri, Mar 12, 2010 at 06:21:06PM +0300, Денис Смирнов wrote:
> On Fri, Mar 12, 2010 at 12:58:06AM +0300, Vladislav Zavjalov wrote:
> 
> VZ> Придумал не слишком красивенький обход (в приложении)
> 
> Спасибо! А что вообще этот кусок кода в encfs делает, и есть ли риск
> несовместимостей от этого патча?

Я это понял так:
Это запись и чтение xml-конфигов с помощью boost/archive и boost/serialization
В xml записывается объект типа EncFSConfig, и к нему пишется
версия, чтоб потом правильно читать устаревшие конфиги.

Фигня в том, что версия устанавливается 20080816, а где-то в boost-е 
она приводится к uint16 (я покопался, но не понял где - везде вроде unsigned int).
А при чтении там стоят всякие проверки, типа "если старше 20080816 - такие поля не нужны" 
и т.п. И с учетом этих проверок boost'у предлагают читать не
тот объект, который записан. (Это все можно смотреть в файле FileUtils.cpp)

Насчет патча - он сомнительный. Он перед всякими проверками говорит
if (version < 65536) version+=65536*306;
Мало того, что с версиями > 20120101 это уже не будет работать, так еще
и конфиги, записанные разными весиями программы могут перепутаться.
Сейчас в конфиги будет писаться неправильная обрезанная версия
и читаться она будет правильно только сборкой с этим патчем.

В общем, я бы еще подумал. Как минимум, попытался бы
сделать, чтоб в конфиги писалась правильная версия (хотя это какие-то
недра boost'a)...

И - попинать знатоков boost'a, что там у них за фигня.

Слава


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

* Re: [devel] Fwd: fuse-encfs-1.5.2-alt7: Sisyphus/x86_64 test rebuild failed [3]
  2010-03-12 15:49             ` Vladislav Zavjalov
@ 2010-03-12 16:33               ` Денис Смирнов
  0 siblings, 0 replies; 8+ messages in thread
From: Денис Смирнов @ 2010-03-12 16:33 UTC (permalink / raw)
  To: ALT Linux Team development discussions

[-- Attachment #1: Type: text/plain, Size: 722 bytes --]

On Fri, Mar 12, 2010 at 06:49:58PM +0300, Vladislav Zavjalov wrote:

VZ> Насчет патча - он сомнительный. Он перед всякими проверками говорит
VZ> if (version < 65536) version+=65536*306;
VZ> Мало того, что с версиями > 20120101 это уже не будет работать, так еще
VZ> и конфиги, записанные разными весиями программы могут перепутаться.
VZ> Сейчас в конфиги будет писаться неправильная обрезанная версия
VZ> и читаться она будет правильно только сборкой с этим патчем.

Получается что если этот патч сейчас приложить -- его придется иметь
пожизненно :(

Тогда подождем свежего boost.

-- 
С уважением, Денис

http://mithraen.ru/
----------------------------------------------------------------------------

[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 198 bytes --]

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

end of thread, other threads:[~2010-03-12 16:33 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2010-03-11 12:49 ` [devel] Fwd: fuse-encfs-1.5.2-alt7: Sisyphus/x86_64 test rebuild failed [3] Denis Smirnov
2010-03-11 13:03   ` Dmitry V. Levin
2010-03-11 17:52     ` Денис Смирнов
2010-03-11 20:42       ` Vladislav Zavjalov
2010-03-11 21:58         ` Vladislav Zavjalov
2010-03-12 15:21           ` Денис Смирнов
2010-03-12 15:49             ` Vladislav Zavjalov
2010-03-12 16:33               ` Денис Смирнов

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