diff --git modules/system/system.admin.inc modules/system/system.admin.inc
index b951d63..e9622b4 100644
--- modules/system/system.admin.inc
+++ modules/system/system.admin.inc
@@ -922,7 +922,7 @@ function system_modules($form, $form_state = array()) {
     foreach ($module->required_by as $required_by => $v) {
       // Hidden modules are unset already.
       if (isset($files[$required_by])) {
-        if ($files[$required_by]->status == 1) {
+        if ($files[$required_by]->status == 1 && $module->status == 1) {
           $extra['required_by'][] = t('@module (<span class="admin-enabled">enabled</span>)', array('@module' => $files[$required_by]->info['name']));
           $extra['disabled'] = TRUE;
         }
diff --git modules/system/system.install modules/system/system.install
index 4292210..026a9e3 100644
--- modules/system/system.install
+++ modules/system/system.install
@@ -60,6 +60,9 @@ function system_requirements($phase) {
     $requirements['php'] = array(
       'title' => $t('PHP'),
       'value' => ($phase == 'runtime') ? $phpversion .' ('. l($t('more information'), 'admin/reports/status/php') .')' : $phpversion,
+      // We need to add an empty description here to potentially fill it when
+      // checking PHP versions of updated modules (see below).
+      'description' => '',
     );
   }
   else {
@@ -353,6 +356,63 @@ function system_requirements($phase) {
     $requirements['update access']['title'] = $t('Access to update.php');
   }
 
+  // Display an error if a newly introduced dependency in a module is not resolved.
+  // During installation we cannot access the database so we need to use the
+  // internal helper function.
+  $files = drupal_installation_attempted() ? _module_build_dependencies(ksort(_system_rebuild_module_data())) : system_rebuild_module_data();
+  foreach ($files as $module => $file) {
+    if (!$file->status) {
+      continue;
+    }
+    $name = $file->info['name'];
+    // Check the module's PHP version.
+    $php = $file->info['php'];
+    if (version_compare($php, PHP_VERSION, '>')) {
+      $requirements['php']['description'] .= $t('@name requires at least PHP @version.', array('@name' => $name, '@version' => $php));
+      $requirements['php']['severity'] = REQUIREMENT_ERROR;
+    }
+    // Check the module's required modules.
+    foreach ($file->requires as $requirement) {
+      $required_module = $requirement['name'];
+
+      // Check if the module exists.
+      if (!isset($files[$required_module])) {
+        $requirements["$module-$required_module"] = array(
+          'title' => $t('Unresolved dependency'),
+          'description' => $t('@name requires this module.', array('@name' => $name)),
+          'value' => t('@required_name (Missing)', array('@required_name' => $required_module)),
+          'severity' => REQUIREMENT_ERROR,
+        );
+        continue;
+      }
+      // Check the module's status.
+      $required_module_data = $files[$required_module];
+      $required_name = $required_module_data->info['name'];
+      // Check the module's version.
+      $version = str_replace(DRUPAL_CORE_COMPATIBILITY . '-', '', $required_module_data->info['version']);
+      $compatibility = drupal_check_incompatibility($requirement, $version);
+      if (!$required_module_data->status && !$compatibility) {
+        $requirements["$module-$required_module"] = array(
+          'title' => $t('Unresolved dependency'),
+          'description' => $t('@name requires this module.', array('@name' => $name)),
+          'value' => $t('@required_name (Disabled)', array('@required_name' => $required_name)),
+          'severity' => REQUIREMENT_ERROR,
+        );
+      }
+      if ($compatibility) {
+        $compatibility = substr($compatibility, 2);
+        $compatibility = rtrim($compatibility, ")");
+        print_r($compatibility);
+        $requirements["$module-$required_module-version"] = array(
+          'title' => $t('Unresolved dependency'),
+          'description' => $t('@name requires this module and version. Currently using @required_name version @version', array('@name' => $name, '@required_name' => $required_name, '@version' => $version)),
+          'value' => t('@required_name (Version @compatibility required)', array('@required_name' => $required_name, '@version' => $version, '@compatibility' => $compatibility)),
+          'severity' => REQUIREMENT_ERROR,
+        );
+      }
+    }
+  }
+
   // Test Unicode library
   include_once DRUPAL_ROOT . '/includes/unicode.inc';
   $requirements = array_merge($requirements, unicode_requirements());
