Welcome to the OS390::Stdio module.
In order to build this extension to perl you must get
the gzipped tape archive over to OS/390 or z/OS (you could ftp in binary mode,
or you could cp over an nfs mount with no XLAT parameter set, or you
could OPUT the file, or ... ).
In summary the steps you then need to execute are:
gunzip OS390-Stdio-0.008.tar.gz
pax -ofrom=ISO8859-1,to=IBM-1047 -rf OS390-Stdio-0.008.tar
cd OS390-Stdio-0.008
perl Makefile.PL
make
make test
make install
If your perl is built to only allow static linking (as is common on OS/390
or z/OS) then be sure to also run:
make inst_perl
In more detail each of the above steps are:
Unpack the ASCII source code archive (the gunzip can be done on a non
OE/USS machine if necessary, in which case you'd ftp over the *.tar file
in binary mode, but only if you do not have gunzip installed on the
mainframe):
gunzip OS390-Stdio-0.008.tar.gz
From the OE/USS shell unpack the archive specifying that you want
an ASCII -> EBCDIC conversion to take place:
pax -ofrom=ISO8859-1,to=IBM-1047 -rf OS390-Stdio-0.008.tar
which might also have been executed as:
pax -o to=IBM-1047,from=ISO8859-1 -r < OS390-Stdio-0.008.tar
then configure and build (see `perldoc ExtUtils::MakeMaker` for more
information on building staticially linked perl extensions and other
options to pass to perl on the `perl Makefile.PL` step, as well as
the section "Build tips" below for more info):
cd OS390-Stdio-0.008
perl Makefile.PL [-DNO_WARN_IF_NOT_PDS]
make
That is, on the second step there you could run either:
perl Makefile.PL
or you could run:
perl Makefile.PL -DNO_WARN_IF_NOT_PDS
just before running make.
(optional) now make a static perl binary:
make perl
now run the regression test:
make test
(see also the section "Regression testing tips" below for more info).
If things look "OK" then install (this may require UID=0 or simply
write privileges to the appropriate directories):
make install
(optional) install the statically linked rebuild perl binary:
make inst_perl
"Documentation"
---------------
Documentation is within Stdio.pm and should be available with:
perldoc OS390::Stdio
There are also examples of working data set handling code in test.pl,
as well as in stdio_cookbook.pod and pds_test. This latter program can
be run after `make test` and it will prompt you for some valid data
set names.
You can find the gzip and gunzip programs as well as GNU make at:
"Build tips"
------------
I've had no luck with versions of perl prior to 5.005_02. Hence I
would recommend that you try that or preferrably an even later
version of perl. I've also noted that the build works just fine
on these:
$ uname -v -r
07.00 02
$ uname -v -r
10.00 02
I've also noted that the build worked fine for V0.003 of this
extension on these:
$ uname -v -r
05.00 02
$ uname -v -r
06.00 02
But this extension has trouble with __dyninit_t and fldata_t
structs on:
$ uname -v -r
03.00 01
I'd be happy to resolve those build problems with someone - send
me a unified or context diff of the changes you had to make. Thanks.
Also, I might like to rename this module to ???::Stdio (that is,
zOS::Stdio, S390::Stdio, zSeries::Stdio ???) if possible or necessary.
As far as I know the C runtime extensions that this perl extension exploits are
also available on VSE/ESA and VM/CMS (I have been informed that they
are not available under BS2000/POSIX-BC, and I doubt they are available
under any non-mainframe OS). Of course I would be willing to rename
mvsopen() and mvswrite() if such generalization proves feasible (I'd consider
s390open() and s390write() if they didn't have a soon-to-expire
timestamp in them, perhaps zseriesopen() and zserieswrite()?). Any help
with such a project would be greatly appreciated since I do not have
routine access to VSE or VM (and have also lost access to OS/390 and z/OS).
Thank you.
"Regression testing tips"
-------------------------
I no longer have access to z/OS, but I have received a report that
when this extension is built under a dynamic loading Perl 5.8.0 for
z/OS 1.2 that the following test anomalies/failures appear during
the run of `make test`:
ok 151
dynalloc() failed with error code 9700, info code 50 at test.pl line 535.
not ok 152
ok 153
ok 156
dynfree() failed with error code 438, info code 50 at test.pl line 567.
not ok 157
ok 158
svc99() failed with error code 484, info code 0 at test.pl line 617.
not ok 159
ok 160
I would appreciate any help anyone could offer in assisting with the
effort to track down and reproduce those test failures.
In general, in order to see more of what the regression tests are doing
when they run look for the %ENV varaibles to set, set them, then re-run
the `make test` suite.
e.g.:
$ grep ENV test.pl
my $DIAG = $ENV{'OS390_STDIO_DIAG'};
my $GORY = $ENV{'OS390_STDIO_GORY'};
So in order to see diagnostics but not gory details I run:
$ export OS390_STDIO_DIAG='1'
$ make test
Any time after the `make perl` or `make test` step it should be posible to run
the pds_test test via:
./pds_test
Then answer the questions that arise. The pds_test script will ask for
a PDS name and a non-PDS data set name, and will attempt to read
the DCB and MEMBER list from each as a means of testing pds_mem().
See also the comments at the head of pds_test for other tips on
running it.
There is also an smf_test program for testing the smf_record()
routine on systems that have SMF running (and whose SMF.BPX facility
allows a perl program to write to SMF).
Please see the stdio_cookbook.pod document for recipes
on how to use OS390::Stdio.
By the way, you now have the option of passing data set names (e.g. partial
names) to the get_dcb() and getname() routines in addition to still
being able to pass mvsopen() file handles.
##################################################################
Special notes for release 0.008:
--------------------------------
Some XS modifications were done to Stdio.xs so that this extension
should compile under either Perl 5.6.1 (a version where Perl uses stdio)
or Perl 5.8.0 (Perl defaults to PerlIO) on z/OS.
Very big thanks Brad Van Duser and Nick Ing-Simmons.
TODO:
Fix the test failures reported on z/OS 1.2 with dynaloading Perl 5.8.0.
None of the catalog/VTOC dslist functions (vol_ser dsname_level) work.
I am beginning to suspect that I may need to use either an ISPF callable
interface (ISPEXEC,) or perhaps assembler calls to either DADSM LOCATE or
perhaps CVAFFILT and CVAFTST && CVAFSEQ layered in via
C<#pragma linkage(CVAF*,OS)>. Help with such programming tasks would be
appreciated (I wonder why it is that a routine was not put into the C
run-time library? :-).
None of the vsam routines [locate() update() delrec()] have been
tested at all. Any volunteers to write tests?
##################################################################
See the Changes file for older information.
Peter Prymmer