@@ -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 :
@@ -438,6 +438,27 @@ def _asus_tinker_board_id(self):
438
438
board = boards ._ASUS_TINKER_BOARD_IDS
439
439
return board
440
440
441
+ def _allwinner_variants_id (self ):
442
+ """Try to detect the id of allwinner based board. (orangepi, nanopi)"""
443
+ board_value = self .detector .get_device_model ()
444
+ board = None
445
+ if not board_value :
446
+ return board
447
+ board_value = board_value .lower ()
448
+ chip_id = self .detector .chip .id
449
+ if "nanopi" in board_value :
450
+ if "neo" in board_value and "SUN8I" in chip_id :
451
+ board = boards .NANOPI_NEO_AIR
452
+ # TODO: Add other specifc board contexts here
453
+ elif "orange pi" in board_value :
454
+ if "zero" in board_value :
455
+ if "H5" in chip_id :
456
+ board = boards .ORANGE_PI_ZERO_PLUS_2H5
457
+ elif "H616" in chip_id :
458
+ board = boards .ORANGE_PI_ZERO_2
459
+ # TODO: Add other specifc board contexts here
460
+ return board
461
+
441
462
@property
442
463
def any_nanopi (self ):
443
464
"""Check whether the current board is any defined Nano Pi."""
0 commit comments