Tillbaka till svenska Fidonet
English   Information   Debug  
OCCULT_CHAT   0/93
OS2BBS   0/787
OS2DOSBBS   0/580
OS2HW   0/42
OS2INET   0/37
OS2LAN   0/134
OS2PROG   0/36
OS2REXX   0/113
OS2USER-L   207
OS2   998/4786
OSDEBATE   0/18996
PASCAL   0/490
PERL   0/457
PHP   0/45
POINTS   0/405
POLITICS   0/29554
POL_INC   0/14731
PSION   103
R20_ADMIN   1121
R20_AMATORRADIO   0/2
R20_BEST_OF_FIDONET   13
R20_CHAT   0/893
R20_DEPP   0/3
R20_DEV   399
R20_ECHO2   1379
R20_ECHOPRES   0/35
R20_ESTAT   0/719
R20_FIDONETPROG...
...RAM.MYPOINT
  0/2
R20_FIDONETPROGRAM   0/22
R20_FIDONET   0/248
R20_FILEFIND   0/24
R20_FILEFOUND   0/22
R20_HIFI   0/3
R20_INFO2   3205
R20_INTERNET   0/12940
R20_INTRESSE   0/60
R20_INTR_KOM   0/99
R20_KANDIDAT.CHAT   42
R20_KANDIDAT   28
R20_KOM_DEV   112
R20_KONTROLL   0/13258
R20_KORSET   0/18
R20_LOKALTRAFIK   0/24
R20_MODERATOR   0/1852
R20_NC   76
R20_NET200   245
R20_NETWORK.OTH...
...ERNETS
  0/13
R20_OPERATIVSYS...
...TEM.LINUX
  0/44
R20_PROGRAMVAROR   0/1
R20_REC2NEC   534
R20_SFOSM   0/340
R20_SF   0/108
R20_SPRAK.ENGLISH   0/1
R20_SQUISH   107
R20_TEST   2
R20_WORST_OF_FIDONET   12
RAR   0/9
RA_MULTI   106
RA_UTIL   0/162
REGCON.EUR   0/2056
REGCON   0/13
SCIENCE   0/1206
SF   0/239
SHAREWARE_SUPPORT   0/5146
SHAREWRE   0/14
SIMPSONS   0/169
STATS_OLD1   0/2539.065
STATS_OLD2   0/2530
STATS_OLD3   0/2395.095
STATS_OLD4   0/1692.25
SURVIVOR   0/495
SYSOPS_CORNER   0/3
SYSOP   0/84
TAGLINES   0/112
TEAMOS2   0/4530
TECH   0/2617
TEST.444   0/105
TRAPDOOR   0/19
TREK   0/755
TUB   0/290
UFO   0/40
UNIX   0/1316
USA_EURLINK   0/102
USR_MODEMS   0/1
VATICAN   0/2740
VIETNAM_VETS   0/14
VIRUS   0/378
VIRUS_INFO   0/201
VISUAL_BASIC   0/473
WHITEHOUSE   0/5187
WIN2000   0/101
WIN32   0/30
WIN95   0/4288
WIN95_OLD1   0/70272
WINDOWS   0/1517
WWB_SYSOP   0/419
WWB_TECH   0/810
ZCC-PUBLIC   0/1
ZEC   4

 
4DOS   0/134
ABORTION   0/7
ALASKA_CHAT   0/506
ALLFIX_FILE   0/1313
ALLFIX_FILE_OLD1   0/7997
ALT_DOS   0/152
AMATEUR_RADIO   0/1039
AMIGASALE   0/14
AMIGA   0/331
AMIGA_INT   0/1
AMIGA_PROG   0/20
AMIGA_SYSOP   0/26
ANIME   0/15
ARGUS   0/924
ASCII_ART   0/340
ASIAN_LINK   0/651
ASTRONOMY   0/417
AUDIO   0/92
AUTOMOBILE_RACING   0/105
BABYLON5   0/17862
BAG   135
BATPOWER   0/361
BBBS.ENGLISH   0/382
BBSLAW   0/109
BBS_ADS   0/5290
BBS_INTERNET   0/507
BIBLE   0/3563
BINKD   0/1119
BINKLEY   0/215
BLUEWAVE   0/2173
CABLE_MODEMS   0/25
CBM   0/46
CDRECORD   0/66
CDROM   0/20
CLASSIC_COMPUTER   0/378
COMICS   0/15
CONSPRCY   0/899
COOKING   32677
COOKING_OLD1   0/24719
COOKING_OLD2   0/40862
COOKING_OLD3   0/37489
COOKING_OLD4   0/35496
COOKING_OLD5   9370
C_ECHO   0/189
C_PLUSPLUS   0/31
DIRTY_DOZEN   0/201
DOORGAMES   0/2053
DOS_INTERNET   0/196
duplikat   6002
ECHOLIST   0/18295
EC_SUPPORT   0/318
ELECTRONICS   0/359
ELEKTRONIK.GER   1534
ENET.LINGUISTIC   0/13
ENET.POLITICS   0/4
ENET.SOFT   0/11701
ENET.SYSOP   33888
ENET.TALKS   0/32
ENGLISH_TUTOR   0/2000
EVOLUTION   0/1335
FDECHO   0/217
FDN_ANNOUNCE   0/7068
FIDONEWS   24094
FIDONEWS_OLD1   0/49742
FIDONEWS_OLD2   0/35949
FIDONEWS_OLD3   0/30874
FIDONEWS_OLD4   0/37224
FIDO_SYSOP   12852
FIDO_UTIL   0/180
FILEFIND   0/209
FILEGATE   0/212
FILM   0/18
FNEWS_PUBLISH   4393
FN_SYSOP   41678
FN_SYSOP_OLD1   71952
FTP_FIDO   0/2
FTSC_PUBLIC   0/13598
FUNNY   0/4886
GENEALOGY.EUR   0/71
GET_INFO   105
GOLDED   0/408
HAM   0/16069
HOLYSMOKE   0/6791
HOT_SITES   0/1
HTMLEDIT   0/71
HUB203   466
HUB_100   264
HUB_400   39
HUMOR   0/29
IC   0/2851
INTERNET   0/424
INTERUSER   0/3
IP_CONNECT   719
JAMNNTPD   0/233
JAMTLAND   0/47
KATTY_KORNER   0/41
LAN   0/16
LINUX-USER   0/19
LINUXHELP   0/1155
LINUX   0/22090
LINUX_BBS   0/957
mail   18.68
mail_fore_ok   249
MENSA   0/341
MODERATOR   0/102
MONTE   0/992
MOSCOW_OKLAHOMA   0/1245
MUFFIN   0/783
MUSIC   0/321
N203_STAT   924
N203_SYSCHAT   313
NET203   321
NET204   69
NET_DEV   0/10
NORD.ADMIN   0/101
NORD.CHAT   0/2572
NORD.FIDONET   189
NORD.HARDWARE   0/28
NORD.KULTUR   0/114
NORD.PROG   0/32
NORD.SOFTWARE   0/88
NORD.TEKNIK   0/58
NORD   0/453
Möte OS2, 4786 texter
 lista första sista föregående nästa
Text 2584, 151 rader
Skriven 2011-04-02 15:16:45 av Jonathan de Boyne Pollard
Ärende: Re: formatting to FAT32
===============================
Gecko/20110303 Thunderbird/3.1.9
comp.os.os2.beta,comp.os.os2.utilities,comp.os.os2.programmer.misc,comp.os.os2.misc

UTC)
comp.os.os2.utilities:156 comp.os.os2.programmer.misc:2071
comp.os.os2.misc:3118
From: Jonathan de Boyne Pollard <J.deBoynePollard-newsgroups@NTLWorld.COM>

 These bugs have been known for years, as you can see on the data of 
> the msgs. Doesn't look like anyone has been working on it.
>
Well M. Ko has the ability to modify, recompile, and use FAT32.IFS, so 
let's introduce FS_CHGFILEPTRL and see whether it fixes the problem M. 
Ko stated that xe didn't know why this was happening. Here's a 
hypothesis that seems reasonable. The data that we have are these:

* Raw access with DosRead/DosWrite/DosSetFilePtr works just fine on your 
~4GiB FAT32 volume.
* DosSetFilePtr() returns ERROR_SEEK on larger FAT32 volumes.
* M. Ko reports that the FS_CHGFILEPTR function of the IFS isn't even 
being called in such circumstances.

The thing to remember, to start with, is that the whole "sector mode" 
thing is a red herring. That's purely within the IFS driver itself. The 
kernel knows nothing of it. As far as the kernel is concerned raw access 
is *always* byte-by-byte and offsets are byte offsets. Once one gets 
one's head around that, then a hypothesis positively leaps out. The OS/2 
version 4.5 kernel, remember, has 64-bit file pointer support. So it's a 
fair chance that what's happening is that the kernel is saying "Oho! The 
application is trying to move the file pointer about, and this disc 
volume is larger than 4GiB. So I'll use 64-bit file pointer 
mechanisms.". The problem in such a circumstance is that FAT32.IFS 
doesn't have a FS_CHGFILEPTRL entrypoint. The kernel sees a non-existent 
entrypoint, and rather than falling back to the 32-bit one it simply 
returns ERROR_SEEK.

By the way, in answer to the other question that came up all those years 
ago: If you look at the VirtualBox shared folders OS/2 IFS driver 
skeleton code, you'll see three out of four entrypoints complete with 
function signatures. The four entrypoints are thus FS_CHGFILEPTR, 
FS_CHGFILEPTRL, FS32_CHGFILEPTR, and FS32_CHGFILEPTRL. The entrypoints 
ending in "L" take a 64-bit file offset value instead of a 32-bit one, 
and the entrypoints beginning "FS32_" are 32-bit functions instead of 
16-bit ones.

If this hypothesis is correct — and it's a fairly credible one — then 
giving the kernel an actual "L" entrypoint to call when it wants to seek 
around within a >4GiB volume will stop the ERROR_SEEKs. Making such a 
function is dead easy. Just copy FS_CHGFILEPTRL, change the lOffset 
parameter to a 64-bit signed integer, and (for now) add a check on the 
desired to position to ensure that it is less than 0x1_0000_0000. Then 
set the FSA_LARGEFILE attribute. This might necessitate doing 
FS_NEWSIZEL, FS_CANCELLOCKREQUESTL, and FS_FILELOCKSL, as well; but the 
same approach applies. Indeed, one could *rename* the non-"L" functions 
to the "L" functions and then make the non-"L" functions into wrappers 
that call the "L" functions. Something like the code at the end of this 
message, which is off the top of my head, perhaps. (I suggest that those 
with JFS source code access check what SFFSI structure is passed to an 
"L" function.)

M. Ko has the ability to modify, recompile, and use FAT32.IFS, and you 
apparently have JFS source code access. If xe does that, and you check 
the SFFSI structure, I can supply CHKVOL to test against a >4GiB volume.

int far pascal FS_CHGFILEPTRL(
     struct sffsi far * psffsi,		/* psffsi	*/
     struct sffsd far * psffsd,		/* psffsd	*/
     LONGLONG lOffset,			/* offset	*/
     unsigned short usType,		/* type		*/
     unsigned short IOFlag		/* IOflag	*/
)
{
PVOLINFO pVolInfo;
POPENINFO pOpenInfo = GetOpenInfo(psffsd);
LONGLONG  lNewOffset;
USHORT rc;

    if (f32Parms.fMessageActive&  LOG_FS)
       Message("FS_CHGFILEPTRL, Mode %d - offset %lld, current offset=%lu",
       usType, lOffset, psffsi->sfi_position);

    pVolInfo = GetVolInfo(psffsi->sfi_hVPB);
    if (IsDriveLocked(pVolInfo))
       return ERROR_DRIVE_LOCKED;

    switch (usType)
       {
       case CFP_RELBEGIN :
          if (lOffset<  0)
             {
             rc = ERROR_NEGATIVE_SEEK;
             goto FS_CHGFILEPTRLEXIT;
             }
          lNewOffset = lOffset;
          break;
       case CFP_RELCUR  :
          lNewOffset = psffsi->sfi_position + lOffset;
          break;
       case CFP_RELEND	:
          lNewOffset = psffsi->sfi_size + lOffset;
          break;
       }
    if (!IsDosSession()&&  lNewOffset<  0)
       {
       rc = ERROR_NEGATIVE_SEEK;
       goto FS_CHGFILEPTRLEXIT;
       }
    /* This ensures that all positions are in the first 4GiB, preserving
       the semantics of 32-bit file pointers.  Of course, with true large
       file support, this test is unnecessary and wrong.  But we're not
       setting out to do that at the moment.  */
    if (lNewOffset>  (ULONGLONG)0xFFFFFFFF)
       {
       rc = ERROR_NEGATIVE_SEEK;
       goto FS_CHGFILEPTRLEXIT;
       }

    /* Yes, we're casting to a ULONGLONG and then assigning into a ULONG.
       This is so that we don't have to revisit this down the line.  */
    if (psffsi->sfi_position != (ULONGLONG)lNewOffset)
       {
       psffsi->sfi_position = (ULONGLONG)lNewOffset;
       pOpenInfo->ulCurCluster = FAT_EOF;
       }
    rc = 0;

FS_CHGFILEPTRLEXIT:
    if (f32Parms.fMessageActive&  LOG_FS)
       Message("FS_CHGFILEPTRL returned %u", rc);
    return rc;
}

int far pascal FS_CHGFILEPTR(
     struct sffsi far * psffsi,		/* psffsi	*/
     struct sffsd far * psffsd,		/* psffsd	*/
     LONG lOffset,			/* offset	*/
     unsigned short usType,		/* type		*/
     unsigned short IOFlag		/* IOflag	*/
)
{
     /* The 32-bit function simply devolves to the 64-bit one.
        If the SFFFSI structures differ, we might not be able to
        do things this simply, and might have to cut and paste
        instead.  */
     return FS_CHGFILEPTRL(psffsi, psffsd, lOffset, usType, IOFlag);
}



--- Internet Rex 2.31
 * Origin: virginmedia.com (1:261/20.999)