Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc
Commits
2aea85fb
Commit
2aea85fb
authored
Oct 20, 2011
by
KO Myung-Hun
Committed by
Rémi Denis-Courmont
Oct 20, 2011
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Implement cdrom tools to access audio/video CD on OS/2
Signed-off-by:
Rémi Denis-Courmont
<
remi@remlab.net
>
parent
eb5b1167
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
183 additions
and
3 deletions
+183
-3
configure.ac
configure.ac
+1
-1
modules/access/vcd/cdrom.c
modules/access/vcd/cdrom.c
+129
-2
modules/access/vcd/cdrom_internals.h
modules/access/vcd/cdrom_internals.h
+53
-0
No files found.
configure.ac
View file @
2aea85fb
...
@@ -2041,7 +2041,7 @@ then
...
@@ -2041,7 +2041,7 @@ then
AC_MSG_RESULT(no)
AC_MSG_RESULT(no)
])
])
if test "${SYS}" = "bsdi" -o "${SYS}" = "mingw32"
if test "${SYS}" = "bsdi" -o "${SYS}" = "mingw32"
-o "${SYS}" = "os2"
then
then
VLC_ADD_PLUGIN([vcd cdda])
VLC_ADD_PLUGIN([vcd cdda])
fi
fi
...
...
modules/access/vcd/cdrom.c
View file @
2aea85fb
...
@@ -30,6 +30,10 @@
...
@@ -30,6 +30,10 @@
# include "config.h"
# include "config.h"
#endif
#endif
#ifdef __OS2__
# define INCL_DOSDEVIOCTL
#endif
#include <vlc_common.h>
#include <vlc_common.h>
#include <vlc_access.h>
#include <vlc_access.h>
#include <vlc_charset.h>
#include <vlc_charset.h>
...
@@ -72,6 +76,8 @@
...
@@ -72,6 +76,8 @@
#elif defined (__linux__)
#elif defined (__linux__)
# include <sys/ioctl.h>
# include <sys/ioctl.h>
# include <linux/cdrom.h>
# include <linux/cdrom.h>
#elif defined( __OS2__ )
# include <os2.h>
#else
#else
# error FIXME
# error FIXME
#endif
#endif
...
@@ -88,7 +94,7 @@ vcddev_t *ioctl_Open( vlc_object_t *p_this, const char *psz_dev )
...
@@ -88,7 +94,7 @@ vcddev_t *ioctl_Open( vlc_object_t *p_this, const char *psz_dev )
int
i_ret
;
int
i_ret
;
int
b_is_file
;
int
b_is_file
;
vcddev_t
*
p_vcddev
;
vcddev_t
*
p_vcddev
;
#if
ndef WIN32
#if
!defined( WIN32 ) && !defined( __OS2__ )
struct
stat
fileinfo
;
struct
stat
fileinfo
;
#endif
#endif
...
@@ -107,7 +113,7 @@ vcddev_t *ioctl_Open( vlc_object_t *p_this, const char *psz_dev )
...
@@ -107,7 +113,7 @@ vcddev_t *ioctl_Open( vlc_object_t *p_this, const char *psz_dev )
/*
/*
* Check if we are dealing with a device or a file (vcd image)
* Check if we are dealing with a device or a file (vcd image)
*/
*/
#if
def WIN32
#if
defined( WIN32 ) || defined( __OS2__ )
if
(
(
strlen
(
psz_dev
)
==
2
&&
psz_dev
[
1
]
==
':'
)
)
if
(
(
strlen
(
psz_dev
)
==
2
&&
psz_dev
[
1
]
==
':'
)
)
{
{
b_is_file
=
0
;
b_is_file
=
0
;
...
@@ -137,6 +143,8 @@ vcddev_t *ioctl_Open( vlc_object_t *p_this, const char *psz_dev )
...
@@ -137,6 +143,8 @@ vcddev_t *ioctl_Open( vlc_object_t *p_this, const char *psz_dev )
#ifdef WIN32
#ifdef WIN32
i_ret
=
win32_vcd_open
(
p_this
,
psz_dev
,
p_vcddev
);
i_ret
=
win32_vcd_open
(
p_this
,
psz_dev
,
p_vcddev
);
#elif defined( __OS2__ )
i_ret
=
os2_vcd_open
(
p_this
,
psz_dev
,
p_vcddev
);
#else
#else
p_vcddev
->
i_device_handle
=
-
1
;
p_vcddev
->
i_device_handle
=
-
1
;
p_vcddev
->
i_device_handle
=
vlc_open
(
psz_dev
,
O_RDONLY
|
O_NONBLOCK
);
p_vcddev
->
i_device_handle
=
vlc_open
(
psz_dev
,
O_RDONLY
|
O_NONBLOCK
);
...
@@ -181,6 +189,9 @@ void ioctl_Close( vlc_object_t * p_this, vcddev_t *p_vcddev )
...
@@ -181,6 +189,9 @@ void ioctl_Close( vlc_object_t * p_this, vcddev_t *p_vcddev )
#ifdef WIN32
#ifdef WIN32
if
(
p_vcddev
->
h_device_handle
)
if
(
p_vcddev
->
h_device_handle
)
CloseHandle
(
p_vcddev
->
h_device_handle
);
CloseHandle
(
p_vcddev
->
h_device_handle
);
#elif defined( __OS2__ )
if
(
p_vcddev
->
hcd
)
DosClose
(
p_vcddev
->
hcd
);
#else
#else
if
(
p_vcddev
->
i_device_handle
!=
-
1
)
if
(
p_vcddev
->
i_device_handle
!=
-
1
)
close
(
p_vcddev
->
i_device_handle
);
close
(
p_vcddev
->
i_device_handle
);
...
@@ -312,6 +323,65 @@ int ioctl_GetTracksMap( vlc_object_t *p_this, const vcddev_t *p_vcddev,
...
@@ -312,6 +323,65 @@ int ioctl_GetTracksMap( vlc_object_t *p_this, const vcddev_t *p_vcddev,
}
}
}
}
#elif defined( __OS2__ )
cdrom_get_tochdr_t
get_tochdr
=
{{
'C'
,
'D'
,
'0'
,
'1'
}};
cdrom_tochdr_t
tochdr
;
ULONG
param_len
;
ULONG
data_len
;
ULONG
rc
;
rc
=
DosDevIOCtl
(
p_vcddev
->
hcd
,
IOCTL_CDROMAUDIO
,
CDROMAUDIO_GETAUDIODISK
,
&
get_tochdr
,
sizeof
(
get_tochdr
),
&
param_len
,
&
tochdr
,
sizeof
(
tochdr
),
&
data_len
);
if
(
rc
)
{
msg_Err
(
p_this
,
"could not read TOCHDR"
);
return
0
;
}
i_tracks
=
tochdr
.
last_track
-
tochdr
.
first_track
+
1
;
if
(
pp_sectors
)
{
cdrom_get_track_t
get_track
=
{{
'C'
,
'D'
,
'0'
,
'1'
},
};
cdrom_track_t
track
;
int
i
;
*
pp_sectors
=
calloc
(
i_tracks
+
1
,
sizeof
(
**
pp_sectors
)
);
if
(
*
pp_sectors
==
NULL
)
return
0
;
for
(
i
=
0
;
i
<
i_tracks
;
i
++
)
{
get_track
.
track
=
tochdr
.
first_track
+
i
;
rc
=
DosDevIOCtl
(
p_vcddev
->
hcd
,
IOCTL_CDROMAUDIO
,
CDROMAUDIO_GETAUDIOTRACK
,
&
get_track
,
sizeof
(
get_track
),
&
param_len
,
&
track
,
sizeof
(
track
),
&
data_len
);
if
(
rc
)
{
msg_Err
(
p_this
,
"could not read %d track"
,
get_track
.
track
);
return
0
;
}
(
*
pp_sectors
)[
i
]
=
MSF_TO_LBA2
(
track
.
start
.
minute
,
track
.
start
.
second
,
track
.
start
.
frame
);
msg_Dbg
(
p_this
,
"p_sectors: %i, %i"
,
i
,
(
*
pp_sectors
)[
i
]);
}
/* for lead-out track */
(
*
pp_sectors
)[
i
]
=
MSF_TO_LBA2
(
tochdr
.
lead_out
.
minute
,
tochdr
.
lead_out
.
second
,
tochdr
.
lead_out
.
frame
);
msg_Dbg
(
p_this
,
"p_sectors: %i, %i"
,
i
,
(
*
pp_sectors
)[
i
]);
}
#elif defined( HAVE_IOC_TOC_HEADER_IN_SYS_CDIO_H ) \
#elif defined( HAVE_IOC_TOC_HEADER_IN_SYS_CDIO_H ) \
|| defined( HAVE_SCSIREQ_IN_SYS_SCSIIO_H )
|| defined( HAVE_SCSIREQ_IN_SYS_SCSIIO_H )
struct
ioc_toc_header
tochdr
;
struct
ioc_toc_header
tochdr
;
...
@@ -508,6 +578,30 @@ int ioctl_ReadSectors( vlc_object_t *p_this, const vcddev_t *p_vcddev,
...
@@ -508,6 +578,30 @@ int ioctl_ReadSectors( vlc_object_t *p_this, const vcddev_t *p_vcddev,
else
return
-
1
;
else
return
-
1
;
}
}
#elif defined( __OS2__ )
cdrom_readlong_t
readlong
=
{{
'C'
,
'D'
,
'0'
,
'1'
},
};
ULONG
param_len
;
ULONG
data_len
;
ULONG
rc
;
readlong
.
addr_mode
=
0
;
/* LBA mode */
readlong
.
sectors
=
i_nb
;
readlong
.
start
=
i_sector
;
rc
=
DosDevIOCtl
(
p_vcddev
->
hcd
,
IOCTL_CDROMDISK
,
CDROMDISK_READLONG
,
&
readlong
,
sizeof
(
readlong
),
&
param_len
,
p_block
,
VCD_SECTOR_SIZE
*
i_nb
,
&
data_len
);
if
(
rc
)
{
msg_Err
(
p_this
,
"could not read block %d"
,
i_sector
);
if
(
i_type
==
VCD_TYPE
)
free
(
p_block
);
return
-
1
;
}
#elif defined( HAVE_SCSIREQ_IN_SYS_SCSIIO_H )
#elif defined( HAVE_SCSIREQ_IN_SYS_SCSIIO_H )
struct
scsireq
sc
;
struct
scsireq
sc
;
int
i_ret
;
int
i_ret
;
...
@@ -941,6 +1035,38 @@ static int win32_vcd_open( vlc_object_t * p_this, const char *psz_dev,
...
@@ -941,6 +1035,38 @@ static int win32_vcd_open( vlc_object_t * p_this, const char *psz_dev,
#endif
/* WIN32 */
#endif
/* WIN32 */
#ifdef __OS2__
/*****************************************************************************
* os2_vcd_open: open vcd drive
*****************************************************************************/
static
int
os2_vcd_open
(
vlc_object_t
*
p_this
,
const
char
*
psz_dev
,
vcddev_t
*
p_vcddev
)
{
char
device
[]
=
"X:"
;
HFILE
hcd
;
ULONG
i_action
;
ULONG
rc
;
p_vcddev
->
hcd
=
0
;
device
[
0
]
=
psz_dev
[
0
];
rc
=
DosOpen
(
device
,
&
hcd
,
&
i_action
,
0
,
FILE_NORMAL
,
OPEN_ACTION_OPEN_IF_EXISTS
|
OPEN_ACTION_FAIL_IF_NEW
,
OPEN_ACCESS_READONLY
|
OPEN_SHARE_DENYNONE
|
OPEN_FLAGS_DASD
,
NULL
);
if
(
rc
)
{
msg_Err
(
p_this
,
"could not open the device %s"
,
psz_dev
);
return
-
1
;
}
p_vcddev
->
hcd
=
hcd
;
return
0
;
}
#endif
/* */
/* */
static
void
astrcat
(
char
**
ppsz_dst
,
char
*
psz_src
)
static
void
astrcat
(
char
**
ppsz_dst
,
char
*
psz_src
)
{
{
...
@@ -1088,6 +1214,7 @@ exit:
...
@@ -1088,6 +1214,7 @@ exit:
}
}
#if defined( __APPLE__ ) || \
#if defined( __APPLE__ ) || \
defined( __OS2__ ) || \
defined( HAVE_IOC_TOC_HEADER_IN_SYS_CDIO_H ) || \
defined( HAVE_IOC_TOC_HEADER_IN_SYS_CDIO_H ) || \
defined( HAVE_SCSIREQ_IN_SYS_SCSIIO_H )
defined( HAVE_SCSIREQ_IN_SYS_SCSIIO_H )
static
int
CdTextRead
(
vlc_object_t
*
p_object
,
const
vcddev_t
*
p_vcddev
,
static
int
CdTextRead
(
vlc_object_t
*
p_object
,
const
vcddev_t
*
p_vcddev
,
...
...
modules/access/vcd/cdrom_internals.h
View file @
2aea85fb
...
@@ -38,6 +38,8 @@ struct vcddev_s
...
@@ -38,6 +38,8 @@ struct vcddev_s
#ifdef WIN32
#ifdef WIN32
HANDLE
h_device_handle
;
/* vcd device descriptor */
HANDLE
h_device_handle
;
/* vcd device descriptor */
#elif defined( __OS2__ )
HFILE
hcd
;
/* vcd device descriptor */
#else
#else
int
i_device_handle
;
/* vcd device descriptor */
int
i_device_handle
;
/* vcd device descriptor */
#endif
#endif
...
@@ -127,6 +129,54 @@ typedef struct _CDROM_READ_TOC_EX {
...
@@ -127,6 +129,54 @@ typedef struct _CDROM_READ_TOC_EX {
#endif
/* WIN32 */
#endif
/* WIN32 */
#ifdef __OS2__
#pragma pack( push, 1 )
typedef
struct
os2_msf_s
{
unsigned
char
frame
;
unsigned
char
second
;
unsigned
char
minute
;
unsigned
char
reserved
;
}
os2_msf_t
;
typedef
struct
cdrom_get_tochdr_s
{
unsigned
char
sign
[
4
];
}
cdrom_get_tochdr_t
;
typedef
struct
cdrom_tochdr_s
{
unsigned
char
first_track
;
unsigned
char
last_track
;
os2_msf_t
lead_out
;
}
cdrom_tochdr_t
;
typedef
struct
cdrom_get_track_s
{
unsigned
char
sign
[
4
];
unsigned
char
track
;
}
cdrom_get_track_t
;
typedef
struct
cdrom_track_s
{
os2_msf_t
start
;
unsigned
char
adr
:
4
;
unsigned
char
control
:
4
;
}
cdrom_track_t
;
typedef
struct
cdrom_readlong_s
{
unsigned
char
sign
[
4
];
unsigned
char
addr_mode
;
unsigned
short
sectors
;
unsigned
long
start
;
unsigned
char
reserved
;
unsigned
char
interleaved_size
;
}
cdrom_readlong_t
;
#pragma pack( pop )
#endif
#define SECTOR_TYPE_MODE2_FORM2 0x14
#define SECTOR_TYPE_MODE2_FORM2 0x14
#define SECTOR_TYPE_CDDA 0x04
#define SECTOR_TYPE_CDDA 0x04
#define READ_CD_RAW_MODE2 0xF0
#define READ_CD_RAW_MODE2 0xF0
...
@@ -144,4 +194,7 @@ static int darwin_getNumberOfTracks( CDTOC *, int );
...
@@ -144,4 +194,7 @@ static int darwin_getNumberOfTracks( CDTOC *, int );
#elif defined( WIN32 )
#elif defined( WIN32 )
static
int
win32_vcd_open
(
vlc_object_t
*
,
const
char
*
,
struct
vcddev_s
*
);
static
int
win32_vcd_open
(
vlc_object_t
*
,
const
char
*
,
struct
vcddev_s
*
);
#elif defined( __OS2__ )
static
int
os2_vcd_open
(
vlc_object_t
*
,
const
char
*
,
struct
vcddev_s
*
);
#endif
#endif
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment