Home | History | Annotate | only in /frameworks/opt/telephony
Up to higher level directory
NameDateSize
Android.mk06-Dec-20161.6K
CleanSpec.mk06-Dec-20163K
jarjar-rules.txt06-Dec-201673
proto/06-Dec-2016
README.txt06-Dec-20162.6K
src/06-Dec-2016
tests/06-Dec-2016
tools/06-Dec-2016

README.txt

      1 This package contains classes used to manage a DataConnection.
      2 
      3 A criticial aspect of this class is that most objects in this
      4 package run on the same thread except DataConnectionTracker
      5 This makes processing efficient as it minimizes context
      6 switching and it eliminates issues with multi-threading.
      7 
      8 This can be done because all actions are either asynchronous
      9 or are known to be non-blocking and fast. At this time only
     10 DcTesterDeactivateAll takes specific advantage of this
     11 single threading knowledge by using Dcc#mDcListAll so be
     12 very careful when making changes that break this assumption.
     13 
     14 A related change was in DataConnectionAc I added code that
     15 checks to see if the caller is on a different thread. If
     16 it is then the AsyncChannel#sendMessageSynchronously is
     17 used. If the caller is on the same thread then a getter
     18 is used. This allows the DCAC to be used from any thread
     19 and was required to fix a bug when Dcc called
     20 PhoneBase#notifyDataConnection which calls DCT#getLinkProperties
     21 and DCT#getLinkCapabilities which call Dcc all on the same
     22 thread. Without this change there was a dead lock when
     23 sendMessageSynchronously blocks.
     24 
     25 
     26 == Testing ==
     27 
     28 The following are Intents that can be sent for testing pruproses on
     29 DEBUGGABLE builds (userdebug, eng)
     30 
     31 *) Causes bringUp and retry requests to fail for all DC's
     32 
     33   adb shell am broadcast -a com.android.internal.telephony.dataconnection.action_fail_bringup --ei counter 2 --ei fail_cause -3
     34 
     35 *) Causes all DC's to get torn down, simulating a temporary network outage:
     36 
     37   adb shell am broadcast -a com.android.internal.telephony.dataconnection.action_deactivate_all
     38 
     39 *) To simplify testing we also have detach and attach simulations below where {x} is gsm, cdma or sip
     40 
     41   adb shell am broadcast -a com.android.internal.telephony.{x}.action_detached
     42   adb shell am broadcast -a com.android.internal.telephony.{x}.action_attached
     43 
     44 
     45 == System properties for Testing ==
     46 
     47 On debuggable builds (userdebug, eng) you can change additional
     48 settings through system properties.  These properties can be set with
     49 "setprop" for the current boot, or added to local.prop to persist
     50 across boots.
     51 
     52 device# setprop key value
     53 
     54 device# echo "key=value" >> /data/local.prop
     55 device# chmod 644 /data/local.prop
     56 
     57 
     58 -- Retry configuration --
     59 
     60 You can replace the connection retry configuration.  For example, you
     61 could change it to perform 4 retries at 5 second intervals:
     62 
     63 device# setprop test.data_retry_config "5000,5000,5000"
     64 
     65 
     66 -- Roaming --
     67 
     68 You can force the telephony stack to always assume that it's roaming
     69 to verify higher-level framework functionality:
     70 
     71 device# setprop telephony.test.forceRoaming true
     72