@@ -80,7 +80,7 @@ def id(self):
80
80
elif chip_id == chips .GENERIC_X86 :
81
81
board_id = boards .GENERIC_LINUX_PC
82
82
elif chip_id == chips .SUN8I :
83
- board_id = self ._armbian_id ()
83
+ board_id = self ._armbian_id () or self . _allwinner_variants_id ()
84
84
elif chip_id == chips .SAMA5 :
85
85
board_id = self ._sama5_id ()
86
86
elif chip_id == chips .IMX8MX :
@@ -136,9 +136,9 @@ def id(self):
136
136
elif chip_id == chips .H6 :
137
137
board_id = self ._pine64_id ()
138
138
elif chip_id == chips .H5 :
139
- board_id = self ._armbian_id ()
139
+ board_id = self ._armbian_id () or self . _allwinner_variants_id ()
140
140
elif chip_id == chips .H616 :
141
- board_id = self ._armbian_id ()
141
+ board_id = self ._armbian_id () or self . _allwinner_variants_id ()
142
142
elif chip_id == chips .A33 :
143
143
board_id = self ._clockwork_pi_id ()
144
144
elif chip_id == chips .RK3308 :
@@ -434,6 +434,27 @@ def _asus_tinker_board_id(self):
434
434
board = boards ._ASUS_TINKER_BOARD_IDS
435
435
return board
436
436
437
+ def _allwinner_variants_id (self ):
438
+ """Try to detect the id of allwinner based board. (orangepi, nanopi)"""
439
+ board_value = self .detector .get_device_model ()
440
+ board = None
441
+ if not board_value :
442
+ return board
443
+ board_value = board_value .lower ()
444
+ chip_id = self .detector .chip .id
445
+ if "nanopi" in board_value :
446
+ if "neo" in board_value and "SUN8I" in chip_id :
447
+ board = boards .NANOPI_NEO_AIR
448
+ # TODO: Add other specifc board contexts here
449
+ elif "orange pi" in board_value :
450
+ if "zero" in board_value :
451
+ if "H5" in chip_id :
452
+ board = boards .ORANGE_PI_ZERO_PLUS_2H5
453
+ elif "H616" in chip_id :
454
+ board = boards .ORANGE_PI_ZERO_2
455
+ # TODO: Add other specifc board contexts here
456
+ return board
457
+
437
458
@property
438
459
def any_nanopi (self ):
439
460
"""Check whether the current board is any defined Nano Pi."""
0 commit comments