summaryrefslogtreecommitdiff
path: root/libopie2/opiecore/device/odevice_zaurus.cpp
Unidiff
Diffstat (limited to 'libopie2/opiecore/device/odevice_zaurus.cpp') (more/less context) (show whitespace changes)
-rw-r--r--libopie2/opiecore/device/odevice_zaurus.cpp33
1 files changed, 9 insertions, 24 deletions
diff --git a/libopie2/opiecore/device/odevice_zaurus.cpp b/libopie2/opiecore/device/odevice_zaurus.cpp
index d3ab63a..b22ee70 100644
--- a/libopie2/opiecore/device/odevice_zaurus.cpp
+++ b/libopie2/opiecore/device/odevice_zaurus.cpp
@@ -543,24 +543,16 @@ Transformation Zaurus::rotation() const
543 int handle = 0; 543 int handle = 0;
544 int retval = 0; 544 int retval = 0;
545 545
546 switch ( d->m_model ) { 546 switch ( d->m_model ) {
547 case Model_Zaurus_SLC3000: // fallthrough 547 case Model_Zaurus_SLC3000: // fallthrough
548 case Model_Zaurus_SLC7x0: 548 case Model_Zaurus_SLC7x0:
549 handle = ::open("/dev/apm_bios", O_RDWR|O_NONBLOCK); 549 OHingeStatus hs = readHingeSensor();
550 if (handle == -1) { 550 if ( hs == CASE_PORTRAIT ) rot = Rot0;
551 return Rot270; 551 else if ( hs == CASE_UNKNOWN ) rot = Rot0;
552 } else { 552 else rot = Rot270;
553 retval = ::ioctl(handle, SHARP_IOCTL_GET_ROTATION);
554 ::close (handle);
555
556 if (retval == 2 )
557 rot = Rot0;
558 else
559 rot = Rot270;
560 }
561 break; 553 break;
562 case Model_Zaurus_SL6000: 554 case Model_Zaurus_SL6000:
563 case Model_Zaurus_SLB600: 555 case Model_Zaurus_SLB600:
564 case Model_Zaurus_SLA300: 556 case Model_Zaurus_SLA300:
565 case Model_Zaurus_SL5500: 557 case Model_Zaurus_SL5500:
566 case Model_Zaurus_SL5000: 558 case Model_Zaurus_SL5000:
@@ -576,23 +568,16 @@ ODirection Zaurus::direction() const
576 ODirection dir; 568 ODirection dir;
577 int handle = 0; 569 int handle = 0;
578 int retval = 0; 570 int retval = 0;
579 switch ( d->m_model ) { 571 switch ( d->m_model ) {
580 case Model_Zaurus_SLC3000: // fallthrough 572 case Model_Zaurus_SLC3000: // fallthrough
581 case Model_Zaurus_SLC7x0: 573 case Model_Zaurus_SLC7x0:
582 handle = ::open( "/dev/apm_bios", O_RDWR|O_NONBLOCK ); 574 OHingeStatus hs = readHingeSensor();
583 if (handle == -1) { 575 if ( hs == CASE_PORTRAIT ) dir = CCW;
584 dir = CW; 576 else if ( hs == CASE_UNKNOWN ) dir = CCW;
585 } else { 577 else dir = CW;
586 retval = ::ioctl( handle, SHARP_IOCTL_GET_ROTATION );
587 ::close (handle);
588 if (retval == 2 )
589 dir = CCW;
590 else
591 dir = CW;
592 }
593 break; 578 break;
594 case Model_Zaurus_SL6000: 579 case Model_Zaurus_SL6000:
595 case Model_Zaurus_SLA300: 580 case Model_Zaurus_SLA300:
596 case Model_Zaurus_SLB600: 581 case Model_Zaurus_SLB600:
597 case Model_Zaurus_SL5500: 582 case Model_Zaurus_SL5500:
598 case Model_Zaurus_SL5000: 583 case Model_Zaurus_SL5000:
@@ -605,13 +590,13 @@ ODirection Zaurus::direction() const
605 590
606bool Zaurus::hasHingeSensor() const 591bool Zaurus::hasHingeSensor() const
607{ 592{
608 return d->m_model == Model_Zaurus_SLC7x0 || d->m_model == Model_Zaurus_SLC3000; 593 return d->m_model == Model_Zaurus_SLC7x0 || d->m_model == Model_Zaurus_SLC3000;
609} 594}
610 595
611OHingeStatus Zaurus::readHingeSensor() 596OHingeStatus Zaurus::readHingeSensor() const
612{ 597{
613 if (m_embedix) 598 if (m_embedix)
614 { 599 {
615 int handle = ::open("/dev/apm_bios", O_RDWR|O_NONBLOCK); 600 int handle = ::open("/dev/apm_bios", O_RDWR|O_NONBLOCK);
616 if (handle == -1) 601 if (handle == -1)
617 { 602 {