mirror of
https://github.com/samba-team/samba.git
synced 2025-01-01 21:18:10 +03:00
Another attempt at fixing the endian problem when upgrading from 2.2.3a.
Herb please check.
Jeremy.
(This used to be commit a312b5b2de
)
This commit is contained in:
parent
9199721eba
commit
1d79e6b90e
@ -363,7 +363,6 @@ fail:
|
||||
|
||||
static BOOL idmap_convert(const char *idmap_name)
|
||||
{
|
||||
BOOL bytereversed = False;
|
||||
int32 vers = tdb_fetch_int32(idmap_tdb, "IDMAP_VERSION");
|
||||
|
||||
if (vers == IDMAP_VERSION)
|
||||
@ -375,16 +374,21 @@ static BOOL idmap_convert(const char *idmap_name)
|
||||
return False;
|
||||
#endif
|
||||
|
||||
bytereversed = (IREV(vers) == IDMAP_VERSION) ? True : False;
|
||||
|
||||
if ((vers == -1) || bytereversed) {
|
||||
if ((vers == -1) || (IREV(vers) == IDMAP_VERSION)) {
|
||||
/* Arrggghh ! Bytereversed or missing - make order independent ! */
|
||||
/*
|
||||
* If the header needed to be converted then the
|
||||
* high and low records may have been created on a
|
||||
* foreign endian machine and will need byte-reversing.
|
||||
*/
|
||||
|
||||
BOOL bytereverse_needed = (idmap_tdb->flags & TDB_CONVERT);
|
||||
int32 wm;
|
||||
|
||||
wm = tdb_fetch_int32(idmap_tdb, HWM_USER);
|
||||
|
||||
if (wm != -1 && bytereversed) {
|
||||
/* A record existed and it was from a big endian machine. */
|
||||
if (wm != -1 && bytereverse_needed) {
|
||||
/* A record existed and it was from a foreign endian machine. */
|
||||
wm = IREV(wm);
|
||||
} else if (wm == -1)
|
||||
wm = server_state.uid_low;
|
||||
@ -395,8 +399,8 @@ static BOOL idmap_convert(const char *idmap_name)
|
||||
}
|
||||
|
||||
wm = tdb_fetch_int32(idmap_tdb, HWM_GROUP);
|
||||
if (wm != -1 && bytereversed) {
|
||||
/* A record existed and it was from a big endian machine. */
|
||||
if (wm != -1 && bytereverse_needed) {
|
||||
/* A record existed and it was from a foreign endian machine. */
|
||||
wm = IREV(wm);
|
||||
} else if (wm == -1)
|
||||
wm = server_state.gid_low;
|
||||
|
Loading…
Reference in New Issue
Block a user