diff options
Diffstat (limited to 'drivers/cdrom')
-rw-r--r-- | drivers/cdrom/cdrom.c | 94 |
1 files changed, 47 insertions, 47 deletions
diff --git a/drivers/cdrom/cdrom.c b/drivers/cdrom/cdrom.c index 8888ed3a8d4f..f614847aad8f 100644 --- a/drivers/cdrom/cdrom.c +++ b/drivers/cdrom/cdrom.c | |||
@@ -338,8 +338,6 @@ do { \ | |||
338 | 338 | ||
339 | /* Not-exported routines. */ | 339 | /* Not-exported routines. */ |
340 | 340 | ||
341 | static void cdrom_count_tracks(struct cdrom_device_info *, tracktype*); | ||
342 | |||
343 | static int cdrom_mrw_exit(struct cdrom_device_info *cdi); | 341 | static int cdrom_mrw_exit(struct cdrom_device_info *cdi); |
344 | 342 | ||
345 | static int cdrom_get_disc_info(struct cdrom_device_info *cdi, disc_information *di); | 343 | static int cdrom_get_disc_info(struct cdrom_device_info *cdi, disc_information *di); |
@@ -948,6 +946,53 @@ static int cdrom_close_write(struct cdrom_device_info *cdi) | |||
948 | #endif | 946 | #endif |
949 | } | 947 | } |
950 | 948 | ||
949 | /* badly broken, I know. Is due for a fixup anytime. */ | ||
950 | static void cdrom_count_tracks(struct cdrom_device_info *cdi, tracktype *tracks) | ||
951 | { | ||
952 | struct cdrom_tochdr header; | ||
953 | struct cdrom_tocentry entry; | ||
954 | int ret, i; | ||
955 | tracks->data = 0; | ||
956 | tracks->audio = 0; | ||
957 | tracks->cdi = 0; | ||
958 | tracks->xa = 0; | ||
959 | tracks->error = 0; | ||
960 | cd_dbg(CD_COUNT_TRACKS, "entering cdrom_count_tracks\n"); | ||
961 | /* Grab the TOC header so we can see how many tracks there are */ | ||
962 | ret = cdi->ops->audio_ioctl(cdi, CDROMREADTOCHDR, &header); | ||
963 | if (ret) { | ||
964 | if (ret == -ENOMEDIUM) | ||
965 | tracks->error = CDS_NO_DISC; | ||
966 | else | ||
967 | tracks->error = CDS_NO_INFO; | ||
968 | return; | ||
969 | } | ||
970 | /* check what type of tracks are on this disc */ | ||
971 | entry.cdte_format = CDROM_MSF; | ||
972 | for (i = header.cdth_trk0; i <= header.cdth_trk1; i++) { | ||
973 | entry.cdte_track = i; | ||
974 | if (cdi->ops->audio_ioctl(cdi, CDROMREADTOCENTRY, &entry)) { | ||
975 | tracks->error = CDS_NO_INFO; | ||
976 | return; | ||
977 | } | ||
978 | if (entry.cdte_ctrl & CDROM_DATA_TRACK) { | ||
979 | if (entry.cdte_format == 0x10) | ||
980 | tracks->cdi++; | ||
981 | else if (entry.cdte_format == 0x20) | ||
982 | tracks->xa++; | ||
983 | else | ||
984 | tracks->data++; | ||
985 | } else { | ||
986 | tracks->audio++; | ||
987 | } | ||
988 | cd_dbg(CD_COUNT_TRACKS, "track %d: format=%d, ctrl=%d\n", | ||
989 | i, entry.cdte_format, entry.cdte_ctrl); | ||
990 | } | ||
991 | cd_dbg(CD_COUNT_TRACKS, "disc has %d tracks: %d=audio %d=data %d=Cd-I %d=XA\n", | ||
992 | header.cdth_trk1, tracks->audio, tracks->data, | ||
993 | tracks->cdi, tracks->xa); | ||
994 | } | ||
995 | |||
951 | static | 996 | static |
952 | int open_for_data(struct cdrom_device_info *cdi) | 997 | int open_for_data(struct cdrom_device_info *cdi) |
953 | { | 998 | { |
@@ -1457,51 +1502,6 @@ int cdrom_media_changed(struct cdrom_device_info *cdi) | |||
1457 | return media_changed(cdi, 0); | 1502 | return media_changed(cdi, 0); |
1458 | } | 1503 | } |
1459 | 1504 | ||
1460 | /* badly broken, I know. Is due for a fixup anytime. */ | ||
1461 | static void cdrom_count_tracks(struct cdrom_device_info *cdi, tracktype* tracks) | ||
1462 | { | ||
1463 | struct cdrom_tochdr header; | ||
1464 | struct cdrom_tocentry entry; | ||
1465 | int ret, i; | ||
1466 | tracks->data=0; | ||
1467 | tracks->audio=0; | ||
1468 | tracks->cdi=0; | ||
1469 | tracks->xa=0; | ||
1470 | tracks->error=0; | ||
1471 | cd_dbg(CD_COUNT_TRACKS, "entering cdrom_count_tracks\n"); | ||
1472 | /* Grab the TOC header so we can see how many tracks there are */ | ||
1473 | if ((ret = cdi->ops->audio_ioctl(cdi, CDROMREADTOCHDR, &header))) { | ||
1474 | if (ret == -ENOMEDIUM) | ||
1475 | tracks->error = CDS_NO_DISC; | ||
1476 | else | ||
1477 | tracks->error = CDS_NO_INFO; | ||
1478 | return; | ||
1479 | } | ||
1480 | /* check what type of tracks are on this disc */ | ||
1481 | entry.cdte_format = CDROM_MSF; | ||
1482 | for (i = header.cdth_trk0; i <= header.cdth_trk1; i++) { | ||
1483 | entry.cdte_track = i; | ||
1484 | if (cdi->ops->audio_ioctl(cdi, CDROMREADTOCENTRY, &entry)) { | ||
1485 | tracks->error=CDS_NO_INFO; | ||
1486 | return; | ||
1487 | } | ||
1488 | if (entry.cdte_ctrl & CDROM_DATA_TRACK) { | ||
1489 | if (entry.cdte_format == 0x10) | ||
1490 | tracks->cdi++; | ||
1491 | else if (entry.cdte_format == 0x20) | ||
1492 | tracks->xa++; | ||
1493 | else | ||
1494 | tracks->data++; | ||
1495 | } else | ||
1496 | tracks->audio++; | ||
1497 | cd_dbg(CD_COUNT_TRACKS, "track %d: format=%d, ctrl=%d\n", | ||
1498 | i, entry.cdte_format, entry.cdte_ctrl); | ||
1499 | } | ||
1500 | cd_dbg(CD_COUNT_TRACKS, "disc has %d tracks: %d=audio %d=data %d=Cd-I %d=XA\n", | ||
1501 | header.cdth_trk1, tracks->audio, tracks->data, | ||
1502 | tracks->cdi, tracks->xa); | ||
1503 | } | ||
1504 | |||
1505 | /* Requests to the low-level drivers will /always/ be done in the | 1505 | /* Requests to the low-level drivers will /always/ be done in the |
1506 | following format convention: | 1506 | following format convention: |
1507 | 1507 | ||