* [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